> -----Original Message----- > From: Dmitry Antipov <dmantipov@xxxxxxxxx> > Sent: Thursday, October 19, 2023 5:38 PM > To: Ping-Ke Shih <pkshih@xxxxxxxxxxx> > Cc: Tom Rix <trix@xxxxxxxxxx>; Kalle Valo <kvalo@xxxxxxxxxx>; linux-wireless@xxxxxxxxxxxxxxx; Dmitry > Antipov <dmantipov@xxxxxxxxx> > Subject: [PATCH] wifi: rtw89: fix clang-specific -Wvoid-pointer-to-enum-cast Please point out "fw_element" in subject, so it would be clear to know what we are dealing with. > > When compiling with clang-18, I've noticed the following: > > drivers/net/wireless/realtek/rtw89/fw.c:389:28: warning: cast to smaller > integer type 'enum rtw89_fw_type' from 'const void *' [-Wvoid-pointer-to-enum-cast] > 389 | enum rtw89_fw_type type = (enum rtw89_fw_type)data; > | ^~~~~~~~~~~~~~~~~~~~~~~~ > drivers/net/wireless/realtek/rtw89/fw.c:569:13: warning: cast to smaller > integer type 'enum rtw89_rf_path' from 'const void *' [-Wvoid-pointer-to-enum-cast] > 569 | rf_path = (enum rtw89_rf_path)data; > | ^~~~~~~~~~~~~~~~~~~~~~~~ > > So avoid brutal everything-to-const-void-and-back casts, introduce > 'union rtw89_fw_element_data' to pass parameters to element handler > callbacks, and adjust all of the related bits accordingly. Compile > tested only. > > Signed-off-by: Dmitry Antipov <dmantipov@xxxxxxxxx> > --- > drivers/net/wireless/realtek/rtw89/fw.c | 81 +++++++++++++++---------- > 1 file changed, 50 insertions(+), 31 deletions(-) > > diff --git a/drivers/net/wireless/realtek/rtw89/fw.c b/drivers/net/wireless/realtek/rtw89/fw.c > index 7cfcf536d6fe..13a98c44d304 100644 > --- a/drivers/net/wireless/realtek/rtw89/fw.c > +++ b/drivers/net/wireless/realtek/rtw89/fw.c > @@ -13,6 +13,20 @@ > #include "reg.h" > #include "util.h" > > +union rtw89_fw_element_data { "fw_element_data" could be confusing, because it looks like data from firmware file. Prefer "fw_element_arg" or "fw_element_var", because the certain handler can handle various cases of fw_element_id. Then, third argument of handler becomes 'const union rtw89_fw_element_arg arg'. > + size_t offset; > + enum rtw89_rf_path path; > + enum rtw89_fw_type type; 'rf_path' and 'fw_type' would be clearer. > +}; > + > +struct rtw89_fw_element_handler { > + int (*fn)(struct rtw89_dev *rtwdev, > + const struct rtw89_fw_element_hdr *elm, > + const union rtw89_fw_element_data data); > + const union rtw89_fw_element_data data; > + const char *name; > +}; > + > static void rtw89_fw_c2h_cmd_handle(struct rtw89_dev *rtwdev, > struct sk_buff *skb); > static int rtw89_h2c_tx_and_wait(struct rtw89_dev *rtwdev, struct sk_buff *skb, > @@ -384,9 +398,9 @@ int __rtw89_fw_recognize(struct rtw89_dev *rtwdev, enum rtw89_fw_type type, > static > int __rtw89_fw_recognize_from_elm(struct rtw89_dev *rtwdev, > const struct rtw89_fw_element_hdr *elm, > - const void *data) > + const union rtw89_fw_element_data data) > { > - enum rtw89_fw_type type = (enum rtw89_fw_type)data; > + enum rtw89_fw_type type = data.type; > struct rtw89_fw_suit *fw_suit; > > fw_suit = rtw89_fw_suit_get(rtwdev, type); > @@ -542,7 +556,7 @@ int rtw89_fw_recognize(struct rtw89_dev *rtwdev) > static > int rtw89_build_phy_tbl_from_elm(struct rtw89_dev *rtwdev, > const struct rtw89_fw_element_hdr *elm, > - const void *data) > + const union rtw89_fw_element_data data) > { > struct rtw89_fw_elm_info *elm_info = &rtwdev->fw.elm_info; > struct rtw89_phy_table *tbl; > @@ -566,7 +580,7 @@ int rtw89_build_phy_tbl_from_elm(struct rtw89_dev *rtwdev, > case RTW89_FW_ELEMENT_ID_RADIO_B: > case RTW89_FW_ELEMENT_ID_RADIO_C: > case RTW89_FW_ELEMENT_ID_RADIO_D: > - rf_path = (enum rtw89_rf_path)data; > + rf_path = data.path; > idx = elm->u.reg2.idx; > > elm_info->rf_radio[idx] = tbl; > @@ -604,10 +618,10 @@ int rtw89_build_phy_tbl_from_elm(struct rtw89_dev *rtwdev, > static > int rtw89_fw_recognize_txpwr_from_elm(struct rtw89_dev *rtwdev, > const struct rtw89_fw_element_hdr *elm, > - const void *data) > + union rtw89_fw_element_data data) const union rtw89_fw_element_data data miss 'const' here. > { > const struct __rtw89_fw_txpwr_element *txpwr_elm = &elm->u.txpwr; > - const unsigned long offset = (const unsigned long)data; > + const unsigned long offset = data.offset; > struct rtw89_efuse *efuse = &rtwdev->efuse; > struct rtw89_txpwr_conf *conf; > > @@ -644,64 +658,69 @@ int rtw89_fw_recognize_txpwr_from_elm(struct rtw89_dev *rtwdev, > return 0; > } > > -struct rtw89_fw_element_handler { > - int (*fn)(struct rtw89_dev *rtwdev, > - const struct rtw89_fw_element_hdr *elm, const void *data); > - const void *data; > - const char *name; > -}; > - > static const struct rtw89_fw_element_handler __fw_element_handlers[] = { > [RTW89_FW_ELEMENT_ID_BBMCU0] = {__rtw89_fw_recognize_from_elm, > - (const void *)RTW89_FW_BBMCU0, NULL}, > + { .type = RTW89_FW_BBMCU0 }, NULL}, > [RTW89_FW_ELEMENT_ID_BBMCU1] = {__rtw89_fw_recognize_from_elm, > - (const void *)RTW89_FW_BBMCU1, NULL}, > - [RTW89_FW_ELEMENT_ID_BB_REG] = {rtw89_build_phy_tbl_from_elm, NULL, "BB"}, > - [RTW89_FW_ELEMENT_ID_BB_GAIN] = {rtw89_build_phy_tbl_from_elm, NULL, NULL}, > + { .type = RTW89_FW_BBMCU1 }, NULL}, > + [RTW89_FW_ELEMENT_ID_BB_REG] = {rtw89_build_phy_tbl_from_elm, > + { 0 }, "BB"}, Can we just '{}' instead? And, straighten it to single one line as before, like [RTW89_FW_ELEMENT_ID_BB_REG] = {rtw89_build_phy_tbl_from_elm, {], "BB"}, > + [RTW89_FW_ELEMENT_ID_BB_GAIN] = {rtw89_build_phy_tbl_from_elm, > + { 0 }, NULL}, > [RTW89_FW_ELEMENT_ID_RADIO_A] = {rtw89_build_phy_tbl_from_elm, > - (const void *)RF_PATH_A, "radio A"}, > + { .path = RF_PATH_A }, "radio A"}, > [RTW89_FW_ELEMENT_ID_RADIO_B] = {rtw89_build_phy_tbl_from_elm, > - (const void *)RF_PATH_B, NULL}, > + { .path = RF_PATH_B }, NULL}, > [RTW89_FW_ELEMENT_ID_RADIO_C] = {rtw89_build_phy_tbl_from_elm, > - (const void *)RF_PATH_C, NULL}, > + { .path = RF_PATH_C }, NULL}, > [RTW89_FW_ELEMENT_ID_RADIO_D] = {rtw89_build_phy_tbl_from_elm, > - (const void *)RF_PATH_D, NULL}, > - [RTW89_FW_ELEMENT_ID_RF_NCTL] = {rtw89_build_phy_tbl_from_elm, NULL, "NCTL"}, > + { .path = RF_PATH_D }, NULL}, > + [RTW89_FW_ELEMENT_ID_RF_NCTL] = {rtw89_build_phy_tbl_from_elm, > + { 0 }, "NCTL"}, > [RTW89_FW_ELEMENT_ID_TXPWR_BYRATE] = { > rtw89_fw_recognize_txpwr_from_elm, > - (const void *)offsetof(struct rtw89_rfe_data, byrate.conf), "TXPWR", > + { .offset = offsetof(struct rtw89_rfe_data, byrate.conf) }, > + "TXPWR", Prefer keeping original single-one-line style. > }, > [RTW89_FW_ELEMENT_ID_TXPWR_LMT_2GHZ] = { > rtw89_fw_recognize_txpwr_from_elm, > - (const void *)offsetof(struct rtw89_rfe_data, lmt_2ghz.conf), NULL, > + { .offset = offsetof(struct rtw89_rfe_data, lmt_2ghz.conf) }, > + NULL, > }, > [RTW89_FW_ELEMENT_ID_TXPWR_LMT_5GHZ] = { > rtw89_fw_recognize_txpwr_from_elm, > - (const void *)offsetof(struct rtw89_rfe_data, lmt_5ghz.conf), NULL, > + { .offset = offsetof(struct rtw89_rfe_data, lmt_5ghz.conf) }, > + NULL, > }, > [RTW89_FW_ELEMENT_ID_TXPWR_LMT_6GHZ] = { > rtw89_fw_recognize_txpwr_from_elm, > - (const void *)offsetof(struct rtw89_rfe_data, lmt_6ghz.conf), NULL, > + { .offset = offsetof(struct rtw89_rfe_data, lmt_6ghz.conf) }, > + NULL, > }, > [RTW89_FW_ELEMENT_ID_TXPWR_LMT_RU_2GHZ] = { > rtw89_fw_recognize_txpwr_from_elm, > - (const void *)offsetof(struct rtw89_rfe_data, lmt_ru_2ghz.conf), NULL, > + { .offset = offsetof(struct rtw89_rfe_data, lmt_ru_2ghz.conf) }, > + NULL, > }, > [RTW89_FW_ELEMENT_ID_TXPWR_LMT_RU_5GHZ] = { > rtw89_fw_recognize_txpwr_from_elm, > - (const void *)offsetof(struct rtw89_rfe_data, lmt_ru_5ghz.conf), NULL, > + { .offset = offsetof(struct rtw89_rfe_data, lmt_ru_5ghz.conf) }, > + NULL, > }, > [RTW89_FW_ELEMENT_ID_TXPWR_LMT_RU_6GHZ] = { > rtw89_fw_recognize_txpwr_from_elm, > - (const void *)offsetof(struct rtw89_rfe_data, lmt_ru_6ghz.conf), NULL, > + { .offset = offsetof(struct rtw89_rfe_data, lmt_ru_6ghz.conf) }, > + NULL, > }, > [RTW89_FW_ELEMENT_ID_TX_SHAPE_LMT] = { > rtw89_fw_recognize_txpwr_from_elm, > - (const void *)offsetof(struct rtw89_rfe_data, tx_shape_lmt.conf), NULL, > + { .offset = offsetof(struct rtw89_rfe_data, tx_shape_lmt.conf) }, > + NULL, > }, > [RTW89_FW_ELEMENT_ID_TX_SHAPE_LMT_RU] = { > rtw89_fw_recognize_txpwr_from_elm, > - (const void *)offsetof(struct rtw89_rfe_data, tx_shape_lmt_ru.conf), NULL, > + { .offset = offsetof(struct rtw89_rfe_data, tx_shape_lmt_ru.conf) }, > + NULL, > }, > }; > > -- > 2.41.0