mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-01 02:36:02 +00:00
ipv4: Prepare ip_route_output() to future .flowi4_tos conversion.
Convert the "tos" parameter of ip_route_output() to dscp_t. This way we'll have a dscp_t value directly available when .flowi4_tos will eventually be converted to dscp_t. All ip_route_output() callers but one set this "tos" parameter to 0 and therefore don't need to be adapted to the new prototype. Only br_nf_pre_routing_finish() needs conversion. It can just use ip4h_dscp() to get the DSCP field from the IPv4 header. Signed-off-by: Guillaume Nault <gnault@redhat.com> Reviewed-by: Ido Schimmel <idosch@nvidia.com> Link: https://patch.msgid.link/0f10d031dd44c70aae9bc6e19391cb30d5c2fe71.1730928699.git.gnault@redhat.com Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
parent
334fef7a2c
commit
48171c65f6
@ -156,12 +156,12 @@ static inline struct rtable *ip_route_output_key(struct net *net, struct flowi4
|
|||||||
* structure is only partially set, it may bypass some fib-rules.
|
* structure is only partially set, it may bypass some fib-rules.
|
||||||
*/
|
*/
|
||||||
static inline struct rtable *ip_route_output(struct net *net, __be32 daddr,
|
static inline struct rtable *ip_route_output(struct net *net, __be32 daddr,
|
||||||
__be32 saddr, u8 tos, int oif,
|
__be32 saddr, dscp_t dscp,
|
||||||
__u8 scope)
|
int oif, __u8 scope)
|
||||||
{
|
{
|
||||||
struct flowi4 fl4 = {
|
struct flowi4 fl4 = {
|
||||||
.flowi4_oif = oif,
|
.flowi4_oif = oif,
|
||||||
.flowi4_tos = tos,
|
.flowi4_tos = inet_dscp_to_dsfield(dscp),
|
||||||
.flowi4_scope = scope,
|
.flowi4_scope = scope,
|
||||||
.daddr = daddr,
|
.daddr = daddr,
|
||||||
.saddr = saddr,
|
.saddr = saddr,
|
||||||
|
@ -406,7 +406,7 @@ static int br_nf_pre_routing_finish(struct net *net, struct sock *sk, struct sk_
|
|||||||
goto free_skb;
|
goto free_skb;
|
||||||
|
|
||||||
rt = ip_route_output(net, iph->daddr, 0,
|
rt = ip_route_output(net, iph->daddr, 0,
|
||||||
iph->tos & INET_DSCP_MASK, 0,
|
ip4h_dscp(iph), 0,
|
||||||
RT_SCOPE_UNIVERSE);
|
RT_SCOPE_UNIVERSE);
|
||||||
if (!IS_ERR(rt)) {
|
if (!IS_ERR(rt)) {
|
||||||
/* - Bridged-and-DNAT'ed traffic doesn't
|
/* - Bridged-and-DNAT'ed traffic doesn't
|
||||||
|
Loading…
Reference in New Issue
Block a user