Log warning if storage magic matches, but version does not

To help us detect when new storage file versions come into
existance log a warning if the storage file magic matches,
but the version does not

Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
This commit is contained in:
Daniel P. Berrange 2012-12-13 14:22:51 +00:00
parent f6bd0a8899
commit dfba37048a

View File

@ -756,16 +756,26 @@ virStorageFileProbeFormatFromBuf(const char *path,
{ {
int format = VIR_STORAGE_FILE_RAW; int format = VIR_STORAGE_FILE_RAW;
int i; int i;
int possibleFormat = VIR_STORAGE_FILE_RAW;
VIR_DEBUG("path=%s", path);
/* First check file magic */ /* First check file magic */
for (i = 0 ; i < VIR_STORAGE_FILE_LAST ; i++) { for (i = 0 ; i < VIR_STORAGE_FILE_LAST ; i++) {
if (virStorageFileMatchesMagic(i, buf, buflen) && if (virStorageFileMatchesMagic(i, buf, buflen)) {
virStorageFileMatchesVersion(i, buf, buflen)) { if (!virStorageFileMatchesVersion(i, buf, buflen)) {
possibleFormat = i;
continue;
}
format = i; format = i;
goto cleanup; goto cleanup;
} }
} }
if (possibleFormat != VIR_STORAGE_FILE_RAW)
VIR_WARN("File %s matches %s magic, but version is wrong. "
"Please report new version to libvir-list@redhat.com",
path, virStorageFileFormatTypeToString(possibleFormat));
/* No magic, so check file extension */ /* No magic, so check file extension */
for (i = 0 ; i < VIR_STORAGE_FILE_LAST ; i++) { for (i = 0 ; i < VIR_STORAGE_FILE_LAST ; i++) {
if (virStorageFileMatchesExtension(i, path)) { if (virStorageFileMatchesExtension(i, path)) {