提交 ba8074b8 编写于 作者: E Eric Blake

sysinfo: simplify function signature

Now that no one is relying on the return value being a pointer to
somewhere inside of the passed-in argument, we can simplify the
callers to simply return success or failure.  Also wrap some long
lines and add some const-correctness.

* src/util/sysinfo.c (virSysinfoParseBIOS, virSysinfoParseSystem)
(virSysinfoParseProcessor, virSysinfoParseMemory): Change return.
(virSysinfoRead): Adjust caller.
上级 d474dbad
/* /*
* sysinfo.c: get SMBIOS/sysinfo information from the host * sysinfo.c: get SMBIOS/sysinfo information from the host
* *
* Copyright (C) 2010-2011 Red Hat, Inc. * Copyright (C) 2010-2012 Red Hat, Inc.
* Copyright (C) 2010 Daniel Veillard * Copyright (C) 2010 Daniel Veillard
* *
* This library is free software; you can redistribute it and/or * This library is free software; you can redistribute it and/or
...@@ -130,13 +130,13 @@ virSysinfoRead(void) { ...@@ -130,13 +130,13 @@ virSysinfoRead(void) {
#else /* !WIN32 && x86 */ #else /* !WIN32 && x86 */
static char * static int
virSysinfoParseBIOS(char *base, virSysinfoDefPtr ret) virSysinfoParseBIOS(const char *base, virSysinfoDefPtr ret)
{ {
char *cur, *eol = NULL; const char *cur, *eol = NULL;
if ((cur = strstr(base, "BIOS Information")) == NULL) if ((cur = strstr(base, "BIOS Information")) == NULL)
return base; return 0;
base = cur; base = cur;
if ((cur = strstr(base, "Vendor: ")) != NULL) { if ((cur = strstr(base, "Vendor: ")) != NULL) {
...@@ -164,19 +164,19 @@ virSysinfoParseBIOS(char *base, virSysinfoDefPtr ret) ...@@ -164,19 +164,19 @@ virSysinfoParseBIOS(char *base, virSysinfoDefPtr ret)
goto no_memory; goto no_memory;
} }
return base + strlen("BIOS Information"); return 0;
no_memory: no_memory:
return NULL; return -1;
} }
static char * static int
virSysinfoParseSystem(char *base, virSysinfoDefPtr ret) virSysinfoParseSystem(const char *base, virSysinfoDefPtr ret)
{ {
char *cur, *eol = NULL; const char *cur, *eol = NULL;
if ((cur = strstr(base, "System Information")) == NULL) if ((cur = strstr(base, "System Information")) == NULL)
return base; return 0;
base = cur; base = cur;
if ((cur = strstr(base, "Manufacturer: ")) != NULL) { if ((cur = strstr(base, "Manufacturer: ")) != NULL) {
...@@ -223,16 +223,17 @@ virSysinfoParseSystem(char *base, virSysinfoDefPtr ret) ...@@ -223,16 +223,17 @@ virSysinfoParseSystem(char *base, virSysinfoDefPtr ret)
goto no_memory; goto no_memory;
} }
return base + strlen("System Information"); return 0;
no_memory: no_memory:
return NULL; return -1;
} }
static char * static int
virSysinfoParseProcessor(char *base, virSysinfoDefPtr ret) virSysinfoParseProcessor(const char *base, virSysinfoDefPtr ret)
{ {
char *cur, *eol, *tmp_base; const char *cur, *tmp_base;
char *eol;
virSysinfoProcessorDefPtr processor; virSysinfoProcessorDefPtr processor;
while((tmp_base = strstr(base, "Processor Information")) != NULL) { while((tmp_base = strstr(base, "Processor Information")) != NULL) {
...@@ -249,7 +250,8 @@ virSysinfoParseProcessor(char *base, virSysinfoDefPtr ret) ...@@ -249,7 +250,8 @@ virSysinfoParseProcessor(char *base, virSysinfoDefPtr ret)
eol = strchr(cur, '\n'); eol = strchr(cur, '\n');
virSkipSpacesBackwards(cur, &eol); virSkipSpacesBackwards(cur, &eol);
if ((eol) && if ((eol) &&
((processor->processor_socket_destination = strndup(cur, eol - cur)) == NULL)) ((processor->processor_socket_destination
= strndup(cur, eol - cur)) == NULL))
goto no_memory; goto no_memory;
} }
if ((cur = strstr(base, "Type: ")) != NULL) { if ((cur = strstr(base, "Type: ")) != NULL) {
...@@ -265,7 +267,8 @@ virSysinfoParseProcessor(char *base, virSysinfoDefPtr ret) ...@@ -265,7 +267,8 @@ virSysinfoParseProcessor(char *base, virSysinfoDefPtr ret)
eol = strchr(cur, '\n'); eol = strchr(cur, '\n');
virSkipSpacesBackwards(cur, &eol); virSkipSpacesBackwards(cur, &eol);
if ((eol) && if ((eol) &&
((processor->processor_family = strndup(cur, eol - cur)) == NULL)) ((processor->processor_family = strndup(cur,
eol - cur)) == NULL))
goto no_memory; goto no_memory;
} }
if ((cur = strstr(base, "Manufacturer: ")) != NULL) { if ((cur = strstr(base, "Manufacturer: ")) != NULL) {
...@@ -273,7 +276,8 @@ virSysinfoParseProcessor(char *base, virSysinfoDefPtr ret) ...@@ -273,7 +276,8 @@ virSysinfoParseProcessor(char *base, virSysinfoDefPtr ret)
eol = strchr(cur, '\n'); eol = strchr(cur, '\n');
virSkipSpacesBackwards(cur, &eol); virSkipSpacesBackwards(cur, &eol);
if ((eol) && if ((eol) &&
((processor->processor_manufacturer = strndup(cur, eol - cur)) == NULL)) ((processor->processor_manufacturer
= strndup(cur, eol - cur)) == NULL))
goto no_memory; goto no_memory;
} }
if ((cur = strstr(base, "Signature: ")) != NULL) { if ((cur = strstr(base, "Signature: ")) != NULL) {
...@@ -281,7 +285,8 @@ virSysinfoParseProcessor(char *base, virSysinfoDefPtr ret) ...@@ -281,7 +285,8 @@ virSysinfoParseProcessor(char *base, virSysinfoDefPtr ret)
eol = strchr(cur, '\n'); eol = strchr(cur, '\n');
virSkipSpacesBackwards(cur, &eol); virSkipSpacesBackwards(cur, &eol);
if ((eol) && if ((eol) &&
((processor->processor_signature = strndup(cur, eol - cur)) == NULL)) ((processor->processor_signature
= strndup(cur, eol - cur)) == NULL))
goto no_memory; goto no_memory;
} }
if ((cur = strstr(base, "Version: ")) != NULL) { if ((cur = strstr(base, "Version: ")) != NULL) {
...@@ -289,7 +294,8 @@ virSysinfoParseProcessor(char *base, virSysinfoDefPtr ret) ...@@ -289,7 +294,8 @@ virSysinfoParseProcessor(char *base, virSysinfoDefPtr ret)
eol = strchr(cur, '\n'); eol = strchr(cur, '\n');
virSkipSpacesBackwards(cur, &eol); virSkipSpacesBackwards(cur, &eol);
if ((eol) && if ((eol) &&
((processor->processor_version = strndup(cur, eol - cur)) == NULL)) ((processor->processor_version = strndup(cur,
eol - cur)) == NULL))
goto no_memory; goto no_memory;
} }
if ((cur = strstr(base, "External Clock: ")) != NULL) { if ((cur = strstr(base, "External Clock: ")) != NULL) {
...@@ -297,7 +303,8 @@ virSysinfoParseProcessor(char *base, virSysinfoDefPtr ret) ...@@ -297,7 +303,8 @@ virSysinfoParseProcessor(char *base, virSysinfoDefPtr ret)
eol = strchr(cur, '\n'); eol = strchr(cur, '\n');
virSkipSpacesBackwards(cur, &eol); virSkipSpacesBackwards(cur, &eol);
if ((eol) && if ((eol) &&
((processor->processor_external_clock = strndup(cur, eol - cur)) == NULL)) ((processor->processor_external_clock
= strndup(cur, eol - cur)) == NULL))
goto no_memory; goto no_memory;
} }
if ((cur = strstr(base, "Max Speed: ")) != NULL) { if ((cur = strstr(base, "Max Speed: ")) != NULL) {
...@@ -305,7 +312,8 @@ virSysinfoParseProcessor(char *base, virSysinfoDefPtr ret) ...@@ -305,7 +312,8 @@ virSysinfoParseProcessor(char *base, virSysinfoDefPtr ret)
eol = strchr(cur, '\n'); eol = strchr(cur, '\n');
virSkipSpacesBackwards(cur, &eol); virSkipSpacesBackwards(cur, &eol);
if ((eol) && if ((eol) &&
((processor->processor_max_speed = strndup(cur, eol - cur)) == NULL)) ((processor->processor_max_speed
= strndup(cur, eol - cur)) == NULL))
goto no_memory; goto no_memory;
} }
if ((cur = strstr(base, "Status: ")) != NULL) { if ((cur = strstr(base, "Status: ")) != NULL) {
...@@ -313,7 +321,8 @@ virSysinfoParseProcessor(char *base, virSysinfoDefPtr ret) ...@@ -313,7 +321,8 @@ virSysinfoParseProcessor(char *base, virSysinfoDefPtr ret)
eol = strchr(cur, '\n'); eol = strchr(cur, '\n');
virSkipSpacesBackwards(cur, &eol); virSkipSpacesBackwards(cur, &eol);
if ((eol) && if ((eol) &&
((processor->processor_status = strndup(cur, eol - cur)) == NULL)) ((processor->processor_status = strndup(cur,
eol - cur)) == NULL))
goto no_memory; goto no_memory;
} }
if ((cur = strstr(base, "Serial Number: ")) != NULL) { if ((cur = strstr(base, "Serial Number: ")) != NULL) {
...@@ -321,7 +330,8 @@ virSysinfoParseProcessor(char *base, virSysinfoDefPtr ret) ...@@ -321,7 +330,8 @@ virSysinfoParseProcessor(char *base, virSysinfoDefPtr ret)
eol = strchr(cur, '\n'); eol = strchr(cur, '\n');
virSkipSpacesBackwards(cur, &eol); virSkipSpacesBackwards(cur, &eol);
if ((eol) && if ((eol) &&
((processor->processor_serial_number = strndup(cur, eol - cur)) == NULL)) ((processor->processor_serial_number
= strndup(cur, eol - cur)) == NULL))
goto no_memory; goto no_memory;
} }
if ((cur = strstr(base, "Part Number: ")) != NULL) { if ((cur = strstr(base, "Part Number: ")) != NULL) {
...@@ -329,23 +339,25 @@ virSysinfoParseProcessor(char *base, virSysinfoDefPtr ret) ...@@ -329,23 +339,25 @@ virSysinfoParseProcessor(char *base, virSysinfoDefPtr ret)
eol = strchr(cur, '\n'); eol = strchr(cur, '\n');
virSkipSpacesBackwards(cur, &eol); virSkipSpacesBackwards(cur, &eol);
if ((eol) && if ((eol) &&
((processor->processor_part_number = strndup(cur, eol - cur)) == NULL)) ((processor->processor_part_number
= strndup(cur, eol - cur)) == NULL))
goto no_memory; goto no_memory;
} }
base += strlen("Processor Information"); base += strlen("Processor Information");
} }
return base; return 0;
no_memory: no_memory:
return NULL; return -1;
} }
static char * static int
virSysinfoParseMemory(char *base, virSysinfoDefPtr ret) virSysinfoParseMemory(const char *base, virSysinfoDefPtr ret)
{ {
char *cur, *eol, *tmp_base; const char *cur, *tmp_base;
char *eol;
virSysinfoMemoryDefPtr memory; virSysinfoMemoryDefPtr memory;
while ((tmp_base = strstr(base, "Memory Device")) != NULL) { while ((tmp_base = strstr(base, "Memory Device")) != NULL) {
...@@ -373,7 +385,8 @@ virSysinfoParseMemory(char *base, virSysinfoDefPtr ret) ...@@ -373,7 +385,8 @@ virSysinfoParseMemory(char *base, virSysinfoDefPtr ret)
eol = strchr(cur, '\n'); eol = strchr(cur, '\n');
virSkipSpacesBackwards(cur, &eol); virSkipSpacesBackwards(cur, &eol);
if ((eol) && if ((eol) &&
((memory->memory_form_factor = strndup(cur, eol - cur)) == NULL)) ((memory->memory_form_factor = strndup(cur,
eol - cur)) == NULL))
goto no_memory; goto no_memory;
} }
if ((cur = strstr(base, "Locator: ")) != NULL) { if ((cur = strstr(base, "Locator: ")) != NULL) {
...@@ -389,7 +402,8 @@ virSysinfoParseMemory(char *base, virSysinfoDefPtr ret) ...@@ -389,7 +402,8 @@ virSysinfoParseMemory(char *base, virSysinfoDefPtr ret)
eol = strchr(cur, '\n'); eol = strchr(cur, '\n');
virSkipSpacesBackwards(cur, &eol); virSkipSpacesBackwards(cur, &eol);
if ((eol) && if ((eol) &&
((memory->memory_bank_locator = strndup(cur, eol - cur)) == NULL)) ((memory->memory_bank_locator = strndup(cur,
eol - cur)) == NULL))
goto no_memory; goto no_memory;
} }
if ((cur = strstr(base, "Type: ")) != NULL) { if ((cur = strstr(base, "Type: ")) != NULL) {
...@@ -405,7 +419,8 @@ virSysinfoParseMemory(char *base, virSysinfoDefPtr ret) ...@@ -405,7 +419,8 @@ virSysinfoParseMemory(char *base, virSysinfoDefPtr ret)
eol = strchr(cur, '\n'); eol = strchr(cur, '\n');
virSkipSpacesBackwards(cur, &eol); virSkipSpacesBackwards(cur, &eol);
if ((eol) && if ((eol) &&
((memory->memory_type_detail = strndup(cur, eol - cur)) == NULL)) ((memory->memory_type_detail = strndup(cur,
eol - cur)) == NULL))
goto no_memory; goto no_memory;
} }
if ((cur = strstr(base, "Speed: ")) != NULL) { if ((cur = strstr(base, "Speed: ")) != NULL) {
...@@ -421,7 +436,8 @@ virSysinfoParseMemory(char *base, virSysinfoDefPtr ret) ...@@ -421,7 +436,8 @@ virSysinfoParseMemory(char *base, virSysinfoDefPtr ret)
eol = strchr(cur, '\n'); eol = strchr(cur, '\n');
virSkipSpacesBackwards(cur, &eol); virSkipSpacesBackwards(cur, &eol);
if ((eol) && if ((eol) &&
((memory->memory_manufacturer = strndup(cur, eol - cur)) == NULL)) ((memory->memory_manufacturer = strndup(cur,
eol - cur)) == NULL))
goto no_memory; goto no_memory;
} }
if ((cur = strstr(base, "Serial Number: ")) != NULL) { if ((cur = strstr(base, "Serial Number: ")) != NULL) {
...@@ -429,7 +445,8 @@ virSysinfoParseMemory(char *base, virSysinfoDefPtr ret) ...@@ -429,7 +445,8 @@ virSysinfoParseMemory(char *base, virSysinfoDefPtr ret)
eol = strchr(cur, '\n'); eol = strchr(cur, '\n');
virSkipSpacesBackwards(cur, &eol); virSkipSpacesBackwards(cur, &eol);
if ((eol) && if ((eol) &&
((memory->memory_serial_number = strndup(cur, eol - cur)) == NULL)) ((memory->memory_serial_number = strndup(cur,
eol - cur)) == NULL))
goto no_memory; goto no_memory;
} }
if ((cur = strstr(base, "Part Number: ")) != NULL) { if ((cur = strstr(base, "Part Number: ")) != NULL) {
...@@ -437,7 +454,8 @@ virSysinfoParseMemory(char *base, virSysinfoDefPtr ret) ...@@ -437,7 +454,8 @@ virSysinfoParseMemory(char *base, virSysinfoDefPtr ret)
eol = strchr(cur, '\n'); eol = strchr(cur, '\n');
virSkipSpacesBackwards(cur, &eol); virSkipSpacesBackwards(cur, &eol);
if ((eol) && if ((eol) &&
((memory->memory_part_number = strndup(cur, eol - cur)) == NULL)) ((memory->memory_part_number = strndup(cur,
eol - cur)) == NULL))
goto no_memory; goto no_memory;
} }
...@@ -445,10 +463,10 @@ virSysinfoParseMemory(char *base, virSysinfoDefPtr ret) ...@@ -445,10 +463,10 @@ virSysinfoParseMemory(char *base, virSysinfoDefPtr ret)
base += strlen("Memory Device"); base += strlen("Memory Device");
} }
return base; return 0;
no_memory: no_memory:
return NULL; return -1;
} }
virSysinfoDefPtr virSysinfoDefPtr
...@@ -481,20 +499,20 @@ virSysinfoRead(void) { ...@@ -481,20 +499,20 @@ virSysinfoRead(void) {
ret->type = VIR_SYSINFO_SMBIOS; ret->type = VIR_SYSINFO_SMBIOS;
if ((virSysinfoParseBIOS(outbuf, ret)) == NULL) if (virSysinfoParseBIOS(outbuf, ret) < 0)
goto no_memory; goto no_memory;
if ((virSysinfoParseSystem(outbuf, ret)) == NULL) if (virSysinfoParseSystem(outbuf, ret) < 0)
goto no_memory; goto no_memory;
ret->nprocessor = 0; ret->nprocessor = 0;
ret->processor = NULL; ret->processor = NULL;
if ((virSysinfoParseProcessor(outbuf, ret)) == NULL) if (virSysinfoParseProcessor(outbuf, ret) < 0)
goto no_memory; goto no_memory;
ret->nmemory = 0; ret->nmemory = 0;
ret->memory = NULL; ret->memory = NULL;
if (virSysinfoParseMemory(outbuf, ret) == NULL) if (virSysinfoParseMemory(outbuf, ret) < 0)
goto no_memory; goto no_memory;
cleanup: cleanup:
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册