ACPI / APEI: Fix the returned value in erst_dbg_read
If the persistent store is empty initially, the function 'erst_dbg_read' returns a nonzero value. The better way is to return a zero indicating the read operation reaches EOF. Tested on two different servers. Signed-off-by: Adrian Huang <adrian.huang@hp.com> Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
This commit is contained in:
parent
d1c3ed669a
commit
6780aa683d
@ -111,8 +111,17 @@ retry_next:
|
|||||||
if (rc)
|
if (rc)
|
||||||
goto out;
|
goto out;
|
||||||
/* no more record */
|
/* no more record */
|
||||||
if (id == APEI_ERST_INVALID_RECORD_ID)
|
if (id == APEI_ERST_INVALID_RECORD_ID) {
|
||||||
|
/*
|
||||||
|
* If the persistent store is empty initially, the function
|
||||||
|
* 'erst_read' below will return "-ENOENT" value. This causes
|
||||||
|
* 'retry_next' label is entered again. The returned value
|
||||||
|
* should be zero indicating the read operation is EOF.
|
||||||
|
*/
|
||||||
|
len = 0;
|
||||||
|
|
||||||
goto out;
|
goto out;
|
||||||
|
}
|
||||||
retry:
|
retry:
|
||||||
rc = len = erst_read(id, erst_dbg_buf, erst_dbg_buf_len);
|
rc = len = erst_read(id, erst_dbg_buf, erst_dbg_buf_len);
|
||||||
/* The record may be cleared by others, try read next record */
|
/* The record may be cleared by others, try read next record */
|
||||||
|
Loading…
Reference in New Issue
Block a user