@@ -111,13 +111,16 @@
/* RSCFDnCFDCmNCFG - CAN FD only */
#define RCANFD_NCFG_NTSEG2(gpriv, x) \
- (((x) & ((gpriv)->info->nom_bittiming->tseg2_max - 1)) << reg_gen4(gpriv, 25, 24))
+ (((x) & ((gpriv)->info->nom_bittiming->tseg2_max - 1)) << \
+ (gpriv)->info->shift_table[RCANFD_NTSEG2_SH])
#define RCANFD_NCFG_NTSEG1(gpriv, x) \
- (((x) & ((gpriv)->info->nom_bittiming->tseg1_max - 1)) << reg_gen4(gpriv, 17, 16))
+ (((x) & ((gpriv)->info->nom_bittiming->tseg1_max - 1)) << \
+ (gpriv)->info->shift_table[RCANFD_NTSEG1_SH])
#define RCANFD_NCFG_NSJW(gpriv, x) \
- (((x) & ((gpriv)->info->nom_bittiming->sjw_max - 1)) << reg_gen4(gpriv, 10, 11))
+ (((x) & ((gpriv)->info->nom_bittiming->sjw_max - 1)) << \
+ (gpriv)->info->shift_table[RCANFD_NSJW_SH])
#define RCANFD_NCFG_NBRP(x) (((x) & 0x3ff) << 0)
@@ -182,10 +185,12 @@
#define RCANFD_DCFG_DSJW(gpriv, x) (((x) & ((gpriv)->info->data_bittiming->sjw_max - 1)) << 24)
#define RCANFD_DCFG_DTSEG2(gpriv, x) \
- (((x) & ((gpriv)->info->data_bittiming->tseg2_max - 1)) << reg_gen4(gpriv, 16, 20))
+ (((x) & ((gpriv)->info->data_bittiming->tseg2_max - 1)) << \
+ (gpriv)->info->shift_table[RCANFD_DTSEG2_SH])
#define RCANFD_DCFG_DTSEG1(gpriv, x) \
- (((x) & ((gpriv)->info->data_bittiming->tseg1_max - 1)) << reg_gen4(gpriv, 8, 16))
+ (((x) & ((gpriv)->info->data_bittiming->tseg1_max - 1)) << \
+ (gpriv)->info->shift_table[RCANFD_DTSEG1_SH])
#define RCANFD_DCFG_DBRP(x) (((x) & 0xff) << 0)
@@ -227,10 +232,10 @@
/* RSCFDnCFDCFCCk */
#define RCANFD_CFCC_CFTML(gpriv, x) \
- (((x) & (gpriv)->info->max_cftml) << reg_gen4(gpriv, 16, 20))
-#define RCANFD_CFCC_CFM(gpriv, x) (((x) & 0x3) << reg_gen4(gpriv, 8, 16))
+ (((x) & (gpriv)->info->max_cftml) << (gpriv)->info->shift_table[RCANFD_CFTML_SH])
+#define RCANFD_CFCC_CFM(gpriv, x) (((x) & 0x3) << (gpriv)->info->shift_table[RCANFD_CFM_SH])
#define RCANFD_CFCC_CFIM BIT(12)
-#define RCANFD_CFCC_CFDC(gpriv, x) (((x) & 0x7) << reg_gen4(gpriv, 21, 8))
+#define RCANFD_CFCC_CFDC(gpriv, x) (((x) & 0x7) << (gpriv)->info->shift_table[RCANFD_CFDC_SH])
#define RCANFD_CFCC_CFPLS(x) (((x) & 0x7) << 4)
#define RCANFD_CFCC_CFTXIE BIT(2)
#define RCANFD_CFCC_CFE BIT(0)
@@ -511,12 +516,24 @@ enum rcar_canfd_reg_offset_id {
RCANFD_CFOFFSET, /* Transmit/receive FIFO buffer access ID register */
};
+enum rcar_canfd_shift_id {
+ RCANFD_NTSEG2_SH, /* Nominal Bit Rate Time Segment 2 Control */
+ RCANFD_NTSEG1_SH, /* Nominal Bit Rate Time Segment 1 Control */
+ RCANFD_NSJW_SH, /* Nominal Bit Rate Resynchronization Jump Width Control */
+ RCANFD_DTSEG2_SH, /* Data Bit Rate Time Segment 2 Control */
+ RCANFD_DTSEG1_SH, /* Data Bit Rate Time Segment 1 Control */
+ RCANFD_CFTML_SH, /* Common FIFO TX Message Buffer Link */
+ RCANFD_CFM_SH, /* Common FIFO Mode */
+ RCANFD_CFDC_SH, /* Common FIFO Depth Configuration */
+};
+
struct rcar_canfd_global;
struct rcar_canfd_hw_info {
const struct can_bittiming_const *nom_bittiming;
const struct can_bittiming_const *data_bittiming;
const u16 *regs;
+ const u8 *shift_table;
u16 num_supported_rules;
u8 rnc_stride;
u8 rnc_field_width;
@@ -643,10 +660,33 @@ static const u16 rcar_gen4_regs[] = {
[RCANFD_CFOFFSET] = 0x6400,
};
+static const u8 rcar_gen3_shift_table[] = {
+ [RCANFD_NTSEG2_SH] = 24,
+ [RCANFD_NTSEG1_SH] = 16,
+ [RCANFD_NSJW_SH] = 11,
+ [RCANFD_DTSEG2_SH] = 20,
+ [RCANFD_DTSEG1_SH] = 16,
+ [RCANFD_CFTML_SH] = 20,
+ [RCANFD_CFM_SH] = 16,
+ [RCANFD_CFDC_SH] = 8,
+};
+
+static const u8 rcar_gen4_shift_table[] = {
+ [RCANFD_NTSEG2_SH] = 25,
+ [RCANFD_NTSEG1_SH] = 17,
+ [RCANFD_NSJW_SH] = 10,
+ [RCANFD_DTSEG2_SH] = 16,
+ [RCANFD_DTSEG1_SH] = 8,
+ [RCANFD_CFTML_SH] = 16,
+ [RCANFD_CFM_SH] = 8,
+ [RCANFD_CFDC_SH] = 21,
+};
+
static const struct rcar_canfd_hw_info rcar_gen3_hw_info = {
.nom_bittiming = &rcar_canfd_gen3_nom_bittiming_const,
.data_bittiming = &rcar_canfd_gen3_data_bittiming_const,
.regs = rcar_gen3_regs,
+ .shift_table = rcar_gen3_shift_table,
.num_supported_rules = 256,
.rnc_stride = 4,
.rnc_field_width = 8,
@@ -661,6 +701,7 @@ static const struct rcar_canfd_hw_info rcar_gen4_hw_info = {
.nom_bittiming = &rcar_canfd_gen4_nom_bittiming_const,
.data_bittiming = &rcar_canfd_gen4_data_bittiming_const,
.regs = rcar_gen4_regs,
+ .shift_table = rcar_gen4_shift_table,
.num_supported_rules = 512,
.rnc_stride = 2,
.rnc_field_width = 16,
@@ -677,6 +718,7 @@ static const struct rcar_canfd_hw_info rzg2l_hw_info = {
.nom_bittiming = &rcar_canfd_gen3_nom_bittiming_const,
.data_bittiming = &rcar_canfd_gen3_data_bittiming_const,
.regs = rcar_gen3_regs,
+ .shift_table = rcar_gen3_shift_table,
.num_supported_rules = 256,
.rnc_stride = 4,
.rnc_field_width = 8,
@@ -688,17 +730,6 @@ static const struct rcar_canfd_hw_info rzg2l_hw_info = {
};
/* Helper functions */
-static inline bool is_gen4(struct rcar_canfd_global *gpriv)
-{
- return gpriv->info == &rcar_gen4_hw_info;
-}
-
-static inline u32 reg_gen4(struct rcar_canfd_global *gpriv,
- u32 gen4, u32 not_gen4)
-{
- return is_gen4(gpriv) ? gen4 : not_gen4;
-}
-
static inline void rcar_canfd_update(u32 mask, u32 val, u32 __iomem *reg)
{
u32 data = readl(reg);