|
@@ -54,29 +54,30 @@ static int blk_pread_nonzeroes(BlockBackend *blk, hwaddr size, void *buf)
|
|
|
* BDRV_REQUEST_MAX_BYTES.
|
|
|
* On success, return true.
|
|
|
* On failure, store an error through @errp and return false.
|
|
|
- * Note that the error messages do not identify the block backend.
|
|
|
- * TODO Since callers don't either, this can result in confusing
|
|
|
- * errors.
|
|
|
+ *
|
|
|
* This function not intended for actual block devices, which read on
|
|
|
* demand. It's for things like memory devices that (ab)use a block
|
|
|
* backend to provide persistence.
|
|
|
*/
|
|
|
-bool blk_check_size_and_read_all(BlockBackend *blk, void *buf, hwaddr size,
|
|
|
- Error **errp)
|
|
|
+bool blk_check_size_and_read_all(BlockBackend *blk, DeviceState *dev,
|
|
|
+ void *buf, hwaddr size, Error **errp)
|
|
|
{
|
|
|
int64_t blk_len;
|
|
|
int ret;
|
|
|
+ g_autofree char *dev_id = NULL;
|
|
|
|
|
|
blk_len = blk_getlength(blk);
|
|
|
if (blk_len < 0) {
|
|
|
error_setg_errno(errp, -blk_len,
|
|
|
- "can't get size of block backend");
|
|
|
+ "can't get size of %s block backend", blk_name(blk));
|
|
|
return false;
|
|
|
}
|
|
|
if (blk_len != size) {
|
|
|
- error_setg(errp, "device requires %" HWADDR_PRIu " bytes, "
|
|
|
- "block backend provides %" PRIu64 " bytes",
|
|
|
- size, blk_len);
|
|
|
+ dev_id = qdev_get_human_name(dev);
|
|
|
+ error_setg(errp, "%s device '%s' requires %" HWADDR_PRIu
|
|
|
+ " bytes, %s block backend provides %" PRIu64 " bytes",
|
|
|
+ object_get_typename(OBJECT(dev)), dev_id, size,
|
|
|
+ blk_name(blk), blk_len);
|
|
|
return false;
|
|
|
}
|
|
|
|
|
@@ -89,7 +90,11 @@ bool blk_check_size_and_read_all(BlockBackend *blk, void *buf, hwaddr size,
|
|
|
assert(size <= BDRV_REQUEST_MAX_BYTES);
|
|
|
ret = blk_pread_nonzeroes(blk, size, buf);
|
|
|
if (ret < 0) {
|
|
|
- error_setg_errno(errp, -ret, "can't read block backend");
|
|
|
+ dev_id = qdev_get_human_name(dev);
|
|
|
+ error_setg_errno(errp, -ret, "can't read %s block backend"
|
|
|
+ " for %s device '%s'",
|
|
|
+ blk_name(blk), object_get_typename(OBJECT(dev)),
|
|
|
+ dev_id);
|
|
|
return false;
|
|
|
}
|
|
|
return true;
|