Bug 107941

Summary: Multiple identical hardware sensors (from lmsensors) do not appear in the sensor list
Product: [Unmaintained] ksysguard Reporter: Simon Munton <simon.j.munton>
Component: generalAssignee: KSysGuard Developers <ksysguard-bugs>
Status: RESOLVED FIXED    
Severity: normal    
Priority: NOR    
Version: unspecified   
Target Milestone: ---   
Platform: Compiled Sources   
OS: Linux   
Latest Commit: Version Fixed In:
Sentry Crash Report:

Description Simon Munton 2005-06-22 22:58:19 UTC
Version:            (using KDE KDE 3.4.1)
Installed from:    Compiled From Sources
OS:                Linux

On my dual processor system there are two max1617 temperature sensors, one per CPU. The
output from sensors shows the following:

max1617-i2c-0-18
Adapter: SMBus I801 adapter at bcd0
Board:       +33°C  (low  =  -128°C, high =  +127°C)
CPU:         +34°C  (low  =  -128°C, high =   +85°C)

max1617-i2c-0-19
Adapter: SMBus I801 adapter at bcd0
Board:       +36°C  (low  =  -128°C, high =  +127°C)
CPU:         +41°C  (low  =  -128°C, high =   +85°C)

ksysguard only shows one max1617 in the sensor list, not both.
Comment 1 John Tapsell 2007-03-26 11:33:23 UTC
SVN commit 645829 by johnflux:

Fix lmsensors module

* Don't show sensors that have been set to ignore in /etc/sensors.conf
* Try to get a reading from the sensor and don't use it if there's an error
* Set the units based on the sensors.  C for temperature, RPM for fans, V for voltages
* Use the lmsensors internal name for the ksysguard name.  The human readable name may not be unique (fixes 107941)
  This does change the names of sensors, so it will break worksheets from kde3.  Because of this, it might not be a
  good idea to backport to kde3's ksysguard

BUG:107941



 M  +41 -18    lmsensors.c  


--- trunk/KDE/kdebase/workspace/ksysguard/ksysguardd/Linux/lmsensors.c #645828:645829
@@ -33,7 +33,7 @@
 
 #ifdef HAVE_LMSENSORS
 #include <sensors/sensors.h>
-
+#define BUFFER_SIZE_LMSEN 300
 typedef struct
 {
   char* fullName;
@@ -55,7 +55,11 @@
   LMSENSOR key;
   LMSENSOR* s;
 
+  if(name == NULL || name[0] == '\0') return 0;
   key.fullName = strdup( name );
+  int end = strlen(key.fullName)-1;
+  if(key.fullName[end] == '?')
+    key.fullName[end] = '\0';
   if ( ( idx = search_ctnr( LmSensors, sensorCmp, &key ) ) < 0 ) {
     free( key.fullName );
     return 0;
@@ -67,9 +71,21 @@
   return s;
 }
 
+static const char *chipName(const sensors_chip_name *chip) {
+  static char buffer[256];
+  if (chip->bus == SENSORS_CHIP_NAME_BUS_ISA)
+    sprintf (buffer, "%s-isa-%04x", chip->prefix, chip->addr);
+  else if (chip->bus == SENSORS_CHIP_NAME_BUS_PCI)
+    sprintf (buffer, "%s-pci-%04x", chip->prefix, chip->addr);
+  else
+    sprintf (buffer, "%s-i2c-%d-%02x", chip->prefix, chip->bus, chip->addr);
+  return buffer;
+}
+
 void initLmSensors( struct SensorModul* sm )
 {
   const sensors_chip_name* scn;
+  char buffer[BUFFER_SIZE_LMSEN];
   int nr = 0;
 
   FILE* input;
@@ -92,28 +108,23 @@
     const sensors_feature_data* sfd;
     nr1 = nr2 = 0;
     while ( ( sfd = sensors_get_all_features( *scn, &nr1, &nr2 ) ) != 0 ) {
-      if ( sfd->mapping == SENSORS_NO_MAPPING ) {
+      if ( sfd->mapping == SENSORS_NO_MAPPING && sfd->mode & SENSORS_MODE_R /* readable feature */) {
         LMSENSOR* p;
         char* label;
-        char* s;
-        char* prefixEscaped, labelEscaped;
 
-        sensors_get_label( *scn, sfd->number, &label );
+        if(sensors_get_label( *scn, sfd->number, &label ) != 0)
+		continue; /*error*/
+	if(sensors_get_ignored( *scn, sfd->number) != 1 )
+		continue; /* 1 for not ignored, 0 for ignore,  <0 for error */
+	double result;
+	if(sensors_get_feature( *scn, sfd->number, &result) != 0 )
+		continue; /* Make sure this feature actually works.  0 for success, <0 for fail */
+
         p = (LMSENSOR*)malloc( sizeof( LMSENSOR ) );
 
-        prefixEscaped = escapeString( scn->prefix );
-        labelEscaped = escapeString( label );
-        p->fullName = (char*)malloc( strlen( "lmsensors/" ) +
-                                     strlen( prefixEscaped ) + 1 +
-                                     strlen( labelEscaped ) + 1 );
-        sprintf( p->fullName, "lmsensors/%s/%s", prefixEscaped, labelEscaped );
-        free( prefixEscaped );
-        free( labelEscaped );
+        snprintf( buffer, BUFFER_SIZE_LMSEN, "lmsensors/%s/%s", chipName(scn), sfd->name );
 
-        /* Make sure that name contains only proper characters. */
-        for ( s = p->fullName; *s; s++ )
-          if ( *s == ' ' )
-            *s = '_';
+	p->fullName = strndup(buffer, BUFFER_SIZE_LMSEN);	
 
         p->scn = scn;
         p->sfd = sfd;
@@ -130,6 +141,7 @@
   bsort_ctnr( LmSensors, sensorCmp );
 }
 
+
 void exitLmSensors( void )
 {
   destr_ctnr( LmSensors, free );
@@ -159,7 +171,18 @@
   }
 
   /* TODO: print real name here */
-  fprintf( CurrentClient, "Sensor Info\t0\t0\t\n" );
+  char *label;
+  if(sensors_get_label( *s->scn, s->sfd->number, &label ) != 0) {  /*error*/
+    fprintf( CurrentClient, "0\n" );
+    return;
+  }
+  if( strncmp(s->sfd->name, "temp", sizeof("temp")-1) == 0)
+    fprintf( CurrentClient, "%s\t0\t0\t°C\n", label );
+  else if( strncmp(s->sfd->name, "fan", sizeof("fan")-1) == 0)
+    fprintf( CurrentClient, "%s\t0\t0\trpm\n", label );
+  else
+    fprintf( CurrentClient, "%s\t0\t0\tV\n", label );  /* For everything else, say it's in volts. */
+
 }
 
 #else /* HAVE_LMSENSORS */
Comment 2 John Tapsell 2007-03-26 13:41:06 UTC
It's now fixed in KDE4. 
I can't really fix this in kde3 without breaking existing sheets.

Reopen if this is a big problem for anyone and we'll try to find a solution