diff mbox series

ipv6: prevent a possible race condition with lifetimes

Message ID 5599cc3b-8925-4cfd-f035-ae3b87e821a3@ugent.be (mailing list archive)
State Changes Requested
Delegated to: Netdev Maintainers
Headers show
Series ipv6: prevent a possible race condition with lifetimes | expand

Checks

Context Check Description
netdev/tree_selection success Guessing tree name failed - patch did not apply

Commit Message

Niels Dossche Feb. 20, 2022, 5:54 p.m. UTC
valid_lft, prefered_lft and tstamp are always accessed under the lock
"lock" in other places. Reading these without taking the lock may result
in inconsistencies regarding the calculation of the valid and preferred
variables since decisions are taken on these fields for those variables.

Signed-off-by: Niels Dossche <niels.dossche@ugent.be>
---
 net/ipv6/addrconf.c | 2 ++
 1 file changed, 2 insertions(+)

Comments

David Ahern Feb. 22, 2022, 3:02 a.m. UTC | #1
On 2/20/22 10:54 AM, Niels Dossche wrote:
> valid_lft, prefered_lft and tstamp are always accessed under the lock
> "lock" in other places. Reading these without taking the lock may result
> in inconsistencies regarding the calculation of the valid and preferred
> variables since decisions are taken on these fields for those variables.
> 
> Signed-off-by: Niels Dossche <niels.dossche@ugent.be>
> ---
>  net/ipv6/addrconf.c | 2 ++
>  1 file changed, 2 insertions(+)
> 

Reviewed-by: David Ahern <dsahern@kernel.org>
Jakub Kicinski Feb. 23, 2022, 12:43 a.m. UTC | #2
On Sun, 20 Feb 2022 18:54:40 +0100 Niels Dossche wrote:
> valid_lft, prefered_lft and tstamp are always accessed under the lock
> "lock" in other places. Reading these without taking the lock may result
> in inconsistencies regarding the calculation of the valid and preferred
> variables since decisions are taken on these fields for those variables.
> 
> Signed-off-by: Niels Dossche <niels.dossche@ugent.be>

Looks like your email client has replaced tabs with spaces, 
so the patch won't apply. Could you try resending with git send-email?
Please add Dave's review tag in the next version, and the subject
tag should be [PATCH net v2]. Thanks!
Niels Dossche Feb. 23, 2022, 1:33 p.m. UTC | #3
It appears that the mail server of the university is changing tabs to spaces.
I will resend it from my personal gmail address, since that does not seem to
change tabs to spaces. Sorry for the inconvenience. Thanks!

On 23/02/2022 01:43, Jakub Kicinski wrote:
> On Sun, 20 Feb 2022 18:54:40 +0100 Niels Dossche wrote:
>> valid_lft, prefered_lft and tstamp are always accessed under the lock
>> "lock" in other places. Reading these without taking the lock may result
>> in inconsistencies regarding the calculation of the valid and preferred
>> variables since decisions are taken on these fields for those variables.
>>
>> Signed-off-by: Niels Dossche <niels.dossche@ugent.be>
> 
> Looks like your email client has replaced tabs with spaces, 
> so the patch won't apply. Could you try resending with git send-email?
> Please add Dave's review tag in the next version, and the subject
> tag should be [PATCH net v2]. Thanks!
diff mbox series

Patch

diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c
index 3f23da8c0b10..6c8ab3e6e6fe 100644
--- a/net/ipv6/addrconf.c
+++ b/net/ipv6/addrconf.c
@@ -4998,6 +4998,7 @@  static int inet6_fill_ifaddr(struct sk_buff *skb, struct inet6_ifaddr *ifa,
            nla_put_s32(skb, IFA_TARGET_NETNSID, args->netnsid))
                goto error;
 
+       spin_lock_bh(&ifa->lock);
        if (!((ifa->flags&IFA_F_PERMANENT) &&
              (ifa->prefered_lft == INFINITY_LIFE_TIME))) {
                preferred = ifa->prefered_lft;
@@ -5019,6 +5020,7 @@  static int inet6_fill_ifaddr(struct sk_buff *skb, struct inet6_ifaddr *ifa,
                preferred = INFINITY_LIFE_TIME;
                valid = INFINITY_LIFE_TIME;
        }
+       spin_unlock_bh(&ifa->lock);
 
        if (!ipv6_addr_any(&ifa->peer_addr)) {
                if (nla_put_in6_addr(skb, IFA_LOCAL, &ifa->addr) < 0 ||