X-Git-Url: http://git.ozlabs.org/?p=petitboot;a=blobdiff_plain;f=ui%2Ftest%2Fdiscover-test.c;h=f3e7dd8cfc5b177595fedfd9a1ff9815c1dea3b2;hp=ae43b1e524b30421e694ed4fee4d04dcb309a8b3;hb=211d7eb1de2d3a9cd97846deb9a85a934dae2981;hpb=9939af2652ce479645eaa78e891ee06f33845a99 diff --git a/ui/test/discover-test.c b/ui/test/discover-test.c index ae43b1e..f3e7dd8 100644 --- a/ui/test/discover-test.c +++ b/ui/test/discover-test.c @@ -3,6 +3,25 @@ #include "ui/common/discover-client.h" +static const char *device_type_string(enum device_type type) +{ + switch (type) { + case DEVICE_TYPE_DISK: + return "disk"; + case DEVICE_TYPE_USB: + return "usb"; + case DEVICE_TYPE_NETWORK: + return "network"; + case DEVICE_TYPE_OPTICAL: + return "optical"; + case DEVICE_TYPE_ANY: + return "any"; + case DEVICE_TYPE_UNKNOWN: + return "unknown"; + } + return "invalid"; +} + static int print_device_add(struct device *device, void __attribute__((unused)) *arg) { @@ -10,6 +29,7 @@ static int print_device_add(struct device *device, printf("new device:\n"); printf("\tid: %s\n", device->id); + printf("\ttype: %s\n", device_type_string(device->type)); printf("\tname: %s\n", device->name); printf("\tdesc: %s\n", device->description); printf("\ticon: %s\n", device->icon_file); @@ -22,12 +42,31 @@ static int print_device_add(struct device *device, printf("\t\ticon: %s\n", opt->icon_file); printf("\t\tboot: %s\n", opt->boot_image_file); printf("\t\tinit: %s\n", opt->initrd_file); + printf("\t\tdtb: %s\n", opt->dtb_file); printf("\t\targs: %s\n", opt->boot_args); } return 0; } +static int print_boot_option_add(struct device *dev, + struct boot_option *opt, + void __attribute__((unused)) *arg) +{ + printf("new boot option (dev: %s):\n", dev->id); + printf("\tdev id: %s\n", opt->device_id); + printf("\tid: %s\n", opt->id); + printf("\tname: %s\n", opt->name); + printf("\tdesc: %s\n", opt->description); + printf("\ticon: %s\n", opt->icon_file); + printf("\tboot: %s\n", opt->boot_image_file); + printf("\tinit: %s\n", opt->initrd_file); + printf("\targs: %s\n", opt->boot_args); + printf("\tdefault:%d\n", opt->is_default); + + return 0; +} + static void print_device_remove(struct device *device, void __attribute__((unused)) *arg) { @@ -36,9 +75,50 @@ static void print_device_remove(struct device *device, printf("\tname: %s\n", device->name); } +static void print_status(struct status *status, + void __attribute__((unused)) *arg) +{ + printf("status:\n"); + printf("\ttype: %d\n", status->type); + printf("\tmessage: %s\n", status->message); + +} + +static void print_sysinfo(struct system_info *sysinfo, + void __attribute__((unused)) *arg) +{ + unsigned int i; + + printf("sysinfo:\n"); + printf("\ttype: %s\n", sysinfo->type); + printf("\tid: %s\n", sysinfo->identifier); + + if (sysinfo->n_interfaces == 0) + printf("\tno interfaces.\n"); + else + printf("\tinterfaces:\n"); + + for (i = 0; i < sysinfo->n_interfaces; i++) { + struct interface_info *if_info = sysinfo->interfaces[i]; + uint8_t *m = if_info->hwaddr; + + printf("\t\tname: %s\n", if_info->name); + + if (if_info->hwaddr_size == 6) + printf("\t\tmac: %02x:%02x:%02x:%02x:%02x:%02x\n", + m[0], m[1], m[2], m[3], m[4], m[5]); + else + printf("\t\tmac: unknown hwaddr size %d\n", + if_info->hwaddr_size); + } +} + static struct discover_client_ops client_ops = { .device_add = print_device_add, + .boot_option_add = print_boot_option_add, .device_remove = print_device_remove, + .update_status = print_status, + .update_sysinfo = print_sysinfo, }; int main(void)