s390/dasd: prevent prefix I/O error
Prevent that a prefix flag is set based on invalid configuration data. The validity.verify_base flag should only be set for alias devices. Usually the unit address type is either one of base, PAV alias or HyperPAV alias. But in cases where the unit address type is not set or any other value the validity.verify_base flag might be set as well. This would lead to follow on errors. Explicitly check for alias devices and set the validity flag only for them. Signed-off-by: Stefan Haberland <sth@linux.vnet.ibm.com> Reviewed-by: Jan Hoeppner <hoeppner@linux.vnet.ibm.com> Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
This commit is contained in:
parent
fbbd7f1a51
commit
da340f921d
|
@ -531,9 +531,11 @@ static int prefix_LRE(struct ccw1 *ccw, struct PFX_eckd_data *pfxdata,
|
|||
pfxdata->validity.define_extent = 1;
|
||||
|
||||
/* private uid is kept up to date, conf_data may be outdated */
|
||||
if (startpriv->uid.type != UA_BASE_DEVICE) {
|
||||
if (startpriv->uid.type == UA_BASE_PAV_ALIAS)
|
||||
pfxdata->validity.verify_base = 1;
|
||||
|
||||
if (startpriv->uid.type == UA_HYPER_PAV_ALIAS) {
|
||||
pfxdata->validity.verify_base = 1;
|
||||
if (startpriv->uid.type == UA_HYPER_PAV_ALIAS)
|
||||
pfxdata->validity.hyper_pav = 1;
|
||||
}
|
||||
|
||||
|
@ -3415,9 +3417,11 @@ static int prepare_itcw(struct itcw *itcw,
|
|||
pfxdata.validity.define_extent = 1;
|
||||
|
||||
/* private uid is kept up to date, conf_data may be outdated */
|
||||
if (startpriv->uid.type != UA_BASE_DEVICE) {
|
||||
if (startpriv->uid.type == UA_BASE_PAV_ALIAS)
|
||||
pfxdata.validity.verify_base = 1;
|
||||
|
||||
if (startpriv->uid.type == UA_HYPER_PAV_ALIAS) {
|
||||
pfxdata.validity.verify_base = 1;
|
||||
if (startpriv->uid.type == UA_HYPER_PAV_ALIAS)
|
||||
pfxdata.validity.hyper_pav = 1;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue