Skip to content

Commit 82dd45f

Browse files
committed
i2c: tegra: Use FIELD_PREP/FIELD_GET macros
Using these macros helps increase readability of the code. Signed-off-by: Thierry Reding <[email protected]>
1 parent a70ff65 commit 82dd45f

File tree

1 file changed

+40
-41
lines changed

1 file changed

+40
-41
lines changed

drivers/i2c/busses/i2c-tegra.c

Lines changed: 40 additions & 41 deletions
Original file line numberDiff line numberDiff line change
@@ -6,6 +6,7 @@
66
* Author: Colin Cross <[email protected]>
77
*/
88

9+
#include <linux/bitfield.h>
910
#include <linux/clk.h>
1011
#include <linux/delay.h>
1112
#include <linux/dmaengine.h>
@@ -29,11 +30,11 @@
2930
#define BYTES_PER_FIFO_WORD 4
3031

3132
#define I2C_CNFG 0x000
32-
#define I2C_CNFG_DEBOUNCE_CNT_SHIFT 12
33+
#define I2C_CNFG_DEBOUNCE_CNT GENMASK(14, 12)
3334
#define I2C_CNFG_PACKET_MODE_EN BIT(10)
3435
#define I2C_CNFG_NEW_MASTER_FSM BIT(11)
3536
#define I2C_CNFG_MULTI_MASTER_MODE BIT(17)
36-
#define I2C_STATUS 0x01C
37+
#define I2C_STATUS 0x01c
3738
#define I2C_SL_CNFG 0x020
3839
#define I2C_SL_CNFG_NACK BIT(1)
3940
#define I2C_SL_CNFG_NEWSL BIT(2)
@@ -48,10 +49,8 @@
4849
#define I2C_FIFO_CONTROL_TX_TRIG(x) (((x) - 1) << 5)
4950
#define I2C_FIFO_CONTROL_RX_TRIG(x) (((x) - 1) << 2)
5051
#define I2C_FIFO_STATUS 0x060
51-
#define I2C_FIFO_STATUS_TX_MASK 0xF0
52-
#define I2C_FIFO_STATUS_TX_SHIFT 4
53-
#define I2C_FIFO_STATUS_RX_MASK 0x0F
54-
#define I2C_FIFO_STATUS_RX_SHIFT 0
52+
#define I2C_FIFO_STATUS_TX GENMASK(7, 4)
53+
#define I2C_FIFO_STATUS_RX GENMASK(3, 0)
5554
#define I2C_INT_MASK 0x064
5655
#define I2C_INT_STATUS 0x068
5756
#define I2C_INT_BUS_CLR_DONE BIT(11)
@@ -61,7 +60,8 @@
6160
#define I2C_INT_TX_FIFO_DATA_REQ BIT(1)
6261
#define I2C_INT_RX_FIFO_DATA_REQ BIT(0)
6362
#define I2C_CLK_DIVISOR 0x06c
64-
#define I2C_CLK_DIVISOR_STD_FAST_MODE_SHIFT 16
63+
#define I2C_CLK_DIVISOR_STD_FAST_MODE GENMASK(31, 16)
64+
#define I2C_CLK_DIVISOR_HSMODE GENMASK(15, 0)
6565

6666
#define DVC_CTRL_REG1 0x000
6767
#define DVC_CTRL_REG1_INTR_EN BIT(10)
@@ -77,10 +77,11 @@
7777
#define I2C_ERR_UNKNOWN_INTERRUPT BIT(2)
7878
#define I2C_ERR_RX_BUFFER_OVERFLOW BIT(3)
7979

80-
#define PACKET_HEADER0_HEADER_SIZE_SHIFT 28
81-
#define PACKET_HEADER0_PACKET_ID_SHIFT 16
82-
#define PACKET_HEADER0_CONT_ID_SHIFT 12
83-
#define PACKET_HEADER0_PROTOCOL_I2C BIT(4)
80+
#define PACKET_HEADER0_HEADER_SIZE GENMASK(29, 28)
81+
#define PACKET_HEADER0_PACKET_ID GENMASK(23, 16)
82+
#define PACKET_HEADER0_CONT_ID GENMASK(15, 12)
83+
#define PACKET_HEADER0_PROTOCOL GENMASK(7, 4)
84+
#define PACKET_HEADER0_PROTOCOL_I2C 1
8485

8586
#define I2C_HEADER_CONT_ON_NAK BIT(21)
8687
#define I2C_HEADER_READ BIT(19)
@@ -91,21 +92,23 @@
9192
#define I2C_HEADER_SLAVE_ADDR_SHIFT 1
9293

9394
#define I2C_BUS_CLEAR_CNFG 0x084
94-
#define I2C_BC_SCLK_THRESHOLD 9
95-
#define I2C_BC_SCLK_THRESHOLD_SHIFT 16
95+
#define I2C_BC_SCLK_THRESHOLD GENMASK(23, 16)
9696
#define I2C_BC_STOP_COND BIT(2)
9797
#define I2C_BC_TERMINATE BIT(1)
9898
#define I2C_BC_ENABLE BIT(0)
9999
#define I2C_BUS_CLEAR_STATUS 0x088
100100
#define I2C_BC_STATUS BIT(0)
101101

102-
#define I2C_CONFIG_LOAD 0x08C
102+
#define I2C_CONFIG_LOAD 0x08c
103103
#define I2C_MSTR_CONFIG_LOAD BIT(0)
104104

105105
#define I2C_CLKEN_OVERRIDE 0x090
106106
#define I2C_MST_CORE_CLKEN_OVR BIT(0)
107107

108-
#define I2C_CONFIG_LOAD_TIMEOUT 1000000
108+
#define I2C_INTERFACE_TIMING_0 0x094
109+
#define I2C_INTERFACE_TIMING_THIGH GENMASK(13, 8)
110+
#define I2C_INTERFACE_TIMING_TLOW GENMASK(5, 0)
111+
#define I2C_INTERFACE_TIMING_1 0x098
109112

110113
#define I2C_MST_FIFO_CONTROL 0x0b4
111114
#define I2C_MST_FIFO_CONTROL_RX_FLUSH BIT(0)
@@ -114,14 +117,11 @@
114117
#define I2C_MST_FIFO_CONTROL_TX_TRIG(x) (((x) - 1) << 16)
115118

116119
#define I2C_MST_FIFO_STATUS 0x0b8
117-
#define I2C_MST_FIFO_STATUS_RX_MASK 0xff
118-
#define I2C_MST_FIFO_STATUS_RX_SHIFT 0
119-
#define I2C_MST_FIFO_STATUS_TX_MASK 0xff0000
120-
#define I2C_MST_FIFO_STATUS_TX_SHIFT 16
120+
#define I2C_MST_FIFO_STATUS_TX GENMASK(23, 16)
121+
#define I2C_MST_FIFO_STATUS_RX GENMASK(7, 0)
121122

122-
#define I2C_INTERFACE_TIMING_0 0x94
123-
#define I2C_THIGH_SHIFT 8
124-
#define I2C_INTERFACE_TIMING_1 0x98
123+
/* configuration load timeout in microseconds */
124+
#define I2C_CONFIG_LOAD_TIMEOUT 1000000
125125

126126
/* Packet header size in bytes */
127127
#define I2C_PACKET_HEADER_SIZE 12
@@ -495,12 +495,10 @@ static int tegra_i2c_empty_rx_fifo(struct tegra_i2c_dev *i2c_dev)
495495

496496
if (i2c_dev->hw->has_mst_fifo) {
497497
val = i2c_readl(i2c_dev, I2C_MST_FIFO_STATUS);
498-
rx_fifo_avail = (val & I2C_MST_FIFO_STATUS_RX_MASK) >>
499-
I2C_MST_FIFO_STATUS_RX_SHIFT;
498+
rx_fifo_avail = FIELD_GET(I2C_MST_FIFO_STATUS_RX, val);
500499
} else {
501500
val = i2c_readl(i2c_dev, I2C_FIFO_STATUS);
502-
rx_fifo_avail = (val & I2C_FIFO_STATUS_RX_MASK) >>
503-
I2C_FIFO_STATUS_RX_SHIFT;
501+
rx_fifo_avail = FIELD_GET(I2C_FIFO_STATUS_RX, val);
504502
}
505503

506504
/* Rounds down to not include partial word at the end of buf */
@@ -551,12 +549,10 @@ static int tegra_i2c_fill_tx_fifo(struct tegra_i2c_dev *i2c_dev)
551549

552550
if (i2c_dev->hw->has_mst_fifo) {
553551
val = i2c_readl(i2c_dev, I2C_MST_FIFO_STATUS);
554-
tx_fifo_avail = (val & I2C_MST_FIFO_STATUS_TX_MASK) >>
555-
I2C_MST_FIFO_STATUS_TX_SHIFT;
552+
tx_fifo_avail = FIELD_GET(I2C_MST_FIFO_STATUS_TX, val);
556553
} else {
557554
val = i2c_readl(i2c_dev, I2C_FIFO_STATUS);
558-
tx_fifo_avail = (val & I2C_FIFO_STATUS_TX_MASK) >>
559-
I2C_FIFO_STATUS_TX_SHIFT;
555+
tx_fifo_avail = FIELD_GET(I2C_FIFO_STATUS_TX, val);
560556
}
561557

