hc
2024-08-12 233ab1bd4c5697f5cdec94e60206e8c6ac609b4c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
/*
 * Copyright 2016 Freescale Semiconductor, Inc.
 *
 * SPDX-License-Identifier:    GPL-2.0+
 *
 */
 
#ifdef CONFIG_ARCH_MX7ULP
struct lpuart_fsl_reg32 {
   u32 verid;
   u32 param;
   u32 global;
   u32 pincfg;
   u32 baud;
   u32 stat;
   u32 ctrl;
   u32 data;
   u32 match;
   u32 modir;
   u32 fifo;
   u32 water;
};
#else
struct lpuart_fsl_reg32 {
   u32 baud;
   u32 stat;
   u32 ctrl;
   u32 data;
   u32 match;
   u32 modir;
   u32 fifo;
   u32 water;
};
#endif
 
struct lpuart_fsl {
   u8 ubdh;
   u8 ubdl;
   u8 uc1;
   u8 uc2;
   u8 us1;
   u8 us2;
   u8 uc3;
   u8 ud;
   u8 uma1;
   u8 uma2;
   u8 uc4;
   u8 uc5;
   u8 ued;
   u8 umodem;
   u8 uir;
   u8 reserved;
   u8 upfifo;
   u8 ucfifo;
   u8 usfifo;
   u8 utwfifo;
   u8 utcfifo;
   u8 urwfifo;
   u8 urcfifo;
   u8 rsvd[28];
};
 
/* Used on i.MX7ULP */
#define LPUART_BAUD_BOTHEDGE_MASK    (0x20000)
#define LPUART_BAUD_OSR_MASK        (0x1F000000)
#define LPUART_BAUD_OSR_SHIFT        (24)
#define LPUART_BAUD_OSR(x)        ((((uint32_t)(x)) << 24) & 0x1F000000)
#define LPUART_BAUD_SBR_MASK        (0x1FFF)
#define LPUART_BAUD_SBR_SHIFT        (0U)
#define LPUART_BAUD_SBR(x)        (((uint32_t)(x)) & 0x1FFF)
#define LPUART_BAUD_M10_MASK        (0x20000000U)
#define LPUART_BAUD_SBNS_MASK        (0x2000U)