diff options
| author | Leandro A. F. Pereira <leandro@hardinfo.org> | 2006-11-19 12:21:16 +0000 | 
|---|---|---|
| committer | Leandro A. F. Pereira <leandro@hardinfo.org> | 2006-11-19 12:21:16 +0000 | 
| commit | f128a3b3f241c7280339a2be8f3e6c18295bb526 (patch) | |
| tree | 46c3565193d89823826c5c7b73305802df617343 | |
| parent | d9f77003caadb032ea53085dbf66fb8083f8f56a (diff) | |
Allow reloading the kernel module list
| -rw-r--r-- | hardinfo2/arch/linux/common/modules.h | 22 | ||||
| -rw-r--r-- | hardinfo2/devices.c | 5 | 
2 files changed, 25 insertions, 2 deletions
| diff --git a/hardinfo2/arch/linux/common/modules.h b/hardinfo2/arch/linux/common/modules.h index 9c335f18..ce012b70 100644 --- a/hardinfo2/arch/linux/common/modules.h +++ b/hardinfo2/arch/linux/common/modules.h @@ -16,12 +16,32 @@   *    Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA   */ +static gboolean +remove_module_devices(gpointer key, gpointer value, gpointer data) +{ +    if (!strncmp((gchar *) key, "MOD", 3)) { +	g_free((gchar *) key); +	g_free((GtkTreeIter *) value); +	return TRUE; +    } +    return FALSE; +} +  void  scan_modules(void)  {      FILE *lsmod;      gchar buffer[1024]; +    shell_status_update("Getting loaded modules information..."); +     +    if (module_list) { +        g_free(module_list); +        module_list = NULL; +    } + +    g_hash_table_foreach_remove(devices, remove_module_devices, NULL); +      lsmod = popen("/sbin/lsmod", "r");      if (!lsmod)  	return; @@ -79,7 +99,7 @@ scan_modules(void)  	/* append this module to the list of modules */  	module_list = g_strdup_printf("%s$%s$%s=%s\n", -				      module_list, +				      module_list ? module_list : "",  				      hashkey,  				      modname,  				      description ? description : ""); diff --git a/hardinfo2/devices.c b/hardinfo2/devices.c index c43104d4..6dc989b2 100644 --- a/hardinfo2/devices.c +++ b/hardinfo2/devices.c @@ -45,7 +45,7 @@ static ModuleEntry hi_entries[] = {  };  static GHashTable *devices = NULL; -static gchar *module_list = ""; +static gchar *module_list = NULL;  static gchar *printer_list = NULL;  static gchar *pci_list = "";  static gchar *input_list = NULL; @@ -115,6 +115,9 @@ void  hi_reload(gint entry)  {      switch (entry) { +    case DEVICES_KERNEL_MODULES: +        scan_modules(); +        break;      case DEVICES_BATTERY:          scan_battery();          break; | 
