capdev: add bind of cap device to ifconfig
[akaros.git] / kern / kfs / ifconfig
1 #!/bin/ash
2
3 NIC='0'
4 MAC=`cat "#ether/ether$NIC/addr"`
5
6 export cputype=amd64
7 export objtype=$cputype
8 export service=cpu
9 export authid=bootes
10 export rootdir=/root
11 export rootspec=''
12 export rootsrv=boot
13
14 if [ -d /etc/network/local.d ]
15 then
16         for cfg in /etc/network/local.d/*
17         do
18                 source $cfg
19         done
20 else
21         echo '/etc/network/local.d not found'
22 fi
23
24 #
25 # Set up the initial namespace for starting networking.
26 #
27 /bin/bind -b '#cons' /dev
28 /bin/bind -b '#random' /dev
29 /bin/bind -a '#capability' /dev
30 #/bin/bind '#d' /fd
31 #/bin/bind -c '#e' /env
32 /bin/bind -b '#proc' /proc
33 /bin/bind -b '#srv' /srv
34
35 #
36 # Configure the network mount point.
37 #
38 /bin/bind -a '#ip' /net
39 /bin/bind -a '#ether'.$NIC /net
40
41 if [ -x /bin/ipconfig ]
42 then
43         if [ -n "$me" ]
44         then
45                 ipconfig -g $route ether /net/ether$NIC $me $mask
46         else
47                 # No explicit configuration; use DHCP.
48                 daemonize /bin/ipconfig -S ether /net/ether$NIC
49         fi
50         ipconfig -P loopback /dev/null 127.0.0.1
51 else
52         if [ ! -n "$me" ]
53         then
54                 # By default, configure for QEMU.
55                 # We only use qemu's setting when we don't have ipconfig so that we can
56                 # test ipconfig + DHCP with qemu.
57                 me='10.0.2.15'
58                 mask='255.255.255.0'
59                 remote='10.0.2.0'
60                 route='10.0.2.2'
61                 dns='10.0.2.3'
62         fi
63         #
64         # Get an instance of an IP stack and bind ether$NIC to it.
65         # The kernel sets errno but 'echo' doesn't return any sort of
66         # error indicator.  Our busybox hacks doesn't know any better
67         # and will think it was an error so direct stderr to /dev/null.
68         #
69         i=`cat /net/ipifc/clone`
70         echo "bind ether /net/ether$NIC" >/net/ipifc/$i/ctl 2>/dev/null
71         #
72         # Configure the stack.
73         #
74         echo "add $me $mask $remote" > /net/ipifc/$i/ctl
75         echo "add 0 0 $route" > /net/iproute
76         echo "I am $me, default route $route"
77         #
78         # Configure the loopback interface.
79         #
80         i=`cat /net/ipifc/clone`
81         echo 'bind loopback /dev/null' > /net/ipifc/$i/ctl
82         echo 'add 127.0.0.1 255.0.0.0 127.0.0.0' > /net/ipifc/$i/ctl
83 fi
84
85 ######### DNS Config #############
86
87 # If we used some form of static configuration, /net/ndb doesn't know about our
88 # DNS server.  This assumes the last contents of ndb is the IP block
89 if [ -n "$me" ]
90 then
91         echo -e "\tdns=$dns" >> /net/ndb
92 fi
93 # Either way, we have DNS in ndb now, but some apps want it in resolv.conf
94 DNS=`grep "dns=" /net/ndb | cut -f 2 -d'='`
95 echo "nameserver $DNS" >> /etc/resolv.conf
96 # And we may have some additional search paths for resolv.conf
97 if [ -n "$me" ]
98 then
99         echo "search $search" >> /etc/resolv.conf
100 fi
101 # We also can provide an etc hosts file for loopback
102 echo "127.0.0.1 localhost" >> /etc/hosts
103
104 daemonize /bin/cs -S
105 mount -a '#srv/cs' /net
106
107 # This is noisy, so it is off by default.
108 #echo debug > /net/cs
109
110 /bin/bind -a '#kprof' /prof
111
112 echo 'ifconfig complete'