Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 98956
b: refs/heads/master
c: b3a686f
h: refs/heads/master
v: v3
  • Loading branch information
Cornelia Huck authored and Heiko Carstens committed Jul 14, 2008
1 parent 472e1f2 commit 80a6055
Show file tree
Hide file tree
Showing 4 changed files with 28 additions and 8 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 44a1c19e3b47a7ac596808177ccd250b95f5e688
refs/heads/master: b3a686f47a3615fcfec0a01c4103c50bb9621369
30 changes: 24 additions & 6 deletions trunk/drivers/s390/cio/cio.c
Original file line number Diff line number Diff line change
Expand Up @@ -498,13 +498,8 @@ int cio_create_sch_lock(struct subchannel *sch)
return 0;
}

static int cio_validate_io_subchannel(struct subchannel *sch)
static int cio_check_devno_blacklisted(struct subchannel *sch)
{
/* Initialization for io subchannels. */
if (!css_sch_is_valid(&sch->schib))
return -ENODEV;

/* Devno is valid. */
if (is_blacklisted(sch->schid.ssid, sch->schib.pmcw.dev)) {
/*
* This device must not be known to Linux. So we simply
Expand All @@ -518,6 +513,26 @@ static int cio_validate_io_subchannel(struct subchannel *sch)
return 0;
}

static int cio_validate_io_subchannel(struct subchannel *sch)
{
/* Initialization for io subchannels. */
if (!css_sch_is_valid(&sch->schib))
return -ENODEV;

/* Devno is valid. */
return cio_check_devno_blacklisted(sch);
}

static int cio_validate_msg_subchannel(struct subchannel *sch)
{
/* Initialization for message subchannels. */
if (!css_sch_is_valid(&sch->schib))
return -ENODEV;

/* Devno is valid. */
return cio_check_devno_blacklisted(sch);
}

/**
* cio_validate_subchannel - basic validation of subchannel
* @sch: subchannel structure to be filled out
Expand Down Expand Up @@ -573,6 +588,9 @@ int cio_validate_subchannel(struct subchannel *sch, struct subchannel_id schid)
case SUBCHANNEL_TYPE_IO:
err = cio_validate_io_subchannel(sch);
break;
case SUBCHANNEL_TYPE_MSG:
err = cio_validate_msg_subchannel(sch);
break;
default:
err = 0;
}
Expand Down
2 changes: 1 addition & 1 deletion trunk/drivers/s390/cio/cio.h
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
struct pmcw {
u32 intparm; /* interruption parameter */
u32 qf : 1; /* qdio facility */
u32 res0 : 1; /* reserved zeros */
u32 w : 1;
u32 isc : 3; /* interruption sublass */
u32 res5 : 3; /* reserved zeros */
u32 ena : 1; /* enabled */
Expand Down
2 changes: 2 additions & 0 deletions trunk/drivers/s390/cio/css.c
Original file line number Diff line number Diff line change
Expand Up @@ -332,6 +332,8 @@ int css_sch_is_valid(struct schib *schib)
{
if ((schib->pmcw.st == SUBCHANNEL_TYPE_IO) && !schib->pmcw.dnv)
return 0;
if ((schib->pmcw.st == SUBCHANNEL_TYPE_MSG) && !schib->pmcw.w)
return 0;
return 1;
}
EXPORT_SYMBOL_GPL(css_sch_is_valid);
Expand Down

0 comments on commit 80a6055

Please sign in to comment.