diff options
Diffstat (limited to 'drivers/s390/cio')
-rw-r--r-- | drivers/s390/cio/chp.c | 14 | ||||
-rw-r--r-- | drivers/s390/cio/css.c | 69 | ||||
-rw-r--r-- | drivers/s390/cio/css.h | 2 | ||||
-rw-r--r-- | drivers/s390/cio/device_fsm.c | 3 |
4 files changed, 49 insertions, 39 deletions
diff --git a/drivers/s390/cio/chp.c b/drivers/s390/cio/chp.c index 920dd71e6434..8ce4ff95cc9c 100644 --- a/drivers/s390/cio/chp.c +++ b/drivers/s390/cio/chp.c | |||
@@ -55,7 +55,7 @@ static wait_queue_head_t cfg_wait_queue; | |||
55 | /* Return channel_path struct for given chpid. */ | 55 | /* Return channel_path struct for given chpid. */ |
56 | static inline struct channel_path *chpid_to_chp(struct chp_id chpid) | 56 | static inline struct channel_path *chpid_to_chp(struct chp_id chpid) |
57 | { | 57 | { |
58 | return css[chpid.cssid]->chps[chpid.id]; | 58 | return channel_subsystems[chpid.cssid]->chps[chpid.id]; |
59 | } | 59 | } |
60 | 60 | ||
61 | /* Set vary state for given chpid. */ | 61 | /* Set vary state for given chpid. */ |
@@ -395,7 +395,7 @@ int chp_new(struct chp_id chpid) | |||
395 | /* fill in status, etc. */ | 395 | /* fill in status, etc. */ |
396 | chp->chpid = chpid; | 396 | chp->chpid = chpid; |
397 | chp->state = 1; | 397 | chp->state = 1; |
398 | chp->dev.parent = &css[chpid.cssid]->device; | 398 | chp->dev.parent = &channel_subsystems[chpid.cssid]->device; |
399 | chp->dev.release = chp_release; | 399 | chp->dev.release = chp_release; |
400 | snprintf(chp->dev.bus_id, BUS_ID_SIZE, "chp%x.%02x", chpid.cssid, | 400 | snprintf(chp->dev.bus_id, BUS_ID_SIZE, "chp%x.%02x", chpid.cssid, |
401 | chpid.id); | 401 | chpid.id); |
@@ -430,18 +430,18 @@ int chp_new(struct chp_id chpid) | |||
430 | device_unregister(&chp->dev); | 430 | device_unregister(&chp->dev); |
431 | goto out_free; | 431 | goto out_free; |
432 | } | 432 | } |
433 | mutex_lock(&css[chpid.cssid]->mutex); | 433 | mutex_lock(&channel_subsystems[chpid.cssid]->mutex); |
434 | if (css[chpid.cssid]->cm_enabled) { | 434 | if (channel_subsystems[chpid.cssid]->cm_enabled) { |
435 | ret = chp_add_cmg_attr(chp); | 435 | ret = chp_add_cmg_attr(chp); |
436 | if (ret) { | 436 | if (ret) { |
437 | sysfs_remove_group(&chp->dev.kobj, &chp_attr_group); | 437 | sysfs_remove_group(&chp->dev.kobj, &chp_attr_group); |
438 | device_unregister(&chp->dev); | 438 | device_unregister(&chp->dev); |
439 | mutex_unlock(&css[chpid.cssid]->mutex); | 439 | mutex_unlock(&channel_subsystems[chpid.cssid]->mutex); |
440 | goto out_free; | 440 | goto out_free; |
441 | } | 441 | } |
442 | } | 442 | } |
443 | css[chpid.cssid]->chps[chpid.id] = chp; | 443 | channel_subsystems[chpid.cssid]->chps[chpid.id] = chp; |
444 | mutex_unlock(&css[chpid.cssid]->mutex); | 444 | mutex_unlock(&channel_subsystems[chpid.cssid]->mutex); |
445 | return ret; | 445 | return ret; |
446 | out_free: | 446 | out_free: |
447 | kfree(chp); | 447 | kfree(chp); |
diff --git a/drivers/s390/cio/css.c b/drivers/s390/cio/css.c index 5635e656c1a3..08f6e7b6c999 100644 --- a/drivers/s390/cio/css.c +++ b/drivers/s390/cio/css.c | |||
@@ -27,7 +27,7 @@ int css_init_done = 0; | |||
27 | static int need_reprobe = 0; | 27 | static int need_reprobe = 0; |
28 | static int max_ssid = 0; | 28 | static int max_ssid = 0; |
29 | 29 | ||
30 | struct channel_subsystem *css[__MAX_CSSID + 1]; | 30 | struct channel_subsystem *channel_subsystems[__MAX_CSSID + 1]; |
31 | 31 | ||
32 | int css_characteristics_avail = 0; | 32 | int css_characteristics_avail = 0; |
33 | 33 | ||
@@ -177,7 +177,7 @@ static int css_register_subchannel(struct subchannel *sch) | |||
177 | int ret; | 177 | int ret; |
178 | 178 | ||
179 | /* Initialize the subchannel structure */ | 179 | /* Initialize the subchannel structure */ |
180 | sch->dev.parent = &css[0]->device; | 180 | sch->dev.parent = &channel_subsystems[0]->device; |
181 | sch->dev.bus = &css_bus_type; | 181 | sch->dev.bus = &css_bus_type; |
182 | sch->dev.release = &css_subchannel_release; | 182 | sch->dev.release = &css_subchannel_release; |
183 | sch->dev.groups = subch_attr_groups; | 183 | sch->dev.groups = subch_attr_groups; |
@@ -606,27 +606,29 @@ static int __init setup_css(int nr) | |||
606 | { | 606 | { |
607 | u32 tod_high; | 607 | u32 tod_high; |
608 | int ret; | 608 | int ret; |
609 | struct channel_subsystem *css; | ||
609 | 610 | ||
610 | memset(css[nr], 0, sizeof(struct channel_subsystem)); | 611 | css = channel_subsystems[nr]; |
611 | css[nr]->pseudo_subchannel = | 612 | memset(css, 0, sizeof(struct channel_subsystem)); |
612 | kzalloc(sizeof(*css[nr]->pseudo_subchannel), GFP_KERNEL); | 613 | css->pseudo_subchannel = |
613 | if (!css[nr]->pseudo_subchannel) | 614 | kzalloc(sizeof(*css->pseudo_subchannel), GFP_KERNEL); |
615 | if (!css->pseudo_subchannel) | ||
614 | return -ENOMEM; | 616 | return -ENOMEM; |
615 | css[nr]->pseudo_subchannel->dev.parent = &css[nr]->device; | 617 | css->pseudo_subchannel->dev.parent = &css->device; |
616 | css[nr]->pseudo_subchannel->dev.release = css_subchannel_release; | 618 | css->pseudo_subchannel->dev.release = css_subchannel_release; |
617 | sprintf(css[nr]->pseudo_subchannel->dev.bus_id, "defunct"); | 619 | sprintf(css->pseudo_subchannel->dev.bus_id, "defunct"); |
618 | ret = cio_create_sch_lock(css[nr]->pseudo_subchannel); | 620 | ret = cio_create_sch_lock(css->pseudo_subchannel); |
619 | if (ret) { | 621 | if (ret) { |
620 | kfree(css[nr]->pseudo_subchannel); | 622 | kfree(css->pseudo_subchannel); |
621 | return ret; | 623 | return ret; |
622 | } | 624 | } |
623 | mutex_init(&css[nr]->mutex); | 625 | mutex_init(&css->mutex); |
624 | css[nr]->valid = 1; | 626 | css->valid = 1; |
625 | css[nr]->cssid = nr; | 627 | css->cssid = nr; |
626 | sprintf(css[nr]->device.bus_id, "css%x", nr); | 628 | sprintf(css->device.bus_id, "css%x", nr); |
627 | css[nr]->device.release = channel_subsystem_release; | 629 | css->device.release = channel_subsystem_release; |
628 | tod_high = (u32) (get_clock() >> 32); | 630 | tod_high = (u32) (get_clock() >> 32); |
629 | css_generate_pgid(css[nr], tod_high); | 631 | css_generate_pgid(css, tod_high); |
630 | return 0; | 632 | return 0; |
631 | } | 633 | } |
632 | 634 | ||
@@ -670,25 +672,28 @@ init_channel_subsystem (void) | |||
670 | } | 672 | } |
671 | /* Setup css structure. */ | 673 | /* Setup css structure. */ |
672 | for (i = 0; i <= __MAX_CSSID; i++) { | 674 | for (i = 0; i <= __MAX_CSSID; i++) { |
673 | css[i] = kmalloc(sizeof(struct channel_subsystem), GFP_KERNEL); | 675 | struct channel_subsystem *css; |
674 | if (!css[i]) { | 676 | |
677 | css = kmalloc(sizeof(struct channel_subsystem), GFP_KERNEL); | ||
678 | if (!css) { | ||
675 | ret = -ENOMEM; | 679 | ret = -ENOMEM; |
676 | goto out_unregister; | 680 | goto out_unregister; |
677 | } | 681 | } |
682 | channel_subsystems[i] = css; | ||
678 | ret = setup_css(i); | 683 | ret = setup_css(i); |
679 | if (ret) | 684 | if (ret) |
680 | goto out_free; | 685 | goto out_free; |
681 | ret = device_register(&css[i]->device); | 686 | ret = device_register(&css->device); |
682 | if (ret) | 687 | if (ret) |
683 | goto out_free_all; | 688 | goto out_free_all; |
684 | if (css_characteristics_avail && | 689 | if (css_characteristics_avail && |
685 | css_chsc_characteristics.secm) { | 690 | css_chsc_characteristics.secm) { |
686 | ret = device_create_file(&css[i]->device, | 691 | ret = device_create_file(&css->device, |
687 | &dev_attr_cm_enable); | 692 | &dev_attr_cm_enable); |
688 | if (ret) | 693 | if (ret) |
689 | goto out_device; | 694 | goto out_device; |
690 | } | 695 | } |
691 | ret = device_register(&css[i]->pseudo_subchannel->dev); | 696 | ret = device_register(&css->pseudo_subchannel->dev); |
692 | if (ret) | 697 | if (ret) |
693 | goto out_file; | 698 | goto out_file; |
694 | } | 699 | } |
@@ -699,22 +704,26 @@ init_channel_subsystem (void) | |||
699 | for_each_subchannel(__init_channel_subsystem, NULL); | 704 | for_each_subchannel(__init_channel_subsystem, NULL); |
700 | return 0; | 705 | return 0; |
701 | out_file: | 706 | out_file: |
702 | device_remove_file(&css[i]->device, &dev_attr_cm_enable); | 707 | device_remove_file(&channel_subsystems[i]->device, |
708 | &dev_attr_cm_enable); | ||
703 | out_device: | 709 | out_device: |
704 | device_unregister(&css[i]->device); | 710 | device_unregister(&channel_subsystems[i]->device); |
705 | out_free_all: | 711 | out_free_all: |
706 | kfree(css[i]->pseudo_subchannel->lock); | 712 | kfree(channel_subsystems[i]->pseudo_subchannel->lock); |
707 | kfree(css[i]->pseudo_subchannel); | 713 | kfree(channel_subsystems[i]->pseudo_subchannel); |
708 | out_free: | 714 | out_free: |
709 | kfree(css[i]); | 715 | kfree(channel_subsystems[i]); |
710 | out_unregister: | 716 | out_unregister: |
711 | while (i > 0) { | 717 | while (i > 0) { |
718 | struct channel_subsystem *css; | ||
719 | |||
712 | i--; | 720 | i--; |
713 | device_unregister(&css[i]->pseudo_subchannel->dev); | 721 | css = channel_subsystems[i]; |
722 | device_unregister(&css->pseudo_subchannel->dev); | ||
714 | if (css_characteristics_avail && css_chsc_characteristics.secm) | 723 | if (css_characteristics_avail && css_chsc_characteristics.secm) |
715 | device_remove_file(&css[i]->device, | 724 | device_remove_file(&css->device, |
716 | &dev_attr_cm_enable); | 725 | &dev_attr_cm_enable); |
717 | device_unregister(&css[i]->device); | 726 | device_unregister(&css->device); |
718 | } | 727 | } |
719 | out_bus: | 728 | out_bus: |
720 | bus_unregister(&css_bus_type); | 729 | bus_unregister(&css_bus_type); |
diff --git a/drivers/s390/cio/css.h b/drivers/s390/cio/css.h index 5d65e83ca66e..f290c5c0f27b 100644 --- a/drivers/s390/cio/css.h +++ b/drivers/s390/cio/css.h | |||
@@ -167,7 +167,7 @@ struct channel_subsystem { | |||
167 | #define to_css(dev) container_of(dev, struct channel_subsystem, device) | 167 | #define to_css(dev) container_of(dev, struct channel_subsystem, device) |
168 | 168 | ||
169 | extern struct bus_type css_bus_type; | 169 | extern struct bus_type css_bus_type; |
170 | extern struct channel_subsystem *css[]; | 170 | extern struct channel_subsystem *channel_subsystems[]; |
171 | 171 | ||
172 | /* Some helper functions for disconnected state. */ | 172 | /* Some helper functions for disconnected state. */ |
173 | int device_is_disconnected(struct subchannel *); | 173 | int device_is_disconnected(struct subchannel *); |
diff --git a/drivers/s390/cio/device_fsm.c b/drivers/s390/cio/device_fsm.c index 8633dc537695..f772ef0a4f22 100644 --- a/drivers/s390/cio/device_fsm.c +++ b/drivers/s390/cio/device_fsm.c | |||
@@ -446,7 +446,8 @@ static void __ccw_device_get_common_pgid(struct ccw_device *cdev) | |||
446 | if (cdev->private->pgid[last].inf.ps.state1 == | 446 | if (cdev->private->pgid[last].inf.ps.state1 == |
447 | SNID_STATE1_RESET) | 447 | SNID_STATE1_RESET) |
448 | /* No previous pgid found */ | 448 | /* No previous pgid found */ |
449 | memcpy(&cdev->private->pgid[0], &css[0]->global_pgid, | 449 | memcpy(&cdev->private->pgid[0], |
450 | &channel_subsystems[0]->global_pgid, | ||
450 | sizeof(struct pgid)); | 451 | sizeof(struct pgid)); |
451 | else | 452 | else |
452 | /* Use existing pgid */ | 453 | /* Use existing pgid */ |