562558
/* Rounds down to not include partial word at the end of buf */
@@ -719,7 +715,7 @@ static int tegra_i2c_init(struct tegra_i2c_dev *i2c_dev, bool clk_reinit)
719715
tegra_dvc_init(i2c_dev);
720716

721717
val = I2C_CNFG_NEW_MASTER_FSM | I2C_CNFG_PACKET_MODE_EN |
722-
(0x2 << I2C_CNFG_DEBOUNCE_CNT_SHIFT);
718+
FIELD_PREP(I2C_CNFG_DEBOUNCE_CNT, 2);
723719

724720
if (i2c_dev->hw->has_multi_master_mode)
725721
val |= I2C_CNFG_MULTI_MASTER_MODE;
@@ -728,9 +724,10 @@ static int tegra_i2c_init(struct tegra_i2c_dev *i2c_dev, bool clk_reinit)
728724
i2c_writel(i2c_dev, 0, I2C_INT_MASK);
729725

730726
/* Make sure clock divisor programmed correctly */
731-
clk_divisor = i2c_dev->hw->clk_divisor_hs_mode;
732-
clk_divisor |= i2c_dev->clk_divisor_non_hs_mode <<
733-
I2C_CLK_DIVISOR_STD_FAST_MODE_SHIFT;
727+
clk_divisor = FIELD_PREP(I2C_CLK_DIVISOR_HSMODE,
728+
i2c_dev->hw->clk_divisor_hs_mode) |
729+
FIELD_PREP(I2C_CLK_DIVISOR_STD_FAST_MODE,
730+
i2c_dev->clk_divisor_non_hs_mode);
734731
i2c_writel(i2c_dev, clk_divisor, I2C_CLK_DIVISOR);
735732

736733
if (i2c_dev->bus_clk_rate > I2C_MAX_STANDARD_MODE_FREQ &&
@@ -745,7 +742,8 @@ static int tegra_i2c_init(struct tegra_i2c_dev *i2c_dev, bool clk_reinit)
745742
}
746743

747744
if (i2c_dev->hw->has_interface_timing_reg) {
748-
val = (thigh << I2C_THIGH_SHIFT) | tlow;
745+
val = FIELD_PREP(I2C_INTERFACE_TIMING_THIGH, thigh) |
746+
FIELD_PREP(I2C_INTERFACE_TIMING_TLOW, tlow);
749747
i2c_writel(i2c_dev, val, I2C_INTERFACE_TIMING_0);
750748
}
751749

@@ -1054,8 +1052,8 @@ static int tegra_i2c_issue_bus_clear(struct i2c_adapter *adap)
10541052
u32 reg;
10551053

10561054
reinit_completion(&i2c_dev->msg_complete);
1057-
reg = (I2C_BC_SCLK_THRESHOLD << I2C_BC_SCLK_THRESHOLD_SHIFT) |
1058-
I2C_BC_STOP_COND | I2C_BC_TERMINATE;
1055+
reg = FIELD_PREP(I2C_BC_SCLK_THRESHOLD, 9) | I2C_BC_STOP_COND |
1056+
I2C_BC_TERMINATE;
10591057
i2c_writel(i2c_dev, reg, I2C_BUS_CLEAR_CNFG);
10601058
if (i2c_dev->hw->has_config_load_reg) {
10611059
err = tegra_i2c_wait_for_config_load(i2c_dev);
@@ -1148,10 +1146,11 @@ static int tegra_i2c_xfer_msg(struct tegra_i2c_dev *i2c_dev,
11481146
}
11491147
}
11501148

1151-
packet_header = (0 << PACKET_HEADER0_HEADER_SIZE_SHIFT) |
1152-
PACKET_HEADER0_PROTOCOL_I2C |
1153-
(i2c_dev->cont_id << PACKET_HEADER0_CONT_ID_SHIFT) |
1154-
(1 << PACKET_HEADER0_PACKET_ID_SHIFT);
1149+
packet_header = FIELD_PREP(PACKET_HEADER0_HEADER_SIZE, 0) |
1150+
FIELD_PREP(PACKET_HEADER0_PROTOCOL,
1151+
PACKET_HEADER0_PROTOCOL_I2C) |
1152+
FIELD_PREP(PACKET_HEADER0_CONT_ID, i2c_dev->cont_id) |
1153+
FIELD_PREP(PACKET_HEADER0_PACKET_ID, 1);
11551154
if (dma && !i2c_dev->msg_read)
11561155
*buffer++ = packet_header;
11571156
else

0 commit comments

Comments
 (0)