From 8b2ccd525b328994d3e62c01092b20859a23e36d Mon Sep 17 00:00:00 2001 From: Jeremy Kerr Date: Fri, 15 Nov 2013 15:23:54 +1100 Subject: discover: populate sysinfo with block devices Signed-off-by: Jeremy Kerr --- discover/sysinfo.c | 34 ++++++++++++++++++++++++++++++++++ 1 file changed, 34 insertions(+) (limited to 'discover/sysinfo.c') diff --git a/discover/sysinfo.c b/discover/sysinfo.c index 870e9a1..3c13277 100644 --- a/discover/sysinfo.c +++ b/discover/sysinfo.c @@ -53,6 +53,40 @@ void system_info_register_interface(unsigned int hwaddr_size, uint8_t *hwaddr, discover_server_notify_system_info(server, sysinfo); } +void system_info_register_blockdev(const char *name, const char *uuid, + const char *mountpoint) +{ + struct blockdev_info *bd_info; + unsigned int i; + + for (i = 0; i < sysinfo->n_blockdevs; i++) { + bd_info = sysinfo->blockdevs[i]; + + if (strcmp(bd_info->name, name)) + continue; + + /* update the mountpoint and UUID, and we're done */ + talloc_free(bd_info->mountpoint); + bd_info->uuid = talloc_strdup(bd_info, uuid); + bd_info->mountpoint = talloc_strdup(bd_info, mountpoint); + discover_server_notify_system_info(server, sysinfo); + return; + } + + bd_info = talloc_zero(sysinfo, struct blockdev_info); + bd_info->name = talloc_strdup(bd_info, name); + bd_info->uuid = talloc_strdup(bd_info, uuid); + bd_info->mountpoint = talloc_strdup(bd_info, mountpoint); + + sysinfo->n_blockdevs++; + sysinfo->blockdevs = talloc_realloc(sysinfo, sysinfo->blockdevs, + struct blockdev_info *, + sysinfo->n_blockdevs); + sysinfo->blockdevs[sysinfo->n_blockdevs - 1] = bd_info; + + discover_server_notify_system_info(server, sysinfo); +} + static void system_info_set_identifier(struct system_info *info) { struct process *process; -- cgit v1.2.1