X-Git-Url: http://git.ozlabs.org/?p=petitboot;a=blobdiff_plain;f=discover%2Fuser-event.c;h=fb3fddb5c4bc5f7390f114ec7820f33d7ec45e77;hp=20b2bea928ea75b221deac7ed675fd9f44345f81;hb=0d3caaf8e9a75e9b6ebc9427c75ed2914c60439d;hpb=1def8f21aecc41ac22652e7b8bd1f5bf7a4dae98 diff --git a/discover/user-event.c b/discover/user-event.c index 20b2bea..fb3fddb 100644 --- a/discover/user-event.c +++ b/discover/user-event.c @@ -37,6 +37,7 @@ #include "resource.h" #include "event.h" #include "user-event.h" +#include "sysinfo.h" #define MAC_ADDR_SIZE 6 @@ -385,6 +386,16 @@ static int user_event_dhcp(struct user_event *uev, struct event *event) struct device_handler *handler = uev->handler; struct discover_device *dev; + uint8_t hwaddr[MAC_ADDR_SIZE]; + + sscanf(event_get_param(event, "mac"), + "%hhX:%hhX:%hhX:%hhX:%hhX:%hhX", + hwaddr, hwaddr + 1, hwaddr + 2, + hwaddr + 3, hwaddr + 4, hwaddr + 5); + + system_info_set_interface_address(sizeof(hwaddr), hwaddr, + event_get_param(event, "ip")); + dev = discover_device_create(handler, event_get_param(event, "mac"), event->device);