]> git.proxmox.com Git - qemu.git/commitdiff
fixed dhcp for windows client
authorbellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162>
Tue, 4 May 2004 03:14:47 +0000 (03:14 +0000)
committerbellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162>
Tue, 4 May 2004 03:14:47 +0000 (03:14 +0000)
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@784 c046a42c-6fe2-441c-8c8c-71466251a162

slirp/bootp.c
slirp/slirp.c

index 7e4b5bab0b18c733af35d10878aeaeb0d85f83bc..755072db83cd8cf6dc2d2c3336b40402aaa0f71e 100644 (file)
@@ -33,6 +33,7 @@
 
 typedef struct {
     uint8_t allocated;
+    uint8_t macaddr[6];
 } BOOTPClient;
 
 BOOTPClient bootp_clients[NB_ADDR];
@@ -63,6 +64,23 @@ static BOOTPClient *get_new_addr(struct in_addr *paddr)
     return bc;
 }
 
+static BOOTPClient *find_addr(struct in_addr *paddr, const uint8_t *macaddr)
+{
+    BOOTPClient *bc;
+    int i;
+
+    for(i = 0; i < NB_ADDR; i++) {
+        if (!memcmp(macaddr, bootp_clients[i].macaddr, 6))
+            goto found;
+    }
+    return NULL;
+ found:
+    bc = &bootp_clients[i];
+    bc->allocated = 1;
+    paddr->s_addr = htonl(ntohl(special_addr.s_addr) | (i + START_ADDR));
+    return bc;
+}
+
 static void dhcp_decode(const uint8_t *buf, int size,
                         int *pmsg_type)
 {
@@ -131,10 +149,19 @@ static void bootp_reply(struct bootp_t *bp)
     m->m_data += sizeof(struct udpiphdr);
     memset(rbp, 0, sizeof(struct bootp_t));
 
-    bc = get_new_addr(&daddr.sin_addr);
-    if (!bc) {
-        dprintf("no address left\n");
-        return;
+    if (dhcp_msg_type == DHCPDISCOVER) {
+        bc = get_new_addr(&daddr.sin_addr);
+        if (!bc) {
+            dprintf("no address left\n");
+            return;
+        }
+        memcpy(bc->macaddr, client_ethaddr, 6);
+    } else {
+        bc = find_addr(&daddr.sin_addr, bp->bp_hwaddr);
+        if (!bc) {
+            dprintf("no address assigned\n");
+            return;
+        }
     }
     dprintf("offered addr=%08x\n", ntohl(daddr.sin_addr.s_addr));
 
index 48b45a39cda342c3dbb09b27d6b8b9f25b62838f..f9c4f159e90fb3656214fdd1bdc2d424543ed733 100644 (file)
@@ -74,7 +74,7 @@ static int get_dns_addr(struct in_addr *pdns_addr)
 
 void slirp_init(void)
 {
-    debug_init("/tmp/slirp.log", DEBUG_DEFAULT);
+    //    debug_init("/tmp/slirp.log", DEBUG_DEFAULT);
 
     link_up = 1;