Module Name: src
Committed By: yamaguchi
Date: Fri Apr 5 06:37:29 UTC 2024
Modified Files:
src/sys/net/lagg: if_lagg.c if_laggproto.c
Log Message:
lagg(4): release lock before pserialize_perform() if possible
To generate a diff of this commit:
cvs rdiff -u -r1.68 -r1.69 src/sys/net/lagg/if_lagg.c
cvs rdiff -u -r1.13 -r1.14 src/sys/net/lagg/if_laggproto.c
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/sys/net/lagg/if_lagg.c
diff -u src/sys/net/lagg/if_lagg.c:1.68 src/sys/net/lagg/if_lagg.c:1.69
--- src/sys/net/lagg/if_lagg.c:1.68 Fri Apr 5 06:05:37 2024
+++ src/sys/net/lagg/if_lagg.c Fri Apr 5 06:37:29 2024
@@ -1,4 +1,4 @@
-/* $NetBSD: if_lagg.c,v 1.68 2024/04/05 06:05:37 yamaguchi Exp $ */
+/* $NetBSD: if_lagg.c,v 1.69 2024/04/05 06:37:29 yamaguchi Exp $ */
/*
* Copyright (c) 2005, 2006 Reyk Floeter <r...@openbsd.org>
@@ -20,7 +20,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_lagg.c,v 1.68 2024/04/05 06:05:37 yamaguchi Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_lagg.c,v 1.69 2024/04/05 06:37:29 yamaguchi Exp $");
#ifdef _KERNEL_OPT
#include "opt_inet.h"
@@ -1705,8 +1705,8 @@ lagg_pr_detach(struct lagg_softc *sc)
LAGG_LOCK(sc);
var = sc->sc_var;
atomic_store_release(&sc->sc_var, NULL);
- pserialize_perform(sc->sc_psz);
LAGG_UNLOCK(sc);
+ pserialize_perform(sc->sc_psz);
if (var != NULL)
lagg_proto_detach(var);
Index: src/sys/net/lagg/if_laggproto.c
diff -u src/sys/net/lagg/if_laggproto.c:1.13 src/sys/net/lagg/if_laggproto.c:1.14
--- src/sys/net/lagg/if_laggproto.c:1.13 Fri Apr 5 06:23:48 2024
+++ src/sys/net/lagg/if_laggproto.c Fri Apr 5 06:37:29 2024
@@ -1,4 +1,4 @@
-/* $NetBSD: if_laggproto.c,v 1.13 2024/04/05 06:23:48 yamaguchi Exp $ */
+/* $NetBSD: if_laggproto.c,v 1.14 2024/04/05 06:37:29 yamaguchi Exp $ */
/*-
* SPDX-License-Identifier: BSD-2-Clause-NetBSD
@@ -29,7 +29,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_laggproto.c,v 1.13 2024/04/05 06:23:48 yamaguchi Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_laggproto.c,v 1.14 2024/04/05 06:37:29 yamaguchi Exp $");
#include <sys/param.h>
#include <sys/types.h>
@@ -319,8 +319,8 @@ lagg_proto_remove_port(struct lagg_proto
LAGG_PROTO_LOCK(psc);
PSLIST_WRITER_REMOVE(pport, lpp_entry);
- pserialize_perform(psc->psc_psz);
LAGG_PROTO_UNLOCK(psc);
+ pserialize_perform(psc->psc_psz);
}
void
@@ -646,8 +646,8 @@ lagg_lb_startport(struct lagg_proto_soft
pm_next->pm_nports = n;
lagg_portmap_switch(&lb->lb_pmaps);
- pserialize_perform(psc->psc_psz);
LAGG_PROTO_UNLOCK(psc);
+ pserialize_perform(psc->psc_psz);
}
void
@@ -675,8 +675,8 @@ lagg_lb_stopport(struct lagg_proto_softc
pm_next->pm_nports = n;
lagg_portmap_switch(&lb->lb_pmaps);
- pserialize_perform(psc->psc_psz);
LAGG_PROTO_UNLOCK(psc);
+ pserialize_perform(psc->psc_psz);
lagg_common_stopport(psc, lp);
}