summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authordzwdz2022-08-27 11:36:42 +0200
committerdzwdz2022-08-27 11:36:42 +0200
commit418cb68ffe64e9359e2e991538ece442fafc0c94 (patch)
tree2763a1d094db200b960638907dcb295b4ac8736d
parent0f51f64e9bdaeed74981150a7b29726610d00504 (diff)
user/netstack: IP gateway, make networking work without a second vm
-rw-r--r--Makefile7
-rw-r--r--src/user/app/init/init.c2
-rw-r--r--src/user/app/netstack/netstack.c17
-rw-r--r--src/user/app/netstack/proto.h2
-rw-r--r--src/user/app/netstack/tcp.c11
5 files changed, 26 insertions, 13 deletions
diff --git a/Makefile b/Makefile
index 49a1745..31b7c56 100644
--- a/Makefile
+++ b/Makefile
@@ -15,7 +15,12 @@ USER_CFLAGS = $(CFLAGS) -Isrc/user/lib/include/
SPARSEFLAGS = -Wno-non-pointer-null
LFLAGS = -ffreestanding -O2 -nostdlib -lgcc -Wl,-zmax-page-size=4096 -Wl,--no-warn-mismatch
-QFLAGS = -no-reboot -nic socket,model=rtl8139,connect=:1234,mac=52:54:00:ca:77:1a
+QFLAGS = -no-reboot
+ifdef NET_DIRECT
+QFLAGS += -nic socket,model=rtl8139,connect=:1234,mac=52:54:00:ca:77:1a
+else
+QFLAGS += -nic user,model=rtl8139,mac=52:54:00:ca:77:1a,net=192.168.0.0/24,hostfwd=tcp::12380-192.168.0.11:80
+endif
ifndef NO_KVM
QFLAGS += -enable-kvm
endif
diff --git a/src/user/app/init/init.c b/src/user/app/init/init.c
index 09ab257..24a0056 100644
--- a/src/user/app/init/init.c
+++ b/src/user/app/init/init.c
@@ -69,7 +69,7 @@ int main(void) {
execv(argv[0], (void*)argv);
}
MOUNT_AT("/net/") {
- const char *argv[] = {"/bin/netstack", "/kdev/eth", "192.168.0.11", NULL};
+ const char *argv[] = {"/bin/netstack", "/kdev/eth", "192.168.0.11", "192.168.0.2", NULL};
execv(argv[0], (void*)argv);
}
diff --git a/src/user/app/netstack/netstack.c b/src/user/app/netstack/netstack.c
index 137d9d9..75a5162 100644
--- a/src/user/app/netstack/netstack.c
+++ b/src/user/app/netstack/netstack.c
@@ -26,19 +26,24 @@ void network_thread(void *arg) { (void)arg;
void fs_thread(void *arg);
int main(int argc, char **argv) {
- if (argc < 3) {
- eprintf("usage: netstack iface ip");
+ if (argc < 4) {
+ eprintf("usage: netstack iface ip gateway");
return 1;
}
- if (ip_parse(argv[2], &state.ip) < 0) {
- eprintf("invalid ip");
- return -1;
- }
state.raw_h = _syscall_open(argv[1], strlen(argv[1]), 0);
if (state.raw_h < 0) {
eprintf("couldn't open %s", argv[1]);
return 1;
}
+ if (ip_parse(argv[2], &state.ip) < 0) {
+ eprintf("invalid ip");
+ return -1;
+ }
+ if (ip_parse(argv[3], &state.gateway) < 0) {
+ eprintf("invalid gateway");
+ return -1;
+ }
+ arp_request(state.gateway);
thread_create(0, network_thread, NULL);
thread_create(0, fs_thread, NULL);
_syscall_await();
diff --git a/src/user/app/netstack/proto.h b/src/user/app/netstack/proto.h
index 72a4fca..4d881ca 100644
--- a/src/user/app/netstack/proto.h
+++ b/src/user/app/netstack/proto.h
@@ -8,7 +8,7 @@ static const mac_t MAC_BROADCAST = {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF};
extern struct net_state {
mac_t mac;
- uint32_t ip;
+ uint32_t ip, gateway;
handle_t raw_h;
} state;
diff --git a/src/user/app/netstack/tcp.c b/src/user/app/netstack/tcp.c
index 2f13a31..dd6d121 100644
--- a/src/user/app/netstack/tcp.c
+++ b/src/user/app/netstack/tcp.c
@@ -120,10 +120,13 @@ struct tcp_conn *tcpc_new(
c->lport = t.src ? t.src : 50002; // TODO randomize source ports
c->rport = t.dst;
if (arpcache_get(c->rip, &c->rmac) < 0) {
- // TODO make arp request, wait for reply
- eprintf("not in ARP cache, unimplemented");
- free(c);
- return NULL;
+ // TODO wait for ARP reply
+ arp_request(c->rip);
+ if (arpcache_get(state.gateway, &c->rmac) < 0) {
+ eprintf("neither target nor gateway not in ARP cache, dropping");
+ free(c);
+ return NULL;
+ }
}
c->state = SYN_SENT;