2  * drivers/s390/cio/device_fsm.c
 
   3  * finite state machine for device handling
 
   5  *    Copyright (C) 2002 IBM Deutschland Entwicklung GmbH,
 
   7  *    Author(s): Cornelia Huck (cornelia.huck@de.ibm.com)
 
   8  *               Martin Schwidefsky (schwidefsky@de.ibm.com)
 
  11 #include <linux/module.h>
 
  12 #include <linux/init.h>
 
  13 #include <linux/jiffies.h>
 
  14 #include <linux/string.h>
 
  16 #include <asm/ccwdev.h>
 
  18 #include <asm/chpid.h>
 
  21 #include "cio_debug.h"
 
  29 device_is_online(struct subchannel *sch)
 
  31         struct ccw_device *cdev;
 
  33         if (!sch->dev.driver_data)
 
  35         cdev = sch->dev.driver_data;
 
  36         return (cdev->private->state == DEV_STATE_ONLINE);
 
  40 device_is_disconnected(struct subchannel *sch)
 
  42         struct ccw_device *cdev;
 
  44         if (!sch->dev.driver_data)
 
  46         cdev = sch->dev.driver_data;
 
  47         return (cdev->private->state == DEV_STATE_DISCONNECTED ||
 
  48                 cdev->private->state == DEV_STATE_DISCONNECTED_SENSE_ID);
 
  52 device_set_disconnected(struct subchannel *sch)
 
  54         struct ccw_device *cdev;
 
  56         if (!sch->dev.driver_data)
 
  58         cdev = sch->dev.driver_data;
 
  59         ccw_device_set_timeout(cdev, 0);
 
  60         cdev->private->flags.fake_irb = 0;
 
  61         cdev->private->state = DEV_STATE_DISCONNECTED;
 
  64 void device_set_intretry(struct subchannel *sch)
 
  66         struct ccw_device *cdev;
 
  68         cdev = sch->dev.driver_data;
 
  71         cdev->private->flags.intretry = 1;
 
  74 int device_trigger_verify(struct subchannel *sch)
 
  76         struct ccw_device *cdev;
 
  78         cdev = sch->dev.driver_data;
 
  79         if (!cdev || !cdev->online)
 
  81         dev_fsm_event(cdev, DEV_EVENT_VERIFY);
 
  86  * Timeout function. It just triggers a DEV_EVENT_TIMEOUT.
 
  89 ccw_device_timeout(unsigned long data)
 
  91         struct ccw_device *cdev;
 
  93         cdev = (struct ccw_device *) data;
 
  94         spin_lock_irq(cdev->ccwlock);
 
  95         dev_fsm_event(cdev, DEV_EVENT_TIMEOUT);
 
  96         spin_unlock_irq(cdev->ccwlock);
 
 103 ccw_device_set_timeout(struct ccw_device *cdev, int expires)
 
 106                 del_timer(&cdev->private->timer);
 
 109         if (timer_pending(&cdev->private->timer)) {
 
 110                 if (mod_timer(&cdev->private->timer, jiffies + expires))
 
 113         cdev->private->timer.function = ccw_device_timeout;
 
 114         cdev->private->timer.data = (unsigned long) cdev;
 
 115         cdev->private->timer.expires = jiffies + expires;
 
 116         add_timer(&cdev->private->timer);
 
 119 /* Kill any pending timers after machine check. */
 
 121 device_kill_pending_timer(struct subchannel *sch)
 
 123         struct ccw_device *cdev;
 
 125         if (!sch->dev.driver_data)
 
 127         cdev = sch->dev.driver_data;
 
 128         ccw_device_set_timeout(cdev, 0);
 
 132  * Cancel running i/o. This is called repeatedly since halt/clear are
 
 133  * asynchronous operations. We do one try with cio_cancel, two tries
 
 134  * with cio_halt, 255 tries with cio_clear. If everythings fails panic.
 
 135  * Returns 0 if device now idle, -ENODEV for device not operational and
 
 136  * -EBUSY if an interrupt is expected (either from halt/clear or from a
 
 140 ccw_device_cancel_halt_clear(struct ccw_device *cdev)
 
 142         struct subchannel *sch;
 
 145         sch = to_subchannel(cdev->dev.parent);
 
 146         ret = stsch(sch->schid, &sch->schib);
 
 147         if (ret || !sch->schib.pmcw.dnv)
 
 149         if (!sch->schib.pmcw.ena)
 
 150                 /* Not operational -> done. */
 
 152         /* Stage 1: cancel io. */
 
 153         if (!(sch->schib.scsw.actl & SCSW_ACTL_HALT_PEND) &&
 
 154             !(sch->schib.scsw.actl & SCSW_ACTL_CLEAR_PEND)) {
 
 155                 ret = cio_cancel(sch);
 
 158                 /* cancel io unsuccessful. From now on it is asynchronous. */
 
 159                 cdev->private->iretry = 3;      /* 3 halt retries. */
 
 161         if (!(sch->schib.scsw.actl & SCSW_ACTL_CLEAR_PEND)) {
 
 162                 /* Stage 2: halt io. */
 
 163                 if (cdev->private->iretry) {
 
 164                         cdev->private->iretry--;
 
 167                                 return (ret == 0) ? -EBUSY : ret;
 
 169                 /* halt io unsuccessful. */
 
 170                 cdev->private->iretry = 255;    /* 255 clear retries. */
 
 172         /* Stage 3: clear io. */
 
 173         if (cdev->private->iretry) {
 
 174                 cdev->private->iretry--;
 
 175                 ret = cio_clear (sch);
 
 176                 return (ret == 0) ? -EBUSY : ret;
 
 178         panic("Can't stop i/o on subchannel.\n");
 
 182 ccw_device_handle_oper(struct ccw_device *cdev)
 
 184         struct subchannel *sch;
 
 186         sch = to_subchannel(cdev->dev.parent);
 
 187         cdev->private->flags.recog_done = 1;
 
 189          * Check if cu type and device type still match. If
 
 190          * not, it is certainly another device and we have to
 
 191          * de- and re-register.
 
 193         if (cdev->id.cu_type != cdev->private->senseid.cu_type ||
 
 194             cdev->id.cu_model != cdev->private->senseid.cu_model ||
 
 195             cdev->id.dev_type != cdev->private->senseid.dev_type ||
 
 196             cdev->id.dev_model != cdev->private->senseid.dev_model) {
 
 197                 PREPARE_WORK(&cdev->private->kick_work,
 
 198                              ccw_device_do_unreg_rereg);
 
 199                 queue_work(ccw_device_work, &cdev->private->kick_work);
 
 202         cdev->private->flags.donotify = 1;
 
 207  * The machine won't give us any notification by machine check if a chpid has
 
 208  * been varied online on the SE so we have to find out by magic (i. e. driving
 
 209  * the channel subsystem to device selection and updating our path masks).
 
 212 __recover_lost_chpids(struct subchannel *sch, int old_lpm)
 
 218         for (i = 0; i<8; i++) {
 
 220                 if (!(sch->lpm & mask))
 
 224                 chpid.id = sch->schib.pmcw.chpid[i];
 
 225                 if (!chp_is_registered(chpid))
 
 226                         css_schedule_eval_all();
 
 231  * Stop device recognition.
 
 234 ccw_device_recog_done(struct ccw_device *cdev, int state)
 
 236         struct subchannel *sch;
 
 237         int notify, old_lpm, same_dev;
 
 239         sch = to_subchannel(cdev->dev.parent);
 
 241         ccw_device_set_timeout(cdev, 0);
 
 242         cio_disable_subchannel(sch);
 
 244          * Now that we tried recognition, we have performed device selection
 
 245          * through ssch() and the path information is up to date.
 
 248         stsch(sch->schid, &sch->schib);
 
 249         sch->lpm = sch->schib.pmcw.pam & sch->opm;
 
 250         /* Check since device may again have become not operational. */
 
 251         if (!sch->schib.pmcw.dnv)
 
 252                 state = DEV_STATE_NOT_OPER;
 
 253         if (cdev->private->state == DEV_STATE_DISCONNECTED_SENSE_ID)
 
 254                 /* Force reprobe on all chpids. */
 
 256         if (sch->lpm != old_lpm)
 
 257                 __recover_lost_chpids(sch, old_lpm);
 
 258         if (cdev->private->state == DEV_STATE_DISCONNECTED_SENSE_ID) {
 
 259                 if (state == DEV_STATE_NOT_OPER) {
 
 260                         cdev->private->flags.recog_done = 1;
 
 261                         cdev->private->state = DEV_STATE_DISCONNECTED;
 
 264                 /* Boxed devices don't need extra treatment. */
 
 267         same_dev = 0; /* Keep the compiler quiet... */
 
 269         case DEV_STATE_NOT_OPER:
 
 270                 CIO_DEBUG(KERN_WARNING, 2,
 
 271                           "SenseID : unknown device %04x on subchannel "
 
 272                           "0.%x.%04x\n", cdev->private->dev_id.devno,
 
 273                           sch->schid.ssid, sch->schid.sch_no);
 
 275         case DEV_STATE_OFFLINE:
 
 276                 if (cdev->private->state == DEV_STATE_DISCONNECTED_SENSE_ID) {
 
 277                         same_dev = ccw_device_handle_oper(cdev);
 
 280                 /* fill out sense information */
 
 281                 memset(&cdev->id, 0, sizeof(cdev->id));
 
 282                 cdev->id.cu_type   = cdev->private->senseid.cu_type;
 
 283                 cdev->id.cu_model  = cdev->private->senseid.cu_model;
 
 284                 cdev->id.dev_type  = cdev->private->senseid.dev_type;
 
 285                 cdev->id.dev_model = cdev->private->senseid.dev_model;
 
 287                         cdev->private->state = DEV_STATE_OFFLINE;
 
 289                                 /* Get device online again. */
 
 290                                 ccw_device_online(cdev);
 
 291                                 wake_up(&cdev->private->wait_q);
 
 295                 /* Issue device info message. */
 
 296                 CIO_DEBUG(KERN_INFO, 2, "SenseID : device 0.%x.%04x reports: "
 
 297                           "CU  Type/Mod = %04X/%02X, Dev Type/Mod = "
 
 299                           cdev->private->dev_id.ssid,
 
 300                           cdev->private->dev_id.devno,
 
 301                           cdev->id.cu_type, cdev->id.cu_model,
 
 302                           cdev->id.dev_type, cdev->id.dev_model);
 
 304         case DEV_STATE_BOXED:
 
 305                 CIO_DEBUG(KERN_WARNING, 2,
 
 306                           "SenseID : boxed device %04x on subchannel "
 
 307                           "0.%x.%04x\n", cdev->private->dev_id.devno,
 
 308                           sch->schid.ssid, sch->schid.sch_no);
 
 311         cdev->private->state = state;
 
 312         io_subchannel_recog_done(cdev);
 
 313         if (state != DEV_STATE_NOT_OPER)
 
 314                 wake_up(&cdev->private->wait_q);
 
 318  * Function called from device_id.c after sense id has completed.
 
 321 ccw_device_sense_id_done(struct ccw_device *cdev, int err)
 
 325                 ccw_device_recog_done(cdev, DEV_STATE_OFFLINE);
 
 327         case -ETIME:            /* Sense id stopped by timeout. */
 
 328                 ccw_device_recog_done(cdev, DEV_STATE_BOXED);
 
 331                 ccw_device_recog_done(cdev, DEV_STATE_NOT_OPER);
 
 337 ccw_device_oper_notify(struct work_struct *work)
 
 339         struct ccw_device_private *priv;
 
 340         struct ccw_device *cdev;
 
 341         struct subchannel *sch;
 
 345         priv = container_of(work, struct ccw_device_private, kick_work);
 
 347         spin_lock_irqsave(cdev->ccwlock, flags);
 
 348         sch = to_subchannel(cdev->dev.parent);
 
 349         if (sch->driver && sch->driver->notify) {
 
 350                 spin_unlock_irqrestore(cdev->ccwlock, flags);
 
 351                 ret = sch->driver->notify(&sch->dev, CIO_OPER);
 
 352                 spin_lock_irqsave(cdev->ccwlock, flags);
 
 356                 /* Reenable channel measurements, if needed. */
 
 357                 spin_unlock_irqrestore(cdev->ccwlock, flags);
 
 359                 spin_lock_irqsave(cdev->ccwlock, flags);
 
 360                 wake_up(&cdev->private->wait_q);
 
 362         spin_unlock_irqrestore(cdev->ccwlock, flags);
 
 364                 /* Driver doesn't want device back. */
 
 365                 ccw_device_do_unreg_rereg(work);
 
 369  * Finished with online/offline processing.
 
 372 ccw_device_done(struct ccw_device *cdev, int state)
 
 374         struct subchannel *sch;
 
 376         sch = to_subchannel(cdev->dev.parent);
 
 378         ccw_device_set_timeout(cdev, 0);
 
 380         if (state != DEV_STATE_ONLINE)
 
 381                 cio_disable_subchannel(sch);
 
 383         /* Reset device status. */
 
 384         memset(&cdev->private->irb, 0, sizeof(struct irb));
 
 386         cdev->private->state = state;
 
 389         if (state == DEV_STATE_BOXED)
 
 390                 CIO_DEBUG(KERN_WARNING, 2,
 
 391                           "Boxed device %04x on subchannel %04x\n",
 
 392                           cdev->private->dev_id.devno, sch->schid.sch_no);
 
 394         if (cdev->private->flags.donotify) {
 
 395                 cdev->private->flags.donotify = 0;
 
 396                 PREPARE_WORK(&cdev->private->kick_work, ccw_device_oper_notify);
 
 397                 queue_work(ccw_device_notify_work, &cdev->private->kick_work);
 
 399         wake_up(&cdev->private->wait_q);
 
 401         if (css_init_done && state != DEV_STATE_ONLINE)
 
 402                 put_device (&cdev->dev);
 
 405 static int cmp_pgid(struct pgid *p1, struct pgid *p2)
 
 413         return memcmp(c1 + 1, c2 + 1, sizeof(struct pgid) - 1);
 
 416 static void __ccw_device_get_common_pgid(struct ccw_device *cdev)
 
 422         for (i = 0; i < 8; i++) {
 
 423                 if (cdev->private->pgid[i].inf.ps.state1 == SNID_STATE1_RESET)
 
 426                 if (cdev->private->pgid[last].inf.ps.state1 ==
 
 428                         /* First non-zero PGID */
 
 432                 if (cmp_pgid(&cdev->private->pgid[i],
 
 433                              &cdev->private->pgid[last]) == 0)
 
 434                         /* Non-conflicting PGIDs */
 
 437                 /* PGID mismatch, can't pathgroup. */
 
 438                 CIO_MSG_EVENT(0, "SNID - pgid mismatch for device "
 
 439                               "0.%x.%04x, can't pathgroup\n",
 
 440                               cdev->private->dev_id.ssid,
 
 441                               cdev->private->dev_id.devno);
 
 442                 cdev->private->options.pgroup = 0;
 
 445         if (cdev->private->pgid[last].inf.ps.state1 ==
 
 447                 /* No previous pgid found */
 
 448                 memcpy(&cdev->private->pgid[0], &css[0]->global_pgid,
 
 449                        sizeof(struct pgid));
 
 451                 /* Use existing pgid */
 
 452                 memcpy(&cdev->private->pgid[0], &cdev->private->pgid[last],
 
 453                        sizeof(struct pgid));
 
 457  * Function called from device_pgid.c after sense path ground has completed.
 
 460 ccw_device_sense_pgid_done(struct ccw_device *cdev, int err)
 
 462         struct subchannel *sch;
 
 464         sch = to_subchannel(cdev->dev.parent);
 
 466         case -EOPNOTSUPP: /* path grouping not supported, use nop instead. */
 
 467                 cdev->private->options.pgroup = 0;
 
 469         case 0: /* success */
 
 470         case -EACCES: /* partial success, some paths not operational */
 
 471                 /* Check if all pgids are equal or 0. */
 
 472                 __ccw_device_get_common_pgid(cdev);
 
 474         case -ETIME:            /* Sense path group id stopped by timeout. */
 
 475         case -EUSERS:           /* device is reserved for someone else. */
 
 476                 ccw_device_done(cdev, DEV_STATE_BOXED);
 
 479                 ccw_device_done(cdev, DEV_STATE_NOT_OPER);
 
 482         /* Start Path Group verification. */
 
 483         cdev->private->state = DEV_STATE_VERIFY;
 
 484         cdev->private->flags.doverify = 0;
 
 485         ccw_device_verify_start(cdev);
 
 489  * Start device recognition.
 
 492 ccw_device_recognition(struct ccw_device *cdev)
 
 494         struct subchannel *sch;
 
 497         if ((cdev->private->state != DEV_STATE_NOT_OPER) &&
 
 498             (cdev->private->state != DEV_STATE_BOXED))
 
 500         sch = to_subchannel(cdev->dev.parent);
 
 501         ret = cio_enable_subchannel(sch, sch->schib.pmcw.isc);
 
 503                 /* Couldn't enable the subchannel for i/o. Sick device. */
 
 506         /* After 60s the device recognition is considered to have failed. */
 
 507         ccw_device_set_timeout(cdev, 60*HZ);
 
 510          * We used to start here with a sense pgid to find out whether a device
 
 511          * is locked by someone else. Unfortunately, the sense pgid command
 
 512          * code has other meanings on devices predating the path grouping
 
 513          * algorithm, so we start with sense id and box the device after an
 
 514          * timeout (or if sense pgid during path verification detects the device
 
 515          * is locked, as may happen on newer devices).
 
 517         cdev->private->flags.recog_done = 0;
 
 518         cdev->private->state = DEV_STATE_SENSE_ID;
 
 519         ccw_device_sense_id_start(cdev);
 
 524  * Handle timeout in device recognition.
 
 527 ccw_device_recog_timeout(struct ccw_device *cdev, enum dev_event dev_event)
 
 531         ret = ccw_device_cancel_halt_clear(cdev);
 
 534                 ccw_device_recog_done(cdev, DEV_STATE_BOXED);
 
 537                 ccw_device_recog_done(cdev, DEV_STATE_NOT_OPER);
 
 540                 ccw_device_set_timeout(cdev, 3*HZ);
 
 546 ccw_device_nopath_notify(struct work_struct *work)
 
 548         struct ccw_device_private *priv;
 
 549         struct ccw_device *cdev;
 
 550         struct subchannel *sch;
 
 554         priv = container_of(work, struct ccw_device_private, kick_work);
 
 556         spin_lock_irqsave(cdev->ccwlock, flags);
 
 557         sch = to_subchannel(cdev->dev.parent);
 
 561         if (sch->driver && sch->driver->notify) {
 
 562                 spin_unlock_irqrestore(cdev->ccwlock, flags);
 
 563                 ret = sch->driver->notify(&sch->dev, CIO_NO_PATH);
 
 564                 spin_lock_irqsave(cdev->ccwlock, flags);
 
 568                 if (get_device(&sch->dev)) {
 
 569                         /* Driver doesn't want to keep device. */
 
 570                         cio_disable_subchannel(sch);
 
 571                         if (get_device(&cdev->dev)) {
 
 572                                 PREPARE_WORK(&cdev->private->kick_work,
 
 573                                              ccw_device_call_sch_unregister);
 
 574                                 queue_work(ccw_device_work,
 
 575                                            &cdev->private->kick_work);
 
 577                                 put_device(&sch->dev);
 
 580                 cio_disable_subchannel(sch);
 
 581                 ccw_device_set_timeout(cdev, 0);
 
 582                 cdev->private->flags.fake_irb = 0;
 
 583                 cdev->private->state = DEV_STATE_DISCONNECTED;
 
 584                 wake_up(&cdev->private->wait_q);
 
 587         spin_unlock_irqrestore(cdev->ccwlock, flags);
 
 591 ccw_device_verify_done(struct ccw_device *cdev, int err)
 
 593         struct subchannel *sch;
 
 595         sch = to_subchannel(cdev->dev.parent);
 
 596         /* Update schib - pom may have changed. */
 
 597         stsch(sch->schid, &sch->schib);
 
 598         /* Update lpm with verified path mask. */
 
 600         /* Repeat path verification? */
 
 601         if (cdev->private->flags.doverify) {
 
 602                 cdev->private->flags.doverify = 0;
 
 603                 ccw_device_verify_start(cdev);
 
 607         case -EOPNOTSUPP: /* path grouping not supported, just set online. */
 
 608                 cdev->private->options.pgroup = 0;
 
 610                 ccw_device_done(cdev, DEV_STATE_ONLINE);
 
 611                 /* Deliver fake irb to device driver, if needed. */
 
 612                 if (cdev->private->flags.fake_irb) {
 
 613                         memset(&cdev->private->irb, 0, sizeof(struct irb));
 
 614                         cdev->private->irb.scsw.cc = 1;
 
 615                         cdev->private->irb.scsw.fctl = SCSW_FCTL_START_FUNC;
 
 616                         cdev->private->irb.scsw.actl = SCSW_ACTL_START_PEND;
 
 617                         cdev->private->irb.scsw.stctl = SCSW_STCTL_STATUS_PEND;
 
 618                         cdev->private->flags.fake_irb = 0;
 
 620                                 cdev->handler(cdev, cdev->private->intparm,
 
 621                                               &cdev->private->irb);
 
 622                         memset(&cdev->private->irb, 0, sizeof(struct irb));
 
 626                 /* Reset oper notify indication after verify error. */
 
 627                 cdev->private->flags.donotify = 0;
 
 628                 ccw_device_done(cdev, DEV_STATE_BOXED);
 
 631                 /* Reset oper notify indication after verify error. */
 
 632                 cdev->private->flags.donotify = 0;
 
 634                         PREPARE_WORK(&cdev->private->kick_work,
 
 635                                      ccw_device_nopath_notify);
 
 636                         queue_work(ccw_device_notify_work,
 
 637                                    &cdev->private->kick_work);
 
 639                         ccw_device_done(cdev, DEV_STATE_NOT_OPER);
 
 648 ccw_device_online(struct ccw_device *cdev)
 
 650         struct subchannel *sch;
 
 653         if ((cdev->private->state != DEV_STATE_OFFLINE) &&
 
 654             (cdev->private->state != DEV_STATE_BOXED))
 
 656         sch = to_subchannel(cdev->dev.parent);
 
 657         if (css_init_done && !get_device(&cdev->dev))
 
 659         ret = cio_enable_subchannel(sch, sch->schib.pmcw.isc);
 
 661                 /* Couldn't enable the subchannel for i/o. Sick device. */
 
 663                         dev_fsm_event(cdev, DEV_EVENT_NOTOPER);
 
 666         /* Do we want to do path grouping? */
 
 667         if (!cdev->private->options.pgroup) {
 
 668                 /* Start initial path verification. */
 
 669                 cdev->private->state = DEV_STATE_VERIFY;
 
 670                 cdev->private->flags.doverify = 0;
 
 671                 ccw_device_verify_start(cdev);
 
 674         /* Do a SensePGID first. */
 
 675         cdev->private->state = DEV_STATE_SENSE_PGID;
 
 676         ccw_device_sense_pgid_start(cdev);
 
 681 ccw_device_disband_done(struct ccw_device *cdev, int err)
 
 685                 ccw_device_done(cdev, DEV_STATE_OFFLINE);
 
 688                 ccw_device_done(cdev, DEV_STATE_BOXED);
 
 691                 ccw_device_done(cdev, DEV_STATE_NOT_OPER);
 
 700 ccw_device_offline(struct ccw_device *cdev)
 
 702         struct subchannel *sch;
 
 704         if (ccw_device_is_orphan(cdev)) {
 
 705                 ccw_device_done(cdev, DEV_STATE_OFFLINE);
 
 708         sch = to_subchannel(cdev->dev.parent);
 
 709         if (stsch(sch->schid, &sch->schib) || !sch->schib.pmcw.dnv)
 
 711         if (cdev->private->state != DEV_STATE_ONLINE) {
 
 712                 if (sch->schib.scsw.actl != 0)
 
 716         if (sch->schib.scsw.actl != 0)
 
 718         /* Are we doing path grouping? */
 
 719         if (!cdev->private->options.pgroup) {
 
 720                 /* No, set state offline immediately. */
 
 721                 ccw_device_done(cdev, DEV_STATE_OFFLINE);
 
 724         /* Start Set Path Group commands. */
 
 725         cdev->private->state = DEV_STATE_DISBAND_PGID;
 
 726         ccw_device_disband_start(cdev);
 
 731  * Handle timeout in device online/offline process.
 
 734 ccw_device_onoff_timeout(struct ccw_device *cdev, enum dev_event dev_event)
 
 738         ret = ccw_device_cancel_halt_clear(cdev);
 
 741                 ccw_device_done(cdev, DEV_STATE_BOXED);
 
 744                 ccw_device_done(cdev, DEV_STATE_NOT_OPER);
 
 747                 ccw_device_set_timeout(cdev, 3*HZ);
 
 752  * Handle not oper event in device recognition.
 
 755 ccw_device_recog_notoper(struct ccw_device *cdev, enum dev_event dev_event)
 
 757         ccw_device_recog_done(cdev, DEV_STATE_NOT_OPER);
 
 761  * Handle not operational event while offline.
 
 764 ccw_device_offline_notoper(struct ccw_device *cdev, enum dev_event dev_event)
 
 766         struct subchannel *sch;
 
 768         cdev->private->state = DEV_STATE_NOT_OPER;
 
 769         sch = to_subchannel(cdev->dev.parent);
 
 770         if (get_device(&cdev->dev)) {
 
 771                 PREPARE_WORK(&cdev->private->kick_work,
 
 772                              ccw_device_call_sch_unregister);
 
 773                 queue_work(ccw_device_work, &cdev->private->kick_work);
 
 775         wake_up(&cdev->private->wait_q);
 
 779  * Handle not operational event while online.
 
 782 ccw_device_online_notoper(struct ccw_device *cdev, enum dev_event dev_event)
 
 784         struct subchannel *sch;
 
 787         sch = to_subchannel(cdev->dev.parent);
 
 788         if (sch->driver->notify) {
 
 789                 spin_unlock_irq(cdev->ccwlock);
 
 790                 ret = sch->driver->notify(&sch->dev,
 
 791                                           sch->lpm ? CIO_GONE : CIO_NO_PATH);
 
 792                 spin_lock_irq(cdev->ccwlock);
 
 796                 ccw_device_set_timeout(cdev, 0);
 
 797                 cdev->private->flags.fake_irb = 0;
 
 798                 cdev->private->state = DEV_STATE_DISCONNECTED;
 
 799                 wake_up(&cdev->private->wait_q);
 
 802         cdev->private->state = DEV_STATE_NOT_OPER;
 
 803         cio_disable_subchannel(sch);
 
 804         if (sch->schib.scsw.actl != 0) {
 
 805                 // FIXME: not-oper indication to device driver ?
 
 806                 ccw_device_call_handler(cdev);
 
 808         if (get_device(&cdev->dev)) {
 
 809                 PREPARE_WORK(&cdev->private->kick_work,
 
 810                              ccw_device_call_sch_unregister);
 
 811                 queue_work(ccw_device_work, &cdev->private->kick_work);
 
 813         wake_up(&cdev->private->wait_q);
 
 817  * Handle path verification event.
 
 820 ccw_device_online_verify(struct ccw_device *cdev, enum dev_event dev_event)
 
 822         struct subchannel *sch;
 
 824         if (cdev->private->state == DEV_STATE_W4SENSE) {
 
 825                 cdev->private->flags.doverify = 1;
 
 828         sch = to_subchannel(cdev->dev.parent);
 
 830          * Since we might not just be coming from an interrupt from the
 
 831          * subchannel we have to update the schib.
 
 833         stsch(sch->schid, &sch->schib);
 
 835         if (sch->schib.scsw.actl != 0 ||
 
 836             (sch->schib.scsw.stctl & SCSW_STCTL_STATUS_PEND) ||
 
 837             (cdev->private->irb.scsw.stctl & SCSW_STCTL_STATUS_PEND)) {
 
 839                  * No final status yet or final status not yet delivered
 
 840                  * to the device driver. Can't do path verfication now,
 
 841                  * delay until final status was delivered.
 
 843                 cdev->private->flags.doverify = 1;
 
 846         /* Device is idle, we can do the path verification. */
 
 847         cdev->private->state = DEV_STATE_VERIFY;
 
 848         cdev->private->flags.doverify = 0;
 
 849         ccw_device_verify_start(cdev);
 
 853  * Got an interrupt for a normal io (state online).
 
 856 ccw_device_irq(struct ccw_device *cdev, enum dev_event dev_event)
 
 860         irb = (struct irb *) __LC_IRB;
 
 861         /* Check for unsolicited interrupt. */
 
 862         if ((irb->scsw.stctl ==
 
 863                         (SCSW_STCTL_STATUS_PEND | SCSW_STCTL_ALERT_STATUS))
 
 864             && (!irb->scsw.cc)) {
 
 865                 if ((irb->scsw.dstat & DEV_STAT_UNIT_CHECK) &&
 
 866                     !irb->esw.esw0.erw.cons) {
 
 867                         /* Unit check but no sense data. Need basic sense. */
 
 868                         if (ccw_device_do_sense(cdev, irb) != 0)
 
 869                                 goto call_handler_unsol;
 
 870                         memcpy(&cdev->private->irb, irb, sizeof(struct irb));
 
 871                         cdev->private->state = DEV_STATE_W4SENSE;
 
 872                         cdev->private->intparm = 0;
 
 877                         cdev->handler (cdev, 0, irb);
 
 878                 if (cdev->private->flags.doverify)
 
 879                         ccw_device_online_verify(cdev, 0);
 
 882         /* Accumulate status and find out if a basic sense is needed. */
 
 883         ccw_device_accumulate_irb(cdev, irb);
 
 884         if (cdev->private->flags.dosense) {
 
 885                 if (ccw_device_do_sense(cdev, irb) == 0) {
 
 886                         cdev->private->state = DEV_STATE_W4SENSE;
 
 890         /* Call the handler. */
 
 891         if (ccw_device_call_handler(cdev) && cdev->private->flags.doverify)
 
 892                 /* Start delayed path verification. */
 
 893                 ccw_device_online_verify(cdev, 0);
 
 897  * Got an timeout in online state.
 
 900 ccw_device_online_timeout(struct ccw_device *cdev, enum dev_event dev_event)
 
 904         ccw_device_set_timeout(cdev, 0);
 
 905         ret = ccw_device_cancel_halt_clear(cdev);
 
 907                 ccw_device_set_timeout(cdev, 3*HZ);
 
 908                 cdev->private->state = DEV_STATE_TIMEOUT_KILL;
 
 911         if (ret == -ENODEV) {
 
 912                 struct subchannel *sch;
 
 914                 sch = to_subchannel(cdev->dev.parent);
 
 916                         PREPARE_WORK(&cdev->private->kick_work,
 
 917                                      ccw_device_nopath_notify);
 
 918                         queue_work(ccw_device_notify_work,
 
 919                                    &cdev->private->kick_work);
 
 921                         dev_fsm_event(cdev, DEV_EVENT_NOTOPER);
 
 922         } else if (cdev->handler)
 
 923                 cdev->handler(cdev, cdev->private->intparm,
 
 924                               ERR_PTR(-ETIMEDOUT));
 
 928  * Got an interrupt for a basic sense.
 
 931 ccw_device_w4sense(struct ccw_device *cdev, enum dev_event dev_event)
 
 935         irb = (struct irb *) __LC_IRB;
 
 936         /* Check for unsolicited interrupt. */
 
 937         if (irb->scsw.stctl ==
 
 938                         (SCSW_STCTL_STATUS_PEND | SCSW_STCTL_ALERT_STATUS)) {
 
 939                 if (irb->scsw.cc == 1)
 
 940                         /* Basic sense hasn't started. Try again. */
 
 941                         ccw_device_do_sense(cdev, irb);
 
 943                         printk(KERN_INFO "Huh? %s(%s): unsolicited "
 
 945                                __FUNCTION__, cdev->dev.bus_id);
 
 947                                 cdev->handler (cdev, 0, irb);
 
 952          * Check if a halt or clear has been issued in the meanwhile. If yes,
 
 953          * only deliver the halt/clear interrupt to the device driver as if it
 
 954          * had killed the original request.
 
 956         if (irb->scsw.fctl & (SCSW_FCTL_CLEAR_FUNC | SCSW_FCTL_HALT_FUNC)) {
 
 957                 /* Retry Basic Sense if requested. */
 
 958                 if (cdev->private->flags.intretry) {
 
 959                         cdev->private->flags.intretry = 0;
 
 960                         ccw_device_do_sense(cdev, irb);
 
 963                 cdev->private->flags.dosense = 0;
 
 964                 memset(&cdev->private->irb, 0, sizeof(struct irb));
 
 965                 ccw_device_accumulate_irb(cdev, irb);
 
 968         /* Add basic sense info to irb. */
 
 969         ccw_device_accumulate_basic_sense(cdev, irb);
 
 970         if (cdev->private->flags.dosense) {
 
 971                 /* Another basic sense is needed. */
 
 972                 ccw_device_do_sense(cdev, irb);
 
 976         cdev->private->state = DEV_STATE_ONLINE;
 
 977         /* Call the handler. */
 
 978         if (ccw_device_call_handler(cdev) && cdev->private->flags.doverify)
 
 979                 /* Start delayed path verification. */
 
 980                 ccw_device_online_verify(cdev, 0);
 
 984 ccw_device_clear_verify(struct ccw_device *cdev, enum dev_event dev_event)
 
 988         irb = (struct irb *) __LC_IRB;
 
 989         /* Accumulate status. We don't do basic sense. */
 
 990         ccw_device_accumulate_irb(cdev, irb);
 
 991         /* Remember to clear irb to avoid residuals. */
 
 992         memset(&cdev->private->irb, 0, sizeof(struct irb));
 
 993         /* Try to start delayed device verification. */
 
 994         ccw_device_online_verify(cdev, 0);
 
 995         /* Note: Don't call handler for cio initiated clear! */
 
 999 ccw_device_killing_irq(struct ccw_device *cdev, enum dev_event dev_event)
 
1001         struct subchannel *sch;
 
1003         sch = to_subchannel(cdev->dev.parent);
 
1004         ccw_device_set_timeout(cdev, 0);
 
1005         /* Start delayed path verification. */
 
1006         ccw_device_online_verify(cdev, 0);
 
1007         /* OK, i/o is dead now. Call interrupt handler. */
 
1009                 cdev->handler(cdev, cdev->private->intparm,
 
1014 ccw_device_killing_timeout(struct ccw_device *cdev, enum dev_event dev_event)
 
1018         ret = ccw_device_cancel_halt_clear(cdev);
 
1019         if (ret == -EBUSY) {
 
1020                 ccw_device_set_timeout(cdev, 3*HZ);
 
1023         /* Start delayed path verification. */
 
1024         ccw_device_online_verify(cdev, 0);
 
1026                 cdev->handler(cdev, cdev->private->intparm,
 
1030 void device_kill_io(struct subchannel *sch)
 
1033         struct ccw_device *cdev;
 
1035         cdev = sch->dev.driver_data;
 
1036         ret = ccw_device_cancel_halt_clear(cdev);
 
1037         if (ret == -EBUSY) {
 
1038                 ccw_device_set_timeout(cdev, 3*HZ);
 
1039                 cdev->private->state = DEV_STATE_TIMEOUT_KILL;
 
1042         /* Start delayed path verification. */
 
1043         ccw_device_online_verify(cdev, 0);
 
1045                 cdev->handler(cdev, cdev->private->intparm,
 
1050 ccw_device_delay_verify(struct ccw_device *cdev, enum dev_event dev_event)
 
1052         /* Start verification after current task finished. */
 
1053         cdev->private->flags.doverify = 1;
 
1057 ccw_device_stlck_done(struct ccw_device *cdev, enum dev_event dev_event)
 
1061         switch (dev_event) {
 
1062         case DEV_EVENT_INTERRUPT:
 
1063                 irb = (struct irb *) __LC_IRB;
 
1064                 /* Check for unsolicited interrupt. */
 
1065                 if ((irb->scsw.stctl ==
 
1066                      (SCSW_STCTL_STATUS_PEND | SCSW_STCTL_ALERT_STATUS)) &&
 
1068                         /* FIXME: we should restart stlck here, but this
 
1069                          * is extremely unlikely ... */
 
1072                 ccw_device_accumulate_irb(cdev, irb);
 
1073                 /* We don't care about basic sense etc. */
 
1075         default: /* timeout */
 
1079         wake_up(&cdev->private->wait_q);
 
1083 ccw_device_start_id(struct ccw_device *cdev, enum dev_event dev_event)
 
1085         struct subchannel *sch;
 
1087         sch = to_subchannel(cdev->dev.parent);
 
1088         if (cio_enable_subchannel(sch, sch->schib.pmcw.isc) != 0)
 
1089                 /* Couldn't enable the subchannel for i/o. Sick device. */
 
1092         /* After 60s the device recognition is considered to have failed. */
 
1093         ccw_device_set_timeout(cdev, 60*HZ);
 
1095         cdev->private->state = DEV_STATE_DISCONNECTED_SENSE_ID;
 
1096         ccw_device_sense_id_start(cdev);
 
1100 device_trigger_reprobe(struct subchannel *sch)
 
1102         struct ccw_device *cdev;
 
1104         if (!sch->dev.driver_data)
 
1106         cdev = sch->dev.driver_data;
 
1107         if (cdev->private->state != DEV_STATE_DISCONNECTED)
 
1110         /* Update some values. */
 
1111         if (stsch(sch->schid, &sch->schib))
 
1113         if (!sch->schib.pmcw.dnv)
 
1116          * The pim, pam, pom values may not be accurate, but they are the best
 
1117          * we have before performing device selection :/
 
1119         sch->lpm = sch->schib.pmcw.pam & sch->opm;
 
1120         /* Re-set some bits in the pmcw that were lost. */
 
1121         sch->schib.pmcw.isc = 3;
 
1122         sch->schib.pmcw.csense = 1;
 
1123         sch->schib.pmcw.ena = 0;
 
1124         if ((sch->lpm & (sch->lpm - 1)) != 0)
 
1125                 sch->schib.pmcw.mp = 1;
 
1126         sch->schib.pmcw.intparm = (__u32)(unsigned long)sch;
 
1127         /* We should also udate ssd info, but this has to wait. */
 
1128         /* Check if this is another device which appeared on the same sch. */
 
1129         if (sch->schib.pmcw.dev != cdev->private->dev_id.devno) {
 
1130                 PREPARE_WORK(&cdev->private->kick_work,
 
1131                              ccw_device_move_to_orphanage);
 
1132                 queue_work(ccw_device_work, &cdev->private->kick_work);
 
1134                 ccw_device_start_id(cdev, 0);
 
1138 ccw_device_offline_irq(struct ccw_device *cdev, enum dev_event dev_event)
 
1140         struct subchannel *sch;
 
1142         sch = to_subchannel(cdev->dev.parent);
 
1144          * An interrupt in state offline means a previous disable was not
 
1145          * successful. Try again.
 
1147         cio_disable_subchannel(sch);
 
1151 ccw_device_change_cmfstate(struct ccw_device *cdev, enum dev_event dev_event)
 
1153         retry_set_schib(cdev);
 
1154         cdev->private->state = DEV_STATE_ONLINE;
 
1155         dev_fsm_event(cdev, dev_event);
 
1158 static void ccw_device_update_cmfblock(struct ccw_device *cdev,
 
1159                                        enum dev_event dev_event)
 
1161         cmf_retry_copy_block(cdev);
 
1162         cdev->private->state = DEV_STATE_ONLINE;
 
1163         dev_fsm_event(cdev, dev_event);
 
1167 ccw_device_quiesce_done(struct ccw_device *cdev, enum dev_event dev_event)
 
1169         ccw_device_set_timeout(cdev, 0);
 
1170         if (dev_event == DEV_EVENT_NOTOPER)
 
1171                 cdev->private->state = DEV_STATE_NOT_OPER;
 
1173                 cdev->private->state = DEV_STATE_OFFLINE;
 
1174         wake_up(&cdev->private->wait_q);
 
1178 ccw_device_quiesce_timeout(struct ccw_device *cdev, enum dev_event dev_event)
 
1182         ret = ccw_device_cancel_halt_clear(cdev);
 
1185                 cdev->private->state = DEV_STATE_OFFLINE;
 
1186                 wake_up(&cdev->private->wait_q);
 
1189                 cdev->private->state = DEV_STATE_NOT_OPER;
 
1190                 wake_up(&cdev->private->wait_q);
 
1193                 ccw_device_set_timeout(cdev, HZ/10);
 
1198  * No operation action. This is used e.g. to ignore a timeout event in
 
1202 ccw_device_nop(struct ccw_device *cdev, enum dev_event dev_event)
 
1207  * Bug operation action. 
 
1210 ccw_device_bug(struct ccw_device *cdev, enum dev_event dev_event)
 
1212         printk(KERN_EMERG "dev_jumptable[%i][%i] == NULL\n",
 
1213                cdev->private->state, dev_event);
 
1218  * device statemachine
 
1220 fsm_func_t *dev_jumptable[NR_DEV_STATES][NR_DEV_EVENTS] = {
 
1221         [DEV_STATE_NOT_OPER] = {
 
1222                 [DEV_EVENT_NOTOPER]     = ccw_device_nop,
 
1223                 [DEV_EVENT_INTERRUPT]   = ccw_device_bug,
 
1224                 [DEV_EVENT_TIMEOUT]     = ccw_device_nop,
 
1225                 [DEV_EVENT_VERIFY]      = ccw_device_nop,
 
1227         [DEV_STATE_SENSE_PGID] = {
 
1228                 [DEV_EVENT_NOTOPER]     = ccw_device_online_notoper,
 
1229                 [DEV_EVENT_INTERRUPT]   = ccw_device_sense_pgid_irq,
 
1230                 [DEV_EVENT_TIMEOUT]     = ccw_device_onoff_timeout,
 
1231                 [DEV_EVENT_VERIFY]      = ccw_device_nop,
 
1233         [DEV_STATE_SENSE_ID] = {
 
1234                 [DEV_EVENT_NOTOPER]     = ccw_device_recog_notoper,
 
1235                 [DEV_EVENT_INTERRUPT]   = ccw_device_sense_id_irq,
 
1236                 [DEV_EVENT_TIMEOUT]     = ccw_device_recog_timeout,
 
1237                 [DEV_EVENT_VERIFY]      = ccw_device_nop,
 
1239         [DEV_STATE_OFFLINE] = {
 
1240                 [DEV_EVENT_NOTOPER]     = ccw_device_offline_notoper,
 
1241                 [DEV_EVENT_INTERRUPT]   = ccw_device_offline_irq,
 
1242                 [DEV_EVENT_TIMEOUT]     = ccw_device_nop,
 
1243                 [DEV_EVENT_VERIFY]      = ccw_device_nop,
 
1245         [DEV_STATE_VERIFY] = {
 
1246                 [DEV_EVENT_NOTOPER]     = ccw_device_online_notoper,
 
1247                 [DEV_EVENT_INTERRUPT]   = ccw_device_verify_irq,
 
1248                 [DEV_EVENT_TIMEOUT]     = ccw_device_onoff_timeout,
 
1249                 [DEV_EVENT_VERIFY]      = ccw_device_delay_verify,
 
1251         [DEV_STATE_ONLINE] = {
 
1252                 [DEV_EVENT_NOTOPER]     = ccw_device_online_notoper,
 
1253                 [DEV_EVENT_INTERRUPT]   = ccw_device_irq,
 
1254                 [DEV_EVENT_TIMEOUT]     = ccw_device_online_timeout,
 
1255                 [DEV_EVENT_VERIFY]      = ccw_device_online_verify,
 
1257         [DEV_STATE_W4SENSE] = {
 
1258                 [DEV_EVENT_NOTOPER]     = ccw_device_online_notoper,
 
1259                 [DEV_EVENT_INTERRUPT]   = ccw_device_w4sense,
 
1260                 [DEV_EVENT_TIMEOUT]     = ccw_device_nop,
 
1261                 [DEV_EVENT_VERIFY]      = ccw_device_online_verify,
 
1263         [DEV_STATE_DISBAND_PGID] = {
 
1264                 [DEV_EVENT_NOTOPER]     = ccw_device_online_notoper,
 
1265                 [DEV_EVENT_INTERRUPT]   = ccw_device_disband_irq,
 
1266                 [DEV_EVENT_TIMEOUT]     = ccw_device_onoff_timeout,
 
1267                 [DEV_EVENT_VERIFY]      = ccw_device_nop,
 
1269         [DEV_STATE_BOXED] = {
 
1270                 [DEV_EVENT_NOTOPER]     = ccw_device_offline_notoper,
 
1271                 [DEV_EVENT_INTERRUPT]   = ccw_device_stlck_done,
 
1272                 [DEV_EVENT_TIMEOUT]     = ccw_device_stlck_done,
 
1273                 [DEV_EVENT_VERIFY]      = ccw_device_nop,
 
1275         /* states to wait for i/o completion before doing something */
 
1276         [DEV_STATE_CLEAR_VERIFY] = {
 
1277                 [DEV_EVENT_NOTOPER]     = ccw_device_online_notoper,
 
1278                 [DEV_EVENT_INTERRUPT]   = ccw_device_clear_verify,
 
1279                 [DEV_EVENT_TIMEOUT]     = ccw_device_nop,
 
1280                 [DEV_EVENT_VERIFY]      = ccw_device_nop,
 
1282         [DEV_STATE_TIMEOUT_KILL] = {
 
1283                 [DEV_EVENT_NOTOPER]     = ccw_device_online_notoper,
 
1284                 [DEV_EVENT_INTERRUPT]   = ccw_device_killing_irq,
 
1285                 [DEV_EVENT_TIMEOUT]     = ccw_device_killing_timeout,
 
1286                 [DEV_EVENT_VERIFY]      = ccw_device_nop, //FIXME
 
1288         [DEV_STATE_QUIESCE] = {
 
1289                 [DEV_EVENT_NOTOPER]     = ccw_device_quiesce_done,
 
1290                 [DEV_EVENT_INTERRUPT]   = ccw_device_quiesce_done,
 
1291                 [DEV_EVENT_TIMEOUT]     = ccw_device_quiesce_timeout,
 
1292                 [DEV_EVENT_VERIFY]      = ccw_device_nop,
 
1294         /* special states for devices gone not operational */
 
1295         [DEV_STATE_DISCONNECTED] = {
 
1296                 [DEV_EVENT_NOTOPER]     = ccw_device_nop,
 
1297                 [DEV_EVENT_INTERRUPT]   = ccw_device_start_id,
 
1298                 [DEV_EVENT_TIMEOUT]     = ccw_device_bug,
 
1299                 [DEV_EVENT_VERIFY]      = ccw_device_start_id,
 
1301         [DEV_STATE_DISCONNECTED_SENSE_ID] = {
 
1302                 [DEV_EVENT_NOTOPER]     = ccw_device_recog_notoper,
 
1303                 [DEV_EVENT_INTERRUPT]   = ccw_device_sense_id_irq,
 
1304                 [DEV_EVENT_TIMEOUT]     = ccw_device_recog_timeout,
 
1305                 [DEV_EVENT_VERIFY]      = ccw_device_nop,
 
1307         [DEV_STATE_CMFCHANGE] = {
 
1308                 [DEV_EVENT_NOTOPER]     = ccw_device_change_cmfstate,
 
1309                 [DEV_EVENT_INTERRUPT]   = ccw_device_change_cmfstate,
 
1310                 [DEV_EVENT_TIMEOUT]     = ccw_device_change_cmfstate,
 
1311                 [DEV_EVENT_VERIFY]      = ccw_device_change_cmfstate,
 
1313         [DEV_STATE_CMFUPDATE] = {
 
1314                 [DEV_EVENT_NOTOPER]     = ccw_device_update_cmfblock,
 
1315                 [DEV_EVENT_INTERRUPT]   = ccw_device_update_cmfblock,
 
1316                 [DEV_EVENT_TIMEOUT]     = ccw_device_update_cmfblock,
 
1317                 [DEV_EVENT_VERIFY]      = ccw_device_update_cmfblock,
 
1322  * io_subchannel_irq is called for "real" interrupts or for status
 
1323  * pending conditions on msch.
 
1326 io_subchannel_irq (struct device *pdev)
 
1328         struct ccw_device *cdev;
 
1330         cdev = to_subchannel(pdev)->dev.driver_data;
 
1332         CIO_TRACE_EVENT (3, "IRQ");
 
1333         CIO_TRACE_EVENT (3, pdev->bus_id);
 
1335                 dev_fsm_event(cdev, DEV_EVENT_INTERRUPT);
 
1338 EXPORT_SYMBOL_GPL(ccw_device_set_timeout);