rtlwifi: remove duplicate C2H handler
Merge duplicate C2H handler and implement the handler in base.c. Signed-off-by: Ping-Ke Shih <pkshih@realtek.com> Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
This commit is contained in:
parent
16cefa449c
commit
daf026ae5f
|
@ -2306,6 +2306,78 @@ label_err:
|
|||
}
|
||||
EXPORT_SYMBOL(rtl_c2hcmd_enqueue);
|
||||
|
||||
void rtl_c2h_content_parsing(struct ieee80211_hw *hw, u8 cmd_id,
|
||||
u8 cmd_len, u8 *cmd_buf)
|
||||
{
|
||||
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
||||
struct rtl_hal_ops *hal_ops = rtlpriv->cfg->ops;
|
||||
const struct rtl_btc_ops *btc_ops = rtlpriv->btcoexist.btc_ops;
|
||||
|
||||
switch (cmd_id) {
|
||||
case C2H_DBG:
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_LOUD, "[C2H], C2H_DBG!!\n");
|
||||
break;
|
||||
case C2H_TXBF:
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_TRACE,
|
||||
"[C2H], C2H_TXBF!!\n");
|
||||
break;
|
||||
case C2H_TX_REPORT:
|
||||
rtl_tx_report_handler(hw, cmd_buf, cmd_len);
|
||||
break;
|
||||
case C2H_RA_RPT:
|
||||
if (hal_ops->c2h_ra_report_handler)
|
||||
hal_ops->c2h_ra_report_handler(hw, cmd_buf, cmd_len);
|
||||
break;
|
||||
case C2H_BT_INFO:
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_TRACE,
|
||||
"[C2H], C2H_BT_INFO!!\n");
|
||||
if (rtlpriv->cfg->ops->get_btc_status())
|
||||
btc_ops->btc_btinfo_notify(rtlpriv, cmd_buf, cmd_len);
|
||||
break;
|
||||
case C2H_BT_MP:
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_TRACE,
|
||||
"[C2H], C2H_BT_MP!!\n");
|
||||
if (rtlpriv->cfg->ops->get_btc_status())
|
||||
btc_ops->btc_btmpinfo_notify(rtlpriv, cmd_buf, cmd_len);
|
||||
break;
|
||||
default:
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_TRACE,
|
||||
"[C2H], Unknown packet!! cmd_id(%#X)!\n", cmd_id);
|
||||
break;
|
||||
}
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(rtl_c2h_content_parsing);
|
||||
|
||||
void rtl_c2h_packet_handler(struct ieee80211_hw *hw, u8 *buffer, u8 len)
|
||||
{
|
||||
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
||||
u8 c2h_cmd_id = 0, c2h_cmd_seq = 0, c2h_cmd_len = 0;
|
||||
u8 *tmp_buf = NULL;
|
||||
|
||||
c2h_cmd_id = buffer[0];
|
||||
c2h_cmd_seq = buffer[1];
|
||||
c2h_cmd_len = len - 2;
|
||||
tmp_buf = buffer + 2;
|
||||
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_TRACE,
|
||||
"[C2H packet], c2hCmdId=0x%x, c2hCmdSeq=0x%x, c2hCmdLen=%d\n",
|
||||
c2h_cmd_id, c2h_cmd_seq, c2h_cmd_len);
|
||||
|
||||
RT_PRINT_DATA(rtlpriv, COMP_FW, DBG_TRACE,
|
||||
"[C2H packet], Content Hex:\n", tmp_buf, c2h_cmd_len);
|
||||
|
||||
switch (c2h_cmd_id) {
|
||||
case C2H_BT_INFO:
|
||||
case C2H_BT_MP:
|
||||
rtl_c2hcmd_enqueue(hw, c2h_cmd_id, c2h_cmd_len, tmp_buf);
|
||||
break;
|
||||
default:
|
||||
rtl_c2h_content_parsing(hw, c2h_cmd_id, c2h_cmd_len, tmp_buf);
|
||||
break;
|
||||
}
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(rtl_c2h_packet_handler);
|
||||
|
||||
void rtl_c2hcmd_launcher(struct ieee80211_hw *hw, int exec)
|
||||
{
|
||||
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
||||
|
|
|
@ -162,6 +162,9 @@ void rtl_fwevt_wq_callback(void *data);
|
|||
void rtl_c2hcmd_wq_callback(void *data);
|
||||
void rtl_c2hcmd_launcher(struct ieee80211_hw *hw, int exec);
|
||||
void rtl_c2hcmd_enqueue(struct ieee80211_hw *hw, u8 tag, u8 len, u8 *val);
|
||||
void rtl_c2h_content_parsing(struct ieee80211_hw *hw, u8 c2h_cmd_id,
|
||||
u8 c2h_cmd_len, u8 *tmp_buf);
|
||||
void rtl_c2h_packet_handler(struct ieee80211_hw *hw, u8 *buffer, u8 len);
|
||||
|
||||
u8 rtl_mrate_idx_to_arfr_id(struct ieee80211_hw *hw, u8 rate_index,
|
||||
enum wireless_mode wirelessmode);
|
||||
|
|
|
@ -884,78 +884,3 @@ void rtl92ee_c2h_ra_report_handler(struct ieee80211_hw *hw,
|
|||
|
||||
rtl92ee_dm_dynamic_arfb_select(hw, rate, collision_state);
|
||||
}
|
||||
|
||||
void rtl92ee_c2h_content_parsing(struct ieee80211_hw *hw, u8 c2h_cmd_id,
|
||||
u8 c2h_cmd_len, u8 *tmp_buf)
|
||||
{
|
||||
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
||||
struct rtl_hal_ops *hal_ops = rtlpriv->cfg->ops;
|
||||
struct rtl_btc_ops *btc_ops = rtlpriv->btcoexist.btc_ops;
|
||||
|
||||
switch (c2h_cmd_id) {
|
||||
case C2H_DBG:
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_TRACE,
|
||||
"[C2H], C2H_8723BE_DBG!!\n");
|
||||
break;
|
||||
case C2H_TXBF:
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_TRACE,
|
||||
"[C2H], C2H_8192E_TXBF!!\n");
|
||||
break;
|
||||
case C2H_TX_REPORT:
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_TRACE ,
|
||||
"[C2H], C2H_8723BE_TX_REPORT!\n");
|
||||
rtl_tx_report_handler(hw, tmp_buf, c2h_cmd_len);
|
||||
break;
|
||||
case C2H_BT_INFO:
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_TRACE,
|
||||
"[C2H], C2H_8723BE_BT_INFO!!\n");
|
||||
if (rtlpriv->cfg->ops->get_btc_status())
|
||||
btc_ops->btc_btinfo_notify(rtlpriv, tmp_buf,
|
||||
c2h_cmd_len);
|
||||
break;
|
||||
case C2H_BT_MP:
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_TRACE,
|
||||
"[C2H], C2H_8723BE_BT_MP!!\n");
|
||||
if (rtlpriv->cfg->ops->get_btc_status())
|
||||
btc_ops->btc_btmpinfo_notify(rtlpriv, tmp_buf,
|
||||
c2h_cmd_len);
|
||||
break;
|
||||
case C2H_RA_RPT:
|
||||
hal_ops->c2h_ra_report_handler(hw, tmp_buf, c2h_cmd_len);
|
||||
break;
|
||||
default:
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_TRACE,
|
||||
"[C2H], Unknown packet!! CmdId(%#X)!\n", c2h_cmd_id);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void rtl92ee_c2h_packet_handler(struct ieee80211_hw *hw, u8 *buffer, u8 len)
|
||||
{
|
||||
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
||||
u8 c2h_cmd_id = 0, c2h_cmd_seq = 0, c2h_cmd_len = 0;
|
||||
u8 *tmp_buf = NULL;
|
||||
|
||||
c2h_cmd_id = buffer[0];
|
||||
c2h_cmd_seq = buffer[1];
|
||||
c2h_cmd_len = len - 2;
|
||||
tmp_buf = buffer + 2;
|
||||
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_TRACE,
|
||||
"[C2H packet], c2hCmdId=0x%x, c2hCmdSeq=0x%x, c2hCmdLen=%d\n",
|
||||
c2h_cmd_id, c2h_cmd_seq, c2h_cmd_len);
|
||||
|
||||
RT_PRINT_DATA(rtlpriv, COMP_FW, DBG_TRACE,
|
||||
"[C2H packet], Content Hex:\n", tmp_buf, c2h_cmd_len);
|
||||
|
||||
switch (c2h_cmd_id) {
|
||||
case C2H_BT_INFO:
|
||||
case C2H_BT_MP:
|
||||
rtl_c2hcmd_enqueue(hw, c2h_cmd_id, c2h_cmd_len, tmp_buf);
|
||||
break;
|
||||
default:
|
||||
rtl92ee_c2h_content_parsing(hw, c2h_cmd_id, c2h_cmd_len,
|
||||
tmp_buf);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -179,9 +179,6 @@ void rtl92ee_set_fw_pwrmode_cmd(struct ieee80211_hw *hw, u8 mode);
|
|||
void rtl92ee_set_fw_media_status_rpt_cmd(struct ieee80211_hw *hw, u8 mstatus);
|
||||
void rtl92ee_set_fw_rsvdpagepkt(struct ieee80211_hw *hw, bool b_dl_finished);
|
||||
void rtl92ee_set_p2p_ps_offload_cmd(struct ieee80211_hw *hw, u8 p2p_ps_state);
|
||||
void rtl92ee_c2h_packet_handler(struct ieee80211_hw *hw, u8 *buffer, u8 len);
|
||||
void rtl92ee_c2h_content_parsing(struct ieee80211_hw *hw, u8 c2h_cmd_id,
|
||||
u8 c2h_cmd_len, u8 *tmp_buf);
|
||||
void rtl92ee_c2h_ra_report_handler(struct ieee80211_hw *hw,
|
||||
u8 *cmd_buf, u8 cmd_len);
|
||||
#endif
|
||||
|
|
|
@ -251,7 +251,7 @@ static struct rtl_hal_ops rtl8192ee_hal_ops = {
|
|||
.fill_h2c_cmd = rtl92ee_fill_h2c_cmd,
|
||||
.get_btc_status = rtl92ee_get_btc_status,
|
||||
.rx_command_packet = rtl92ee_rx_command_packet,
|
||||
.c2h_content_parsing = rtl92ee_c2h_content_parsing,
|
||||
.c2h_content_parsing = rtl_c2h_content_parsing,
|
||||
.c2h_ra_report_handler = rtl92ee_c2h_ra_report_handler,
|
||||
};
|
||||
|
||||
|
|
|
@ -1085,7 +1085,7 @@ u32 rtl92ee_rx_command_packet(struct ieee80211_hw *hw,
|
|||
result = 0;
|
||||
break;
|
||||
case C2H_PACKET:
|
||||
rtl92ee_c2h_packet_handler(hw, skb->data, (u8)skb->len);
|
||||
rtl_c2h_packet_handler(hw, skb->data, (u8)skb->len);
|
||||
result = 1;
|
||||
break;
|
||||
default:
|
||||
|
|
|
@ -703,72 +703,3 @@ void rtl8723be_set_p2p_ps_offload_cmd(struct ieee80211_hw *hw,
|
|||
rtl8723be_fill_h2c_cmd(hw, H2C_8723B_P2P_PS_OFFLOAD, 1,
|
||||
(u8 *)p2p_ps_offload);
|
||||
}
|
||||
|
||||
void rtl8723be_c2h_content_parsing(struct ieee80211_hw *hw,
|
||||
u8 c2h_cmd_id,
|
||||
u8 c2h_cmd_len, u8 *tmp_buf)
|
||||
{
|
||||
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
||||
struct rtl_btc_ops *btc_ops = rtlpriv->btcoexist.btc_ops;
|
||||
|
||||
switch (c2h_cmd_id) {
|
||||
case C2H_DBG:
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_TRACE,
|
||||
"[C2H], C2H_8723BE_DBG!!\n");
|
||||
break;
|
||||
case C2H_TX_REPORT:
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_TRACE,
|
||||
"[C2H], C2H_8723BE_TX_REPORT!\n");
|
||||
rtl_tx_report_handler(hw, tmp_buf, c2h_cmd_len);
|
||||
break;
|
||||
case C2H_BT_INFO:
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_TRACE,
|
||||
"[C2H], C2H_8723BE_BT_INFO!!\n");
|
||||
if (rtlpriv->cfg->ops->get_btc_status())
|
||||
btc_ops->btc_btinfo_notify(rtlpriv, tmp_buf,
|
||||
c2h_cmd_len);
|
||||
break;
|
||||
case C2H_BT_MP:
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_TRACE,
|
||||
"[C2H], C2H_8723BE_BT_MP!!\n");
|
||||
if (rtlpriv->cfg->ops->get_btc_status())
|
||||
btc_ops->btc_btmpinfo_notify(rtlpriv, tmp_buf,
|
||||
c2h_cmd_len);
|
||||
break;
|
||||
default:
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_TRACE,
|
||||
"[C2H], Unknown packet!! CmdId(%#X)!\n", c2h_cmd_id);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void rtl8723be_c2h_packet_handler(struct ieee80211_hw *hw, u8 *buffer, u8 len)
|
||||
{
|
||||
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
||||
u8 c2h_cmd_id = 0, c2h_cmd_seq = 0, c2h_cmd_len = 0;
|
||||
u8 *tmp_buf = NULL;
|
||||
|
||||
c2h_cmd_id = buffer[0];
|
||||
c2h_cmd_seq = buffer[1];
|
||||
c2h_cmd_len = len - 2;
|
||||
tmp_buf = buffer + 2;
|
||||
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_TRACE,
|
||||
"[C2H packet], c2hCmdId=0x%x, c2hCmdSeq=0x%x, c2hCmdLen=%d\n",
|
||||
c2h_cmd_id, c2h_cmd_seq, c2h_cmd_len);
|
||||
|
||||
RT_PRINT_DATA(rtlpriv, COMP_FW, DBG_TRACE,
|
||||
"[C2H packet], Content Hex:\n", tmp_buf, c2h_cmd_len);
|
||||
|
||||
switch (c2h_cmd_id) {
|
||||
case C2H_BT_INFO:
|
||||
case C2H_BT_MP:
|
||||
rtl_c2hcmd_enqueue(hw, c2h_cmd_id, c2h_cmd_len, tmp_buf);
|
||||
break;
|
||||
|
||||
default:
|
||||
rtl8723be_c2h_content_parsing(hw, c2h_cmd_id, c2h_cmd_len,
|
||||
tmp_buf);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -143,7 +143,4 @@ void rtl8723be_set_fw_pwrmode_cmd(struct ieee80211_hw *hw, u8 mode);
|
|||
void rtl8723be_set_fw_media_status_rpt_cmd(struct ieee80211_hw *hw, u8 mstatus);
|
||||
void rtl8723be_set_fw_rsvdpagepkt(struct ieee80211_hw *hw, bool b_dl_finished);
|
||||
void rtl8723be_set_p2p_ps_offload_cmd(struct ieee80211_hw *hw, u8 p2p_ps_state);
|
||||
void rtl8723be_c2h_packet_handler(struct ieee80211_hw *hw, u8 *buffer, u8 len);
|
||||
void rtl8723be_c2h_content_parsing(struct ieee80211_hw *hw, u8 c2h_cmd_id,
|
||||
u8 c2h_cmd_len, u8 *tmp_buf);
|
||||
#endif
|
||||
|
|
|
@ -263,7 +263,7 @@ static struct rtl_hal_ops rtl8723be_hal_ops = {
|
|||
.get_btc_status = rtl8723be_get_btc_status,
|
||||
.rx_command_packet = rtl8723be_rx_command_packet,
|
||||
.is_fw_header = is_fw_header,
|
||||
.c2h_content_parsing = rtl8723be_c2h_content_parsing,
|
||||
.c2h_content_parsing = rtl_c2h_content_parsing,
|
||||
};
|
||||
|
||||
static struct rtl_mod_params rtl8723be_mod_params = {
|
||||
|
|
|
@ -774,8 +774,7 @@ u32 rtl8723be_rx_command_packet(struct ieee80211_hw *hw,
|
|||
result = 0;
|
||||
break;
|
||||
case C2H_PACKET:
|
||||
rtl8723be_c2h_packet_handler(hw, skb->data,
|
||||
(u8)skb->len);
|
||||
rtl_c2h_packet_handler(hw, skb->data, (u8)skb->len);
|
||||
result = 1;
|
||||
break;
|
||||
default:
|
||||
|
|
|
@ -1917,71 +1917,3 @@ void rtl8821ae_c2h_ra_report_handler(struct ieee80211_hw *hw,
|
|||
|
||||
rtl8821ae_dm_update_init_rate(hw, rate);
|
||||
}
|
||||
|
||||
void rtl8821ae_c2h_content_parsing(struct ieee80211_hw *hw,
|
||||
u8 c2h_cmd_id, u8 c2h_cmd_len,
|
||||
u8 *tmp_buf)
|
||||
{
|
||||
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
||||
struct rtl_hal_ops *hal_ops = rtlpriv->cfg->ops;
|
||||
struct rtl_btc_ops *btc_ops = rtlpriv->btcoexist.btc_ops;
|
||||
|
||||
switch (c2h_cmd_id) {
|
||||
case C2H_DBG:
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_LOUD, "[C2H], C2H_8812_DBG!!\n");
|
||||
break;
|
||||
case C2H_TX_REPORT:
|
||||
rtl_tx_report_handler(hw, tmp_buf, c2h_cmd_len);
|
||||
break;
|
||||
case C2H_RA_RPT:
|
||||
hal_ops->c2h_ra_report_handler(hw, tmp_buf, c2h_cmd_len);
|
||||
break;
|
||||
case C2H_BT_INFO:
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_LOUD,
|
||||
"[C2H], C2H_8812_BT_INFO!!\n");
|
||||
if (rtlpriv->cfg->ops->get_btc_status())
|
||||
btc_ops->btc_btinfo_notify(rtlpriv, tmp_buf,
|
||||
c2h_cmd_len);
|
||||
break;
|
||||
case C2H_BT_MP:
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_TRACE,
|
||||
"[C2H], C2H_8812_BT_MP!!\n");
|
||||
if (rtlpriv->cfg->ops->get_btc_status())
|
||||
btc_ops->btc_btmpinfo_notify(rtlpriv, tmp_buf,
|
||||
c2h_cmd_len);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void rtl8821ae_c2h_packet_handler(struct ieee80211_hw *hw, u8 *buffer,
|
||||
u8 length)
|
||||
{
|
||||
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
||||
u8 c2h_cmd_id = 0, c2h_cmd_seq = 0, c2h_cmd_len = 0;
|
||||
u8 *tmp_buf = NULL;
|
||||
|
||||
c2h_cmd_id = buffer[0];
|
||||
c2h_cmd_seq = buffer[1];
|
||||
c2h_cmd_len = length - 2;
|
||||
tmp_buf = buffer + 2;
|
||||
|
||||
RT_TRACE(rtlpriv, COMP_FW, DBG_LOUD,
|
||||
"[C2H packet], c2hCmdId=0x%x, c2hCmdSeq=0x%x, c2hCmdLen=%d\n",
|
||||
c2h_cmd_id, c2h_cmd_seq, c2h_cmd_len);
|
||||
|
||||
RT_PRINT_DATA(rtlpriv, COMP_FW, DBG_LOUD,
|
||||
"[C2H packet], Content Hex:\n", tmp_buf, c2h_cmd_len);
|
||||
|
||||
switch (c2h_cmd_id) {
|
||||
case C2H_BT_INFO:
|
||||
rtl_c2hcmd_enqueue(hw, c2h_cmd_id, c2h_cmd_len, tmp_buf);
|
||||
break;
|
||||
|
||||
default:
|
||||
rtl8821ae_c2h_content_parsing(hw, c2h_cmd_id, c2h_cmd_len,
|
||||
tmp_buf);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -317,11 +317,6 @@ void rtl8821ae_set_fw_keep_alive_cmd(struct ieee80211_hw *hw, bool func_en);
|
|||
void rtl8821ae_set_fw_disconnect_decision_ctrl_cmd(struct ieee80211_hw *hw,
|
||||
bool enabled);
|
||||
void rtl8821ae_set_fw_global_info_cmd(struct ieee80211_hw *hw);
|
||||
void rtl8821ae_c2h_packet_handler(struct ieee80211_hw *hw,
|
||||
u8 *buffer, u8 length);
|
||||
void rtl8821ae_c2h_content_parsing(struct ieee80211_hw *hw,
|
||||
u8 c2h_cmd_id, u8 c2h_cmd_len,
|
||||
u8 *tmp_buf);
|
||||
void rtl8821ae_c2h_ra_report_handler(struct ieee80211_hw *hw,
|
||||
u8 *cmd_buf, u8 cmd_len);
|
||||
#endif
|
||||
|
|
|
@ -304,7 +304,7 @@ static struct rtl_hal_ops rtl8821ae_hal_ops = {
|
|||
.fill_h2c_cmd = rtl8821ae_fill_h2c_cmd,
|
||||
.get_btc_status = rtl8821ae_get_btc_status,
|
||||
.rx_command_packet = rtl8821ae_rx_command_packet,
|
||||
.c2h_content_parsing = rtl8821ae_c2h_content_parsing,
|
||||
.c2h_content_parsing = rtl_c2h_content_parsing,
|
||||
.c2h_ra_report_handler = rtl8821ae_c2h_ra_report_handler,
|
||||
.add_wowlan_pattern = rtl8821ae_add_wowlan_pattern,
|
||||
};
|
||||
|
|
|
@ -1018,7 +1018,7 @@ u32 rtl8821ae_rx_command_packet(struct ieee80211_hw *hw,
|
|||
result = 0;
|
||||
break;
|
||||
case C2H_PACKET:
|
||||
rtl8821ae_c2h_packet_handler(hw, skb->data, (u8)skb->len);
|
||||
rtl_c2h_packet_handler(hw, skb->data, (u8)skb->len);
|
||||
result = 1;
|
||||
RT_TRACE(rtlpriv, COMP_RECV, DBG_LOUD,
|
||||
"skb->len=%d\n\n", skb->len);
|
||||
|
|
Loading…
Reference in New Issue