mirror of
https://github.com/lm-sensors/lm-sensors
synced 2025-08-30 22:05:11 +00:00
Use strtoul() instead of parsing integers on our own.
git-svn-id: http://lm-sensors.org/svn/lm-sensors/branches/lm-sensors-3.0.0@4675 7894878c-1315-0410-8ee3-d5d059ff63e0
This commit is contained in:
61
lib/data.c
61
lib/data.c
@@ -76,7 +76,7 @@ int sensors_parse_chip_name(const char *orig_name, sensors_chip_name *res)
|
||||
{
|
||||
char *part2, *part3, *part4;
|
||||
char *name = strdup(orig_name);
|
||||
int i;
|
||||
char *endptr;
|
||||
|
||||
if (! name)
|
||||
sensors_fatal_error("sensors_parse_chip_name","Allocating new name");
|
||||
@@ -103,28 +103,9 @@ int sensors_parse_chip_name(const char *orig_name, sensors_chip_name *res)
|
||||
if (!strcmp(part4,"*"))
|
||||
res->addr = SENSORS_CHIP_NAME_ADDR_ANY;
|
||||
else {
|
||||
if ((strlen(part4) > 4) || (strlen(part4) == 0))
|
||||
res->addr = strtoul(part4, &endptr, 16);
|
||||
if (*part4 == '\0' || *endptr != '\0' || res->addr < 0)
|
||||
goto ERROR;
|
||||
res->addr = 0;
|
||||
for (i = 0; ; i++) {
|
||||
switch (part4[i]) {
|
||||
case '0': case '1': case '2': case '3': case '4':
|
||||
case '5': case '6': case '7': case '8': case '9':
|
||||
res->addr = res->addr * 16 + part4[i] - '0';
|
||||
break;
|
||||
case 'a': case 'b': case 'c': case 'd': case 'e': case 'f':
|
||||
res->addr = res->addr * 16 + part4[i] - 'a' + 10;
|
||||
break;
|
||||
case 'A': case 'B': case 'C': case 'D': case 'E': case 'F':
|
||||
res->addr = res->addr * 16 + part4[i] - 'A' + 10;
|
||||
break;
|
||||
case 0:
|
||||
goto DONE;
|
||||
default:
|
||||
goto ERROR;
|
||||
}
|
||||
}
|
||||
DONE:;
|
||||
}
|
||||
|
||||
/* OK. So let's look at part3. It must either be the number of the
|
||||
@@ -147,22 +128,9 @@ DONE:;
|
||||
} else if (part2 && !strcmp(part2,"i2c") && !strcmp(part3,"*"))
|
||||
res->bus = SENSORS_CHIP_NAME_BUS_ANY_I2C;
|
||||
else if (part2 && !strcmp(part2,"i2c")) {
|
||||
if ((strlen(part3) > 3) || (strlen(part3) == 0))
|
||||
res->bus = strtoul(part3, &endptr, 10);
|
||||
if (*part3 == '\0' || *endptr != '\0' || res->bus < 0)
|
||||
goto ERROR;
|
||||
res->bus = 0;
|
||||
for (i = 0; ; i++) {
|
||||
switch (part3[i]) {
|
||||
case '0': case '1': case '2': case '3': case '4':
|
||||
case '5': case '6': case '7': case '8': case '9':
|
||||
res->bus = res->bus * 10 + part3[i] - '0';
|
||||
break;
|
||||
case 0:
|
||||
goto DONE2;
|
||||
default:
|
||||
goto ERROR;
|
||||
}
|
||||
}
|
||||
DONE2:;
|
||||
} else if (res->addr == SENSORS_CHIP_NAME_ADDR_ANY) {
|
||||
res->bus = SENSORS_CHIP_NAME_BUS_ANY;
|
||||
if (part2)
|
||||
@@ -188,27 +156,16 @@ ERROR:
|
||||
|
||||
int sensors_parse_i2cbus_name(const char *name, int *res)
|
||||
{
|
||||
int i;
|
||||
char *endptr;
|
||||
|
||||
if (strncmp(name,"i2c-",4)) {
|
||||
return -SENSORS_ERR_BUS_NAME;
|
||||
}
|
||||
name += 4;
|
||||
if ((strlen(name) > 3) || (strlen(name) == 0))
|
||||
*res = strtoul(name, &endptr, 10);
|
||||
if (*name == '\0' || *endptr != '\0' || *res < 0)
|
||||
return -SENSORS_ERR_BUS_NAME;
|
||||
*res = 0;
|
||||
for (i = 0; ; i++) {
|
||||
switch (name[i]) {
|
||||
case '0': case '1': case '2': case '3': case '4':
|
||||
case '5': case '6': case '7': case '8': case '9':
|
||||
*res = *res * 10 + name[i] - '0';
|
||||
break;
|
||||
case 0:
|
||||
return 0;
|
||||
default:
|
||||
return -SENSORS_ERR_BUS_NAME;
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
|
Reference in New Issue
Block a user