guix-commits
[Top][All Lists]
Advanced

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

01/03: syscalls: Add network-interface-running?


From: Danny Milosavljevic
Subject: 01/03: syscalls: Add network-interface-running?
Date: Fri, 7 Jul 2017 01:02:57 -0400 (EDT)

dannym pushed a commit to branch wip-installer-2
in repository guix.

commit 853265e137dc211a82503f4f4d44822a96522205
Author: Danny Milosavljevic <address@hidden>
Date:   Fri Jul 7 06:42:50 2017 +0200

    syscalls: Add network-interface-running?
    
    * guix/build/syscalls.scm (network-interface-running?): New variable.
    Export it.
    (IFF_RUNNING): New variable.
---
 guix/build/syscalls.scm | 9 +++++++++
 1 file changed, 9 insertions(+)

diff --git a/guix/build/syscalls.scm b/guix/build/syscalls.scm
index 9c082b4..5a6662a 100644
--- a/guix/build/syscalls.scm
+++ b/guix/build/syscalls.scm
@@ -88,6 +88,7 @@
 
             PF_PACKET
             AF_PACKET
+            network-interface-running?
             all-network-interface-names
             network-interface-names
             network-interface-netmask
@@ -1108,6 +1109,7 @@ bytes."
 (define-as-needed IFF_UP #x1)                     ;Interface is up
 (define-as-needed IFF_BROADCAST #x2)              ;Broadcast address valid.
 (define-as-needed IFF_LOOPBACK #x8)               ;Is a loopback net.
+(define-as-needed IFF_RUNNING #x40)               ;interface RFC2863 OPER_UP
 
 (define IF_NAMESIZE 16)                           ;maximum interface name size
 
@@ -1282,6 +1284,13 @@ interface NAME."
     (close-port sock)
     (not (zero? (logand flags IFF_LOOPBACK)))))
 
+(define (network-interface-running? name)
+  "Return true if NAME designates a running network interface."
+  (let* ((sock  (socket SOCK_STREAM AF_INET 0))
+         (flags (network-interface-flags sock name)))
+    (close-port sock)
+    (not (zero? (logand flags IFF_RUNNING)))))
+
 (define-as-needed (set-network-interface-flags socket name flags)
   "Set the flag of network interface NAME to FLAGS."
   (let ((req (make-bytevector ifreq-struct-size)))



reply via email to

[Prev in Thread] Current Thread [Next in Thread]