mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-18 10:35:20 +00:00
virStoragePoolSourceAdapter: Refine the SCSI_HOST adapter name
Preparation for future patches by creating a scsi_host union. For now, just the 'name' will be present.
This commit is contained in:
parent
8d854e5b5b
commit
53f620568e
@ -343,7 +343,7 @@ virStoragePoolSourceAdapterClear(virStoragePoolSourceAdapter adapter)
|
|||||||
VIR_FREE(adapter.data.fchost.parent);
|
VIR_FREE(adapter.data.fchost.parent);
|
||||||
} else if (adapter.type ==
|
} else if (adapter.type ==
|
||||||
VIR_STORAGE_POOL_SOURCE_ADAPTER_TYPE_SCSI_HOST) {
|
VIR_STORAGE_POOL_SOURCE_ADAPTER_TYPE_SCSI_HOST) {
|
||||||
VIR_FREE(adapter.data.name);
|
VIR_FREE(adapter.data.scsi_host.name);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -576,7 +576,7 @@ virStoragePoolDefParseSource(xmlXPathContextPtr ctxt,
|
|||||||
virXPathString("string(./adapter/@wwpn)", ctxt);
|
virXPathString("string(./adapter/@wwpn)", ctxt);
|
||||||
} else if (source->adapter.type ==
|
} else if (source->adapter.type ==
|
||||||
VIR_STORAGE_POOL_SOURCE_ADAPTER_TYPE_SCSI_HOST) {
|
VIR_STORAGE_POOL_SOURCE_ADAPTER_TYPE_SCSI_HOST) {
|
||||||
source->adapter.data.name =
|
source->adapter.data.scsi_host.name =
|
||||||
virXPathString("string(./adapter/@name)", ctxt);
|
virXPathString("string(./adapter/@name)", ctxt);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -601,7 +601,7 @@ virStoragePoolDefParseSource(xmlXPathContextPtr ctxt,
|
|||||||
/* To keep back-compat, 'type' is not required to specify
|
/* To keep back-compat, 'type' is not required to specify
|
||||||
* for scsi_host adapter.
|
* for scsi_host adapter.
|
||||||
*/
|
*/
|
||||||
if ((source->adapter.data.name =
|
if ((source->adapter.data.scsi_host.name =
|
||||||
virXPathString("string(./adapter/@name)", ctxt)))
|
virXPathString("string(./adapter/@name)", ctxt)))
|
||||||
source->adapter.type =
|
source->adapter.type =
|
||||||
VIR_STORAGE_POOL_SOURCE_ADAPTER_TYPE_SCSI_HOST;
|
VIR_STORAGE_POOL_SOURCE_ADAPTER_TYPE_SCSI_HOST;
|
||||||
@ -854,7 +854,7 @@ virStoragePoolDefParseXML(xmlXPathContextPtr ctxt)
|
|||||||
goto error;
|
goto error;
|
||||||
} else if (ret->source.adapter.type ==
|
} else if (ret->source.adapter.type ==
|
||||||
VIR_STORAGE_POOL_SOURCE_ADAPTER_TYPE_SCSI_HOST) {
|
VIR_STORAGE_POOL_SOURCE_ADAPTER_TYPE_SCSI_HOST) {
|
||||||
if (!ret->source.adapter.data.name) {
|
if (!ret->source.adapter.data.scsi_host.name) {
|
||||||
virReportError(VIR_ERR_XML_ERROR, "%s",
|
virReportError(VIR_ERR_XML_ERROR, "%s",
|
||||||
_("missing storage pool source adapter name"));
|
_("missing storage pool source adapter name"));
|
||||||
goto error;
|
goto error;
|
||||||
@ -1021,7 +1021,8 @@ virStoragePoolSourceFormat(virBufferPtr buf,
|
|||||||
src->adapter.data.fchost.wwpn);
|
src->adapter.data.fchost.wwpn);
|
||||||
} else if (src->adapter.type ==
|
} else if (src->adapter.type ==
|
||||||
VIR_STORAGE_POOL_SOURCE_ADAPTER_TYPE_SCSI_HOST) {
|
VIR_STORAGE_POOL_SOURCE_ADAPTER_TYPE_SCSI_HOST) {
|
||||||
virBufferAsprintf(buf, " name='%s'/>\n", src->adapter.data.name);
|
virBufferAsprintf(buf, " name='%s'/>\n",
|
||||||
|
src->adapter.data.scsi_host.name);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2028,8 +2029,8 @@ virStoragePoolSourceFindDuplicate(virStoragePoolObjListPtr pools,
|
|||||||
matchpool = pool;
|
matchpool = pool;
|
||||||
} else if (pool->def->source.adapter.type ==
|
} else if (pool->def->source.adapter.type ==
|
||||||
VIR_STORAGE_POOL_SOURCE_ADAPTER_TYPE_SCSI_HOST){
|
VIR_STORAGE_POOL_SOURCE_ADAPTER_TYPE_SCSI_HOST){
|
||||||
if (STREQ(pool->def->source.adapter.data.name,
|
if (STREQ(pool->def->source.adapter.data.scsi_host.name,
|
||||||
def->source.adapter.data.name))
|
def->source.adapter.data.scsi_host.name))
|
||||||
matchpool = pool;
|
matchpool = pool;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -179,7 +179,9 @@ struct _virStoragePoolSourceAdapter {
|
|||||||
int type; /* virStoragePoolSourceAdapterType */
|
int type; /* virStoragePoolSourceAdapterType */
|
||||||
|
|
||||||
union {
|
union {
|
||||||
|
struct {
|
||||||
char *name;
|
char *name;
|
||||||
|
} scsi_host;
|
||||||
struct {
|
struct {
|
||||||
char *parent;
|
char *parent;
|
||||||
char *wwnn;
|
char *wwnn;
|
||||||
|
@ -1975,7 +1975,7 @@ phypStorageVolCreateXML(virStoragePoolPtr pool,
|
|||||||
spdef->source.ndevice = 1;
|
spdef->source.ndevice = 1;
|
||||||
|
|
||||||
/*XXX source adapter not working properly, should show hdiskX */
|
/*XXX source adapter not working properly, should show hdiskX */
|
||||||
if ((spdef->source.adapter.data.name =
|
if ((spdef->source.adapter.data.scsi_host.name =
|
||||||
phypGetStoragePoolDevice(pool->conn, pool->name)) == NULL) {
|
phypGetStoragePoolDevice(pool->conn, pool->name)) == NULL) {
|
||||||
VIR_ERROR(_("Unable to determine storage pools's source adapter."));
|
VIR_ERROR(_("Unable to determine storage pools's source adapter."));
|
||||||
goto err;
|
goto err;
|
||||||
@ -2197,7 +2197,7 @@ phypStorageVolGetXMLDesc(virStorageVolPtr vol, unsigned int flags)
|
|||||||
|
|
||||||
pool.source.ndevice = 1;
|
pool.source.ndevice = 1;
|
||||||
|
|
||||||
if ((pool.source.adapter.data.name =
|
if ((pool.source.adapter.data.scsi_host.name =
|
||||||
phypGetStoragePoolDevice(sp->conn, sp->name)) == NULL) {
|
phypGetStoragePoolDevice(sp->conn, sp->name)) == NULL) {
|
||||||
VIR_ERROR(_("Unable to determine storage sps's source adapter."));
|
VIR_ERROR(_("Unable to determine storage sps's source adapter."));
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
@ -2436,7 +2436,7 @@ phypBuildStoragePool(virConnectPtr conn, virStoragePoolDefPtr def)
|
|||||||
managed_system, vios_id);
|
managed_system, vios_id);
|
||||||
|
|
||||||
virBufferAsprintf(&buf, "mksp -f %schild %s", def->name,
|
virBufferAsprintf(&buf, "mksp -f %schild %s", def->name,
|
||||||
source.adapter.data.name);
|
source.adapter.data.scsi_host.name);
|
||||||
|
|
||||||
if (system_type == HMC)
|
if (system_type == HMC)
|
||||||
virBufferAddChar(&buf, '\'');
|
virBufferAddChar(&buf, '\'');
|
||||||
@ -2667,7 +2667,7 @@ phypStoragePoolGetXMLDesc(virStoragePoolPtr pool, unsigned int flags)
|
|||||||
def.source.ndevice = 1;
|
def.source.ndevice = 1;
|
||||||
|
|
||||||
/*XXX source adapter not working properly, should show hdiskX */
|
/*XXX source adapter not working properly, should show hdiskX */
|
||||||
if ((def.source.adapter.data.name =
|
if ((def.source.adapter.data.scsi_host.name =
|
||||||
phypGetStoragePoolDevice(pool->conn, pool->name)) == NULL) {
|
phypGetStoragePoolDevice(pool->conn, pool->name)) == NULL) {
|
||||||
VIR_ERROR(_("Unable to determine storage pools's source adapter."));
|
VIR_ERROR(_("Unable to determine storage pools's source adapter."));
|
||||||
goto err;
|
goto err;
|
||||||
|
@ -548,7 +548,7 @@ getAdapterName(virStoragePoolSourceAdapter adapter)
|
|||||||
char *name = NULL;
|
char *name = NULL;
|
||||||
|
|
||||||
if (adapter.type == VIR_STORAGE_POOL_SOURCE_ADAPTER_TYPE_SCSI_HOST) {
|
if (adapter.type == VIR_STORAGE_POOL_SOURCE_ADAPTER_TYPE_SCSI_HOST) {
|
||||||
ignore_value(VIR_STRDUP(name, adapter.data.name));
|
ignore_value(VIR_STRDUP(name, adapter.data.scsi_host.name));
|
||||||
} else if (adapter.type == VIR_STORAGE_POOL_SOURCE_ADAPTER_TYPE_FC_HOST) {
|
} else if (adapter.type == VIR_STORAGE_POOL_SOURCE_ADAPTER_TYPE_FC_HOST) {
|
||||||
if (!(name = virGetFCHostNameByWWN(NULL,
|
if (!(name = virGetFCHostNameByWWN(NULL,
|
||||||
adapter.data.fchost.wwnn,
|
adapter.data.fchost.wwnn,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user