uchcom: remove UCHCOM_REG_BREAK2 alias of UCHCOM_REG_LCR1

Also, add definitions for more bits of UCHCOM_REG_LCR1 as seen in the
Linux driver.  UCHCOM_LCR1_PARENB definition was different from that in
the Linux driver and clashed with newly added UCHCOM_LCR1_RX.  I took a
liberty to change UCHCOM_LCR1_PARENB to the Linux definition as it was
unused in the driver anyway.  This change should make
uchcom_cfg_set_break() easier to understand.

Approved by:	hselasky
MFC after:	2 weeks
This commit is contained in:
avg 2018-05-21 21:02:10 +00:00
parent ae0d438d19
commit becbe0e2da

View File

@ -122,7 +122,6 @@ SYSCTL_INT(_hw_usb_uchcom, OID_AUTO, debug, CTLFLAG_RWTUN,
#define UCHCOM_REG_BPS_MOD 0x14 #define UCHCOM_REG_BPS_MOD 0x14
#define UCHCOM_REG_BPS_PAD 0x0F #define UCHCOM_REG_BPS_PAD 0x0F
#define UCHCOM_REG_BREAK1 0x05 #define UCHCOM_REG_BREAK1 0x05
#define UCHCOM_REG_BREAK2 0x18
#define UCHCOM_REG_LCR1 0x18 #define UCHCOM_REG_LCR1 0x18
#define UCHCOM_REG_LCR2 0x25 #define UCHCOM_REG_LCR2 0x25
@ -135,12 +134,14 @@ SYSCTL_INT(_hw_usb_uchcom, OID_AUTO, debug, CTLFLAG_RWTUN,
#define UCHCOM_DTR_MASK 0x20 #define UCHCOM_DTR_MASK 0x20
#define UCHCOM_RTS_MASK 0x40 #define UCHCOM_RTS_MASK 0x40
#define UCHCOM_BRK1_MASK 0x01 #define UCHCOM_BRK_MASK 0x01
#define UCHCOM_BRK2_MASK 0x40
#define UCHCOM_LCR1_MASK 0xAF #define UCHCOM_LCR1_MASK 0xAF
#define UCHCOM_LCR2_MASK 0x07 #define UCHCOM_LCR2_MASK 0x07
#define UCHCOM_LCR1_PARENB 0x80 #define UCHCOM_LCR1_RX 0x80
#define UCHCOM_LCR1_TX 0x40
#define UCHCOM_LCR1_PARENB 0x08
#define UCHCOM_LCR1_CS8 0x03
#define UCHCOM_LCR2_PAREVEN 0x07 #define UCHCOM_LCR2_PAREVEN 0x07
#define UCHCOM_LCR2_PARODD 0x06 #define UCHCOM_LCR2_PARODD 0x06
#define UCHCOM_LCR2_PARMARK 0x05 #define UCHCOM_LCR2_PARMARK 0x05
@ -556,17 +557,17 @@ uchcom_cfg_set_break(struct ucom_softc *ucom, uint8_t onoff)
uint8_t brk1; uint8_t brk1;
uint8_t brk2; uint8_t brk2;
uchcom_read_reg(sc, UCHCOM_REG_BREAK1, &brk1, UCHCOM_REG_BREAK2, &brk2); uchcom_read_reg(sc, UCHCOM_REG_BREAK1, &brk1, UCHCOM_REG_LCR1, &brk2);
if (onoff) { if (onoff) {
/* on - clear bits */ /* on - clear bits */
brk1 &= ~UCHCOM_BRK1_MASK; brk1 &= ~UCHCOM_BRK_MASK;
brk2 &= ~UCHCOM_BRK2_MASK; brk2 &= ~UCHCOM_LCR1_TX;
} else { } else {
/* off - set bits */ /* off - set bits */
brk1 |= UCHCOM_BRK1_MASK; brk1 |= UCHCOM_BRK_MASK;
brk2 |= UCHCOM_BRK2_MASK; brk2 |= UCHCOM_LCR1_TX;
} }
uchcom_write_reg(sc, UCHCOM_REG_BREAK1, brk1, UCHCOM_REG_BREAK2, brk2); uchcom_write_reg(sc, UCHCOM_REG_BREAK1, brk1, UCHCOM_REG_LCR1, brk2);
} }
static int static int