--- zzzz-none-000/linux-5.4.213/net/ipv4/protocol.c 2022-09-15 10:04:56.000000000 +0000 +++ alder-5690pro-762/linux-5.4.213/net/ipv4/protocol.c 2024-08-14 09:02:13.000000000 +0000 @@ -74,3 +74,29 @@ return ret; } EXPORT_SYMBOL(inet_del_offload); + +int inet_update_protocol(const struct net_protocol *new_prot, + unsigned char protocol, const struct net_protocol **old_prot) +{ + int ret; + + rcu_read_lock(); + *old_prot = rcu_dereference(inet_protos[protocol]); + if (!*old_prot) { + rcu_read_unlock(); + return -1; + } + rcu_read_unlock(); + + /* + * old_prot is not protected as cmpxchg is successful only if + * old_prot matches with the value in inet_protos[protocol] + */ + ret = (cmpxchg((const struct net_protocol **)&inet_protos[protocol], + *old_prot, new_prot) == *old_prot) ? 0 : -1; + + synchronize_net(); + + return ret; +} +EXPORT_SYMBOL(inet_update_protocol);