Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/netbsd-8]: src Pull up following revision(s) (requested by bouyer in tic...



details:   https://anonhg.NetBSD.org/src/rev/d4c1791497a4
branches:  netbsd-8
changeset: 434006:d4c1791497a4
user:      snj <snj%NetBSD.org@localhost>
date:      Thu Jun 15 05:32:35 2017 +0000

description:
Pull up following revision(s) (requested by bouyer in ticket #34):
        sys/netcan/can_pcb.c: revision 1.6
        tests/net/can/t_can.c: revision 1.6
Refuse to bind to a non-CAN interface.
Also release the lock in the error branch.
--
Test bind()ing to a non-existent interface.

diffstat:

 sys/netcan/can_pcb.c  |  10 +++++++---
 tests/net/can/t_can.c |  30 ++++++++++++++++++++++++++++--
 2 files changed, 35 insertions(+), 5 deletions(-)

diffs (89 lines):

diff -r cbfda622c679 -r d4c1791497a4 sys/netcan/can_pcb.c
--- a/sys/netcan/can_pcb.c      Thu Jun 15 05:30:13 2017 +0000
+++ b/sys/netcan/can_pcb.c      Thu Jun 15 05:32:35 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: can_pcb.c,v 1.5 2017/06/01 02:45:14 chs Exp $  */
+/*     $NetBSD: can_pcb.c,v 1.5.2.1 2017/06/15 05:32:35 snj Exp $      */
 
 /*-
  * Copyright (c) 2003, 2017 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: can_pcb.c,v 1.5 2017/06/01 02:45:14 chs Exp $");
+__KERNEL_RCSID(0, "$NetBSD: can_pcb.c,v 1.5.2.1 2017/06/15 05:32:35 snj Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -127,8 +127,12 @@
        mutex_enter(&canp->canp_mtx);
        if (scan->can_ifindex != 0) {
                canp->canp_ifp = if_byindex(scan->can_ifindex);
-               if (canp->canp_ifp == NULL)
+               if (canp->canp_ifp == NULL ||
+                   canp->canp_ifp->if_dlt != DLT_CAN_SOCKETCAN) {
+                       canp->canp_ifp = NULL;
+                       mutex_exit(&canp->canp_mtx);
                        return (EADDRNOTAVAIL);
+               }
                soisconnected(canp->canp_socket);
        } else {
                canp->canp_ifp = NULL;
diff -r cbfda622c679 -r d4c1791497a4 tests/net/can/t_can.c
--- a/tests/net/can/t_can.c     Thu Jun 15 05:30:13 2017 +0000
+++ b/tests/net/can/t_can.c     Thu Jun 15 05:32:35 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: t_can.c,v 1.5 2017/05/28 14:53:13 christos Exp $       */
+/*     $NetBSD: t_can.c,v 1.5.2.1 2017/06/15 05:32:35 snj Exp $        */
 
 /*-
  * Copyright (c) 2017 The NetBSD Foundation, Inc.
@@ -32,7 +32,7 @@
 
 #include <sys/cdefs.h>
 #ifndef lint
-__RCSID("$NetBSD: t_can.c,v 1.5 2017/05/28 14:53:13 christos Exp $");
+__RCSID("$NetBSD: t_can.c,v 1.5.2.1 2017/06/15 05:32:35 snj Exp $");
 #endif /* not lint */
 
 #include <sys/types.h>
@@ -717,6 +717,31 @@
        }
 }
 
+ATF_TC(canbindunknown);
+ATF_TC_HEAD(canbindunknown, tc)
+{
+
+       atf_tc_set_md_var(tc, "descr", "check that bind to unkown interface fails");
+       atf_tc_set_md_var(tc, "timeout", "5");
+}
+
+ATF_TC_BODY(canbindunknown, tc)
+{
+       struct sockaddr_can sa;
+       int r, s;
+
+       rump_init();
+
+       s = can_socket_with_own();
+
+       sa.can_family = AF_CAN;
+       sa.can_ifindex = 10; /* should not exist */
+
+       r = rump_sys_bind(s, (struct sockaddr *)&sa, sizeof(sa));
+
+       ATF_CHECK_MSG(r < 0, "bind() didn't fail (%d)", r);
+}
+
 ATF_TP_ADD_TCS(tp)
 {
 
@@ -730,5 +755,6 @@
         ATF_TP_ADD_TC(tp, canrecvfrom);
         ATF_TP_ADD_TC(tp, canbindfilter);
         ATF_TP_ADD_TC(tp, cannoloop);
+        ATF_TP_ADD_TC(tp, canbindunknown);
        return atf_no_error();
 }



Home | Main Index | Thread Index | Old Index