提交 73ea7350 编写于 作者: N Nathan Huckleberry 提交者: David S. Miller

net: sparx5: Fix return type of sparx5_port_xmit_impl

The ndo_start_xmit field in net_device_ops is expected to be of type
netdev_tx_t (*ndo_start_xmit)(struct sk_buff *skb, struct net_device *dev).

The mismatched return type breaks forward edge kCFI since the underlying
function definition does not match the function hook definition.

The return type of sparx5_port_xmit_impl should be changed from int to
netdev_tx_t.
Reported-by: NDan Carpenter <error27@gmail.com>
Link: https://github.com/ClangBuiltLinux/linux/issues/1703
Cc: llvm@lists.linux.dev
Signed-off-by: NNathan Huckleberry <nhuck@google.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 7a62ed61
...@@ -291,7 +291,7 @@ struct frame_info { ...@@ -291,7 +291,7 @@ struct frame_info {
void sparx5_xtr_flush(struct sparx5 *sparx5, u8 grp); void sparx5_xtr_flush(struct sparx5 *sparx5, u8 grp);
void sparx5_ifh_parse(u32 *ifh, struct frame_info *info); void sparx5_ifh_parse(u32 *ifh, struct frame_info *info);
irqreturn_t sparx5_xtr_handler(int irq, void *_priv); irqreturn_t sparx5_xtr_handler(int irq, void *_priv);
int sparx5_port_xmit_impl(struct sk_buff *skb, struct net_device *dev); netdev_tx_t sparx5_port_xmit_impl(struct sk_buff *skb, struct net_device *dev);
int sparx5_manual_injection_mode(struct sparx5 *sparx5); int sparx5_manual_injection_mode(struct sparx5 *sparx5);
void sparx5_port_inj_timer_setup(struct sparx5_port *port); void sparx5_port_inj_timer_setup(struct sparx5_port *port);
......
...@@ -222,13 +222,13 @@ static int sparx5_inject(struct sparx5 *sparx5, ...@@ -222,13 +222,13 @@ static int sparx5_inject(struct sparx5 *sparx5,
return NETDEV_TX_OK; return NETDEV_TX_OK;
} }
int sparx5_port_xmit_impl(struct sk_buff *skb, struct net_device *dev) netdev_tx_t sparx5_port_xmit_impl(struct sk_buff *skb, struct net_device *dev)
{ {
struct net_device_stats *stats = &dev->stats; struct net_device_stats *stats = &dev->stats;
struct sparx5_port *port = netdev_priv(dev); struct sparx5_port *port = netdev_priv(dev);
struct sparx5 *sparx5 = port->sparx5; struct sparx5 *sparx5 = port->sparx5;
u32 ifh[IFH_LEN]; u32 ifh[IFH_LEN];
int ret; netdev_tx_t ret;
memset(ifh, 0, IFH_LEN * 4); memset(ifh, 0, IFH_LEN * 4);
sparx5_set_port_ifh(ifh, port->portno); sparx5_set_port_ifh(ifh, port->portno);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册