Message ID | 20250402102047.27943-1-biju.das.jz@bp.renesas.com (mailing list archive) |
---|---|
Headers | show |
Series | Add support for RZ/G3E CANFD | expand |
Hi All, Please ignore this series, as I posted a new one[1] as I missed the address field in patch#7 and aborted the git send-email command [1] https://lore.kernel.org/all/20250402102226.28032-1-biju.das.jz@bp.renesas.com/ Cheers, Biju On Wed, Apr 2, 2025 at 11:20 AM Biju Das <biju.das.jz@bp.renesas.com> wrote: > > The CAN-FD module on RZ/G3E is very similar to the one on both R-Car V4H > and RZ/G2L, but differs in some hardware parameters: > * No external clock, but instead has ram clock. > * Support up to 6 channels. > * 20 interrupts. > > v7->v8: > * Collected tags. > * Updated commit description for patch#{5,9,15,16,17}. > * Replaced the macro RCANFD_GERFL_EEF0_7->RCANFD_GERFL_EEF. > * Dropped the redundant macro RCANFD_GERFL_EEF(ch). > * Added patch for dropping the mask operation in RCANFD_GAFLCFG_SETRNC > macro. > * Converted RCANFD_GAFLCFG_SETRNC->rcar_canfd_setrnc(). > * Updated RCANFD_GAFLCFG macro by replacing the parameter ch->w, where w > is the GAFLCFG index used in the hardware manual. > * Renamed the parameter x->page_num in RCANFD_GAFLECTR_AFLPN macro to > make it clear. > * Renamed the parameter x->cftml in RCANFD_CFCC_CFTML macro to make it > clear. > * Updated {rzg2l,car_gen3_hw_info} with ch_interface_mode = 0. > * Updated {rzg2l,rcar_gen3}_hw_info with shared_can_regs = 0. > * Started using struct rcanfd_regs instead of LUT for reg offsets. > * Started using struct rcar_canfd_shift_data instead of LUT for shift > data. > * Renamed only_internal_clks->external_clk to avoid negation. > * Updated rcar_canfd_hw_info tables with external_clk entries. > * Replaced 10->sizeof(name) in scnprintf(). > v6->v7: > * Collected tags > * Replaced 'aswell'->'as well' in patch#11 commit description. > v5->v6: > * Replaced RCANFD_RNC_PER_REG macro with rnc_stride variable. > * Updated commit description for patch#7 and #8 > * Dropped mask_table: > AFLPN_MASK is replaced by max_aflpn variable. > CFTML_MASK is replaced by max_cftml variable. > BITTIMING MASK's are replaced by {nom,data}_bittiming variables. > * Collected tag from Geert. > v4->v5: > * Collected tag from Geert. > * The rules for R-Car Gen3/4 could be kept together, reducing the number > of lines. Similar change for rzg2l-canfd aswell. > * Keeping interrupts and resets together allows to keep a clear > separation between RZ/G2L and RZ/G3E, at the expense of only > a single line. > * Retained the tags for binding patches as it is trivial changes. > * Dropped the unused macro RCANFD_GAFLCFG_GETRNC. > * Updated macro RCANFD_GERFL_ERR by using gpriv->channels_mask and > dropped unused macro RCANFD_GERFL_EEF0_7. > * Replaced RNC mask in RCANFD_GAFLCFG_SETRNC macro by using > info->num_supported_rules variable. > * Updated the macro RCANFD_GAFLCFG by using info->rnc_field_width > variable. > * Updated shift value in RCANFD_GAFLCFG_SETRNC macro by using a formula > (32 - (n % rnc_per_reg + 1) * field_width). > * Replaced the variable name shared_can_reg->shared_can_regs. > * Improved commit description for patch{#11,#12}by replacing has->have. > * Dropped RCANFD_EEF_MASK and RCANFD_RNC_MASK as it is taken > care by gpriv->channels_mask and info->num_supported_rules. > * Dropped RCANFD_FIRST_RNC_SH and RCANFD_SECOND_RNC_SH by using a > formula (32 - (n % rnc_per_reg + 1) * rnc_field_width. > * Improved commit description by "All SoCs supports extenal clock"-> > "All existing SoCs support an external clock". > * Updated error description in probe as "cannot get enabled ram clock" > * Updated r9a09g047_hw_info table. > v3->v4: > * Added Rb tag from Rob for patch#2. > * Added prefix RCANFD_* to enum rcar_canfd_reg_offset_id. > * Added prefix RCANFD_* to enum rcar_canfd_mask_id. > * Added prefix RCANFD_* to enum rcar_canfd_shift_id. > v2->v3: > * Collected tags. > * Dropped reg_gen4() and is_gen4() by adding mask_table, shift_table, > regs, ch_interface_mode and shared_can_reg variables to > struct rcar_canfd_hw_info. > v1->v2: > * Split the series with fixes patch separately. > * Added patch for Simplify rcar_canfd_probe() using > of_get_available_child_by_name() as dependency patch hit on can-next. > * Added Rb tag from Vincent Mailhol. > * Dropped redundant comment from commit description for patch#3. > > Biju Das (19): > dt-bindings: can: renesas,rcar-canfd: Simplify the conditional schema > dt-bindings: can: renesas,rcar-canfd: Document RZ/G3E support > can: rcar_canfd: Use of_get_available_child_by_name() > can: rcar_canfd: Drop RCANFD_GAFLCFG_GETRNC macro > can: rcar_canfd: Update RCANFD_GERFL_ERR macro > can: rcar_canfd: Drop the mask operation in RCANFD_GAFLCFG_SETRNC > macro > can: rcar_canfd: Add rcar_canfd_setrnc() > can: rcar_canfd: Update RCANFD_GAFLCFG macro > can: rcar_canfd: Add rnc_field_width variable to struct > rcar_canfd_hw_info > can: rcar_canfd: Add max_aflpn variable to struct rcar_canfd_hw_info > can: rcar_canfd: Add max_cftml variable to struct rcar_canfd_hw_info > can: rcar_canfd: Add {nom,data}_bittiming variables to struct > rcar_canfd_hw_info > can: rcar_canfd: Add ch_interface_mode variable to struct > rcar_canfd_hw_info > can: rcar_canfd: Add shared_can_regs variable to struct > rcar_canfd_hw_info > can: rcar_canfd: Add struct rcanfd_regs variable to struct > rcar_canfd_hw_info > can: rcar_canfd: Add sh variable to struct rcar_canfd_hw_info > can: rcar_canfd: Add external_clk variable to struct > rcar_canfd_hw_info > can: rcar_canfd: Enhance multi_channel_irqs handling > can: rcar_canfd: Add RZ/G3E support > > .../bindings/net/can/renesas,rcar-canfd.yaml | 171 ++++++++--- > drivers/net/can/rcar/rcar_canfd.c | 277 +++++++++++++----- > 2 files changed, 339 insertions(+), 109 deletions(-) > > -- > 2.43.0 >