case -EIO:
                qeth_clear_ipacmd_list(card);
                qeth_schedule_recovery(card);
+               /* fall through */
        default:
                goto out;
        }
                                "host\n");
                        break;
                case QETH_IDX_ACT_ERR_AUTH:
+               case QETH_IDX_ACT_ERR_AUTH_USER:
                        dev_err(&card->read.ccwdev->dev,
                                "Setting the device online failed because of "
-                               "insufficient LPAR authorization\n");
+                               "insufficient authorization\n");
                        break;
                default:
                        QETH_DBF_MESSAGE(2, "%s IDX_ACTIVATE on read channel:"
                                " negative reply\n",
                                dev_name(&card->read.ccwdev->dev));
                }
+               QETH_CARD_TEXT_(card, 2, "idxread%c",
+                       QETH_IDX_ACT_CAUSE_CODE(iob->data));
                goto out;
        }
 
                card->info.link_type = link_type;
        } else
                card->info.link_type = 0;
-       QETH_DBF_TEXT_(SETUP, 2, "link%d", link_type);
+       QETH_DBF_TEXT_(SETUP, 2, "link%d", card->info.link_type);
        QETH_DBF_TEXT_(SETUP, 2, "  rc%d", iob->rc);
        return 0;
 }
 
 #define QETH_IS_IDX_ACT_POS_REPLY(buffer) (((buffer)[0x08] & 3) == 2)
 #define QETH_IDX_REPLY_LEVEL(buffer) (buffer + 0x12)
 #define QETH_IDX_ACT_CAUSE_CODE(buffer) (buffer)[0x09]
-#define QETH_IDX_ACT_ERR_EXCL  0x19
-#define QETH_IDX_ACT_ERR_AUTH  0x1E
+#define QETH_IDX_ACT_ERR_EXCL          0x19
+#define QETH_IDX_ACT_ERR_AUTH          0x1E
+#define QETH_IDX_ACT_ERR_AUTH_USER     0x20
 
 #define PDU_ENCAPSULATION(buffer) \
        (buffer + *(buffer + (*(buffer + 0x0b)) + \