2  * hvc_iucv.c - z/VM IUCV hypervisor console (HVC) device driver
 
   4  * This HVC device driver provides terminal access using
 
   5  * z/VM IUCV communication paths.
 
   7  * Copyright IBM Corp. 2008
 
   9  * Author(s):   Hendrik Brueckner <brueckner@linux.vnet.ibm.com>
 
  11 #define KMSG_COMPONENT          "hvc_iucv"
 
  12 #define pr_fmt(fmt)             KMSG_COMPONENT ": " fmt
 
  14 #include <linux/types.h>
 
  15 #include <asm/ebcdic.h>
 
  16 #include <linux/delay.h>
 
  17 #include <linux/init.h>
 
  18 #include <linux/mempool.h>
 
  19 #include <linux/module.h>
 
  20 #include <linux/tty.h>
 
  21 #include <linux/wait.h>
 
  22 #include <net/iucv/iucv.h>
 
  24 #include "hvc_console.h"
 
  27 /* General device driver settings */
 
  28 #define HVC_IUCV_MAGIC          0xc9e4c3e5
 
  29 #define MAX_HVC_IUCV_LINES      HVC_ALLOC_TTY_ADAPTERS
 
  30 #define MEMPOOL_MIN_NR          (PAGE_SIZE / sizeof(struct iucv_tty_buffer)/4)
 
  32 /* IUCV TTY message  */
 
  33 #define MSG_VERSION             0x02    /* Message version */
 
  34 #define MSG_TYPE_ERROR          0x01    /* Error message */
 
  35 #define MSG_TYPE_TERMENV        0x02    /* Terminal environment variable */
 
  36 #define MSG_TYPE_TERMIOS        0x04    /* Terminal IO struct update */
 
  37 #define MSG_TYPE_WINSIZE        0x08    /* Terminal window size update */
 
  38 #define MSG_TYPE_DATA           0x10    /* Terminal data */
 
  41         u8      version;                /* Message version */
 
  42         u8      type;                   /* Message type */
 
  43 #define MSG_MAX_DATALEN         ((u16)(~0))
 
  44         u16     datalen;                /* Payload length */
 
  45         u8      data[];                 /* Payload buffer */
 
  46 } __attribute__((packed));
 
  47 #define MSG_SIZE(s)             ((s) + offsetof(struct iucv_tty_msg, data))
 
  60 struct hvc_iucv_private {
 
  61         struct hvc_struct       *hvc;           /* HVC struct reference */
 
  62         u8                      srv_name[8];    /* IUCV service name (ebcdic) */
 
  63         unsigned char           is_console;     /* Linux console usage flag */
 
  64         enum iucv_state_t       iucv_state;     /* IUCV connection status */
 
  65         enum tty_state_t        tty_state;      /* TTY status */
 
  66         struct iucv_path        *path;          /* IUCV path pointer */
 
  67         spinlock_t              lock;           /* hvc_iucv_private lock */
 
  68 #define SNDBUF_SIZE             (PAGE_SIZE)     /* must be < MSG_MAX_DATALEN */
 
  69         void                    *sndbuf;        /* send buffer            */
 
  70         size_t                  sndbuf_len;     /* length of send buffer  */
 
  71 #define QUEUE_SNDBUF_DELAY      (HZ / 25)
 
  72         struct delayed_work     sndbuf_work;    /* work: send iucv msg(s) */
 
  73         wait_queue_head_t       sndbuf_waitq;   /* wait for send completion */
 
  74         struct list_head        tty_outqueue;   /* outgoing IUCV messages */
 
  75         struct list_head        tty_inqueue;    /* incoming IUCV messages */
 
  78 struct iucv_tty_buffer {
 
  79         struct list_head        list;   /* list pointer */
 
  80         struct iucv_message     msg;    /* store an IUCV message */
 
  81         size_t                  offset; /* data buffer offset */
 
  82         struct iucv_tty_msg     *mbuf;  /* buffer to store input/output data */
 
  85 /* IUCV callback handler */
 
  86 static  int hvc_iucv_path_pending(struct iucv_path *, u8[8], u8[16]);
 
  87 static void hvc_iucv_path_severed(struct iucv_path *, u8[16]);
 
  88 static void hvc_iucv_msg_pending(struct iucv_path *, struct iucv_message *);
 
  89 static void hvc_iucv_msg_complete(struct iucv_path *, struct iucv_message *);
 
  92 /* Kernel module parameter: use one terminal device as default */
 
  93 static unsigned long hvc_iucv_devices = 1;
 
  95 /* Array of allocated hvc iucv tty lines... */
 
  96 static struct hvc_iucv_private *hvc_iucv_table[MAX_HVC_IUCV_LINES];
 
  97 #define IUCV_HVC_CON_IDX        (0)
 
  99 /* Kmem cache and mempool for iucv_tty_buffer elements */
 
 100 static struct kmem_cache *hvc_iucv_buffer_cache;
 
 101 static mempool_t *hvc_iucv_mempool;
 
 103 /* IUCV handler callback functions */
 
 104 static struct iucv_handler hvc_iucv_handler = {
 
 105         .path_pending  = hvc_iucv_path_pending,
 
 106         .path_severed  = hvc_iucv_path_severed,
 
 107         .message_complete = hvc_iucv_msg_complete,
 
 108         .message_pending  = hvc_iucv_msg_pending,
 
 113  * hvc_iucv_get_private() - Return a struct hvc_iucv_private instance.
 
 114  * @num:        The HVC virtual terminal number (vtermno)
 
 116  * This function returns the struct hvc_iucv_private instance that corresponds
 
 117  * to the HVC virtual terminal number specified as parameter @num.
 
 119 struct hvc_iucv_private *hvc_iucv_get_private(uint32_t num)
 
 121         if ((num < HVC_IUCV_MAGIC) || (num - HVC_IUCV_MAGIC > hvc_iucv_devices))
 
 123         return hvc_iucv_table[num - HVC_IUCV_MAGIC];
 
 127  * alloc_tty_buffer() - Return a new struct iucv_tty_buffer element.
 
 128  * @size:       Size of the internal buffer used to store data.
 
 129  * @flags:      Memory allocation flags passed to mempool.
 
 131  * This function allocates a new struct iucv_tty_buffer element and, optionally,
 
 132  * allocates an internal data buffer with the specified size @size.
 
 133  * Note: The total message size arises from the internal buffer size and the
 
 134  *       members of the iucv_tty_msg structure.
 
 135  * The function returns NULL if memory allocation has failed.
 
 137 static struct iucv_tty_buffer *alloc_tty_buffer(size_t size, gfp_t flags)
 
 139         struct iucv_tty_buffer *bufp;
 
 141         bufp = mempool_alloc(hvc_iucv_mempool, flags);
 
 144         memset(bufp, 0, sizeof(*bufp));
 
 147                 bufp->msg.length = MSG_SIZE(size);
 
 148                 bufp->mbuf = kmalloc(bufp->msg.length, flags);
 
 150                         mempool_free(bufp, hvc_iucv_mempool);
 
 153                 bufp->mbuf->version = MSG_VERSION;
 
 154                 bufp->mbuf->type    = MSG_TYPE_DATA;
 
 155                 bufp->mbuf->datalen = (u16) size;
 
 161  * destroy_tty_buffer() - destroy struct iucv_tty_buffer element.
 
 162  * @bufp:       Pointer to a struct iucv_tty_buffer element, SHALL NOT be NULL.
 
 164 static void destroy_tty_buffer(struct iucv_tty_buffer *bufp)
 
 167         mempool_free(bufp, hvc_iucv_mempool);
 
 171  * destroy_tty_buffer_list() - call destroy_tty_buffer() for each list element.
 
 172  * @list:       List containing struct iucv_tty_buffer elements.
 
 174 static void destroy_tty_buffer_list(struct list_head *list)
 
 176         struct iucv_tty_buffer *ent, *next;
 
 178         list_for_each_entry_safe(ent, next, list, list) {
 
 179                 list_del(&ent->list);
 
 180                 destroy_tty_buffer(ent);
 
 185  * hvc_iucv_write() - Receive IUCV message & write data to HVC buffer.
 
 186  * @priv:               Pointer to struct hvc_iucv_private
 
 187  * @buf:                HVC buffer for writing received terminal data.
 
 188  * @count:              HVC buffer size.
 
 189  * @has_more_data:      Pointer to an int variable.
 
 191  * The function picks up pending messages from the input queue and receives
 
 192  * the message data that is then written to the specified buffer @buf.
 
 193  * If the buffer size @count is less than the data message size, the
 
 194  * message is kept on the input queue and @has_more_data is set to 1.
 
 195  * If all message data has been written, the message is removed from
 
 198  * The function returns the number of bytes written to the terminal, zero if
 
 199  * there are no pending data messages available or if there is no established
 
 201  * If the IUCV path has been severed, then -EPIPE is returned to cause a
 
 202  * hang up (that is issued by the HVC layer).
 
 204 static int hvc_iucv_write(struct hvc_iucv_private *priv,
 
 205                           char *buf, int count, int *has_more_data)
 
 207         struct iucv_tty_buffer *rb;
 
 211         /* immediately return if there is no IUCV connection */
 
 212         if (priv->iucv_state == IUCV_DISCONN)
 
 215         /* if the IUCV path has been severed, return -EPIPE to inform the
 
 216          * HVC layer to hang up the tty device. */
 
 217         if (priv->iucv_state == IUCV_SEVERED)
 
 220         /* check if there are pending messages */
 
 221         if (list_empty(&priv->tty_inqueue))
 
 224         /* receive an iucv message and flip data to the tty (ldisc) */
 
 225         rb = list_first_entry(&priv->tty_inqueue, struct iucv_tty_buffer, list);
 
 228         if (!rb->mbuf) { /* message not yet received ... */
 
 229                 /* allocate mem to store msg data; if no memory is available
 
 230                  * then leave the buffer on the list and re-try later */
 
 231                 rb->mbuf = kmalloc(rb->msg.length, GFP_ATOMIC);
 
 235                 rc = __iucv_message_receive(priv->path, &rb->msg, 0,
 
 236                                             rb->mbuf, rb->msg.length, NULL);
 
 238                 case 0: /* Successful       */
 
 240                 case 2: /* No message found */
 
 241                 case 9: /* Message purged   */
 
 246                 /* remove buffer if an error has occured or received data
 
 248                 if (rc || (rb->mbuf->version != MSG_VERSION) ||
 
 249                           (rb->msg.length    != MSG_SIZE(rb->mbuf->datalen)))
 
 250                         goto out_remove_buffer;
 
 253         switch (rb->mbuf->type) {
 
 255                 written = min_t(int, rb->mbuf->datalen - rb->offset, count);
 
 256                 memcpy(buf, rb->mbuf->data + rb->offset, written);
 
 257                 if (written < (rb->mbuf->datalen - rb->offset)) {
 
 258                         rb->offset += written;
 
 264         case MSG_TYPE_WINSIZE:
 
 265                 if (rb->mbuf->datalen != sizeof(struct winsize))
 
 267                 hvc_resize(priv->hvc, *((struct winsize *) rb->mbuf->data));
 
 270         case MSG_TYPE_ERROR:    /* ignored ... */
 
 271         case MSG_TYPE_TERMENV:  /* ignored ... */
 
 272         case MSG_TYPE_TERMIOS:  /* ignored ... */
 
 278         destroy_tty_buffer(rb);
 
 279         *has_more_data = !list_empty(&priv->tty_inqueue);
 
 286  * hvc_iucv_get_chars() - HVC get_chars operation.
 
 287  * @vtermno:    HVC virtual terminal number.
 
 288  * @buf:        Pointer to a buffer to store data
 
 289  * @count:      Size of buffer available for writing
 
 291  * The HVC thread calls this method to read characters from the back-end.
 
 292  * If an IUCV communication path has been established, pending IUCV messages
 
 293  * are received and data is copied into buffer @buf up to @count bytes.
 
 295  * Locking:     The routine gets called under an irqsave() spinlock; and
 
 296  *              the routine locks the struct hvc_iucv_private->lock to call
 
 299 static int hvc_iucv_get_chars(uint32_t vtermno, char *buf, int count)
 
 301         struct hvc_iucv_private *priv = hvc_iucv_get_private(vtermno);
 
 311         spin_lock(&priv->lock);
 
 313         written = hvc_iucv_write(priv, buf, count, &has_more_data);
 
 314         spin_unlock(&priv->lock);
 
 316         /* if there are still messages on the queue... schedule another run */
 
 324  * hvc_iucv_queue() - Buffer terminal data for sending.
 
 325  * @priv:       Pointer to struct hvc_iucv_private instance.
 
 326  * @buf:        Buffer containing data to send.
 
 327  * @count:      Size of buffer and amount of data to send.
 
 329  * The function queues data for sending. To actually send the buffered data,
 
 330  * a work queue function is scheduled (with QUEUE_SNDBUF_DELAY).
 
 331  * The function returns the number of data bytes that has been buffered.
 
 333  * If the device is not connected, data is ignored and the function returns
 
 335  * If the buffer is full, the function returns 0.
 
 336  * If an existing IUCV communicaton path has been severed, -EPIPE is returned
 
 337  * (that can be passed to HVC layer to cause a tty hangup).
 
 339 static int hvc_iucv_queue(struct hvc_iucv_private *priv, const char *buf,
 
 344         if (priv->iucv_state == IUCV_DISCONN)
 
 345                 return count;                   /* ignore data */
 
 347         if (priv->iucv_state == IUCV_SEVERED)
 
 350         len = min_t(size_t, count, SNDBUF_SIZE - priv->sndbuf_len);
 
 354         memcpy(priv->sndbuf + priv->sndbuf_len, buf, len);
 
 355         priv->sndbuf_len += len;
 
 357         if (priv->iucv_state == IUCV_CONNECTED)
 
 358                 schedule_delayed_work(&priv->sndbuf_work, QUEUE_SNDBUF_DELAY);
 
 364  * hvc_iucv_send() - Send an IUCV message containing terminal data.
 
 365  * @priv:       Pointer to struct hvc_iucv_private instance.
 
 367  * If an IUCV communication path has been established, the buffered output data
 
 368  * is sent via an IUCV message and the number of bytes sent is returned.
 
 369  * Returns 0 if there is no established IUCV communication path or
 
 370  * -EPIPE if an existing IUCV communicaton path has been severed.
 
 372 static int hvc_iucv_send(struct hvc_iucv_private *priv)
 
 374         struct iucv_tty_buffer *sb;
 
 377         if (priv->iucv_state == IUCV_SEVERED)
 
 380         if (priv->iucv_state == IUCV_DISCONN)
 
 383         if (!priv->sndbuf_len)
 
 386         /* allocate internal buffer to store msg data and also compute total
 
 388         sb = alloc_tty_buffer(priv->sndbuf_len, GFP_ATOMIC);
 
 392         memcpy(sb->mbuf->data, priv->sndbuf, priv->sndbuf_len);
 
 393         sb->mbuf->datalen = (u16) priv->sndbuf_len;
 
 394         sb->msg.length = MSG_SIZE(sb->mbuf->datalen);
 
 396         list_add_tail(&sb->list, &priv->tty_outqueue);
 
 398         rc = __iucv_message_send(priv->path, &sb->msg, 0, 0,
 
 399                                  (void *) sb->mbuf, sb->msg.length);
 
 401                 /* drop the message here; however we might want to handle
 
 402                  * 0x03 (msg limit reached) by trying again... */
 
 404                 destroy_tty_buffer(sb);
 
 406         len = priv->sndbuf_len;
 
 407         priv->sndbuf_len = 0;
 
 413  * hvc_iucv_sndbuf_work() - Send buffered data over IUCV
 
 414  * @work:       Work structure.
 
 416  * This work queue function sends buffered output data over IUCV and,
 
 417  * if not all buffered data could be sent, reschedules itself.
 
 419 static void hvc_iucv_sndbuf_work(struct work_struct *work)
 
 421         struct hvc_iucv_private *priv;
 
 423         priv = container_of(work, struct hvc_iucv_private, sndbuf_work.work);
 
 427         spin_lock_bh(&priv->lock);
 
 429         spin_unlock_bh(&priv->lock);
 
 433  * hvc_iucv_put_chars() - HVC put_chars operation.
 
 434  * @vtermno:    HVC virtual terminal number.
 
 435  * @buf:        Pointer to an buffer to read data from
 
 436  * @count:      Size of buffer available for reading
 
 438  * The HVC thread calls this method to write characters to the back-end.
 
 439  * The function calls hvc_iucv_queue() to queue terminal data for sending.
 
 441  * Locking:     The method gets called under an irqsave() spinlock; and
 
 442  *              locks struct hvc_iucv_private->lock.
 
 444 static int hvc_iucv_put_chars(uint32_t vtermno, const char *buf, int count)
 
 446         struct hvc_iucv_private *priv = hvc_iucv_get_private(vtermno);
 
 455         spin_lock(&priv->lock);
 
 456         queued = hvc_iucv_queue(priv, buf, count);
 
 457         spin_unlock(&priv->lock);
 
 463  * hvc_iucv_notifier_add() - HVC notifier for opening a TTY for the first time.
 
 464  * @hp: Pointer to the HVC device (struct hvc_struct)
 
 465  * @id: Additional data (originally passed to hvc_alloc): the index of an struct
 
 466  *      hvc_iucv_private instance.
 
 468  * The function sets the tty state to TTY_OPENED for the struct hvc_iucv_private
 
 469  * instance that is derived from @id. Always returns 0.
 
 471  * Locking:     struct hvc_iucv_private->lock, spin_lock_bh
 
 473 static int hvc_iucv_notifier_add(struct hvc_struct *hp, int id)
 
 475         struct hvc_iucv_private *priv;
 
 477         priv = hvc_iucv_get_private(id);
 
 481         spin_lock_bh(&priv->lock);
 
 482         priv->tty_state = TTY_OPENED;
 
 483         spin_unlock_bh(&priv->lock);
 
 489  * hvc_iucv_cleanup() - Clean up and reset a z/VM IUCV HVC instance.
 
 490  * @priv:       Pointer to the struct hvc_iucv_private instance.
 
 492 static void hvc_iucv_cleanup(struct hvc_iucv_private *priv)
 
 494         destroy_tty_buffer_list(&priv->tty_outqueue);
 
 495         destroy_tty_buffer_list(&priv->tty_inqueue);
 
 497         priv->tty_state = TTY_CLOSED;
 
 498         priv->iucv_state = IUCV_DISCONN;
 
 500         priv->sndbuf_len = 0;
 
 504  * tty_outqueue_empty() - Test if the tty outq is empty
 
 505  * @priv:       Pointer to struct hvc_iucv_private instance.
 
 507 static inline int tty_outqueue_empty(struct hvc_iucv_private *priv)
 
 511         spin_lock_bh(&priv->lock);
 
 512         rc = list_empty(&priv->tty_outqueue);
 
 513         spin_unlock_bh(&priv->lock);
 
 519  * flush_sndbuf_sync() - Flush send buffer and wait for completion
 
 520  * @priv:       Pointer to struct hvc_iucv_private instance.
 
 522  * The routine cancels a pending sndbuf work, calls hvc_iucv_send()
 
 523  * to flush any buffered terminal output data and waits for completion.
 
 525 static void flush_sndbuf_sync(struct hvc_iucv_private *priv)
 
 529         cancel_delayed_work_sync(&priv->sndbuf_work);
 
 531         spin_lock_bh(&priv->lock);
 
 532         hvc_iucv_send(priv);            /* force sending buffered data */
 
 533         sync_wait = !list_empty(&priv->tty_outqueue); /* anything queued ? */
 
 534         spin_unlock_bh(&priv->lock);
 
 537                 wait_event_timeout(priv->sndbuf_waitq,
 
 538                                    tty_outqueue_empty(priv), HZ);
 
 542  * hvc_iucv_notifier_hangup() - HVC notifier for TTY hangups.
 
 543  * @hp:         Pointer to the HVC device (struct hvc_struct)
 
 544  * @id:         Additional data (originally passed to hvc_alloc):
 
 545  *              the index of an struct hvc_iucv_private instance.
 
 547  * This routine notifies the HVC back-end that a tty hangup (carrier loss,
 
 548  * virtual or otherwise) has occured.
 
 549  * The z/VM IUCV HVC device driver ignores virtual hangups (vhangup())
 
 550  * to keep an existing IUCV communication path established.
 
 551  * (Background: vhangup() is called from user space (by getty or login) to
 
 552  *              disable writing to the tty by other applications).
 
 553  * If the tty has been opened and an established IUCV path has been severed
 
 554  * (we caused the tty hangup), the function calls hvc_iucv_cleanup().
 
 556  * Locking:     struct hvc_iucv_private->lock
 
 558 static void hvc_iucv_notifier_hangup(struct hvc_struct *hp, int id)
 
 560         struct hvc_iucv_private *priv;
 
 562         priv = hvc_iucv_get_private(id);
 
 566         flush_sndbuf_sync(priv);
 
 568         spin_lock_bh(&priv->lock);
 
 569         /* NOTE: If the hangup was scheduled by ourself (from the iucv
 
 570          *       path_servered callback [IUCV_SEVERED]), we have to clean up
 
 571          *       our structure and to set state to TTY_CLOSED.
 
 572          *       If the tty was hung up otherwise (e.g. vhangup()), then we
 
 573          *       ignore this hangup and keep an established IUCV path open...
 
 574          *       (...the reason is that we are not able to connect back to the
 
 575          *       client if we disconnect on hang up) */
 
 576         priv->tty_state = TTY_CLOSED;
 
 578         if (priv->iucv_state == IUCV_SEVERED)
 
 579                 hvc_iucv_cleanup(priv);
 
 580         spin_unlock_bh(&priv->lock);
 
 584  * hvc_iucv_notifier_del() - HVC notifier for closing a TTY for the last time.
 
 585  * @hp:         Pointer to the HVC device (struct hvc_struct)
 
 586  * @id:         Additional data (originally passed to hvc_alloc):
 
 587  *              the index of an struct hvc_iucv_private instance.
 
 589  * This routine notifies the HVC back-end that the last tty device fd has been
 
 590  * closed.  The function calls hvc_iucv_cleanup() to clean up the struct
 
 591  * hvc_iucv_private instance.
 
 593  * Locking:     struct hvc_iucv_private->lock
 
 595 static void hvc_iucv_notifier_del(struct hvc_struct *hp, int id)
 
 597         struct hvc_iucv_private *priv;
 
 598         struct iucv_path        *path;
 
 600         priv = hvc_iucv_get_private(id);
 
 604         flush_sndbuf_sync(priv);
 
 606         spin_lock_bh(&priv->lock);
 
 607         path = priv->path;              /* save reference to IUCV path */
 
 609         hvc_iucv_cleanup(priv);
 
 610         spin_unlock_bh(&priv->lock);
 
 612         /* sever IUCV path outside of priv->lock due to lock ordering of:
 
 613          * priv->lock <--> iucv_table_lock */
 
 615                 iucv_path_sever(path, NULL);
 
 616                 iucv_path_free(path);
 
 621  * hvc_iucv_path_pending() - IUCV handler to process a connection request.
 
 622  * @path:       Pending path (struct iucv_path)
 
 623  * @ipvmid:     z/VM system identifier of originator
 
 624  * @ipuser:     User specified data for this path
 
 625  *              (AF_IUCV: port/service name and originator port)
 
 627  * The function uses the @ipuser data to determine if the pending path belongs
 
 628  * to a terminal managed by this device driver.
 
 629  * If the path belongs to this driver, ensure that the terminal is not accessed
 
 630  * multiple times (only one connection to a terminal is allowed).
 
 631  * If the terminal is not yet connected, the pending path is accepted and is
 
 632  * associated to the appropriate struct hvc_iucv_private instance.
 
 634  * Returns 0 if @path belongs to a terminal managed by the this device driver;
 
 635  * otherwise returns -ENODEV in order to dispatch this path to other handlers.
 
 637  * Locking:     struct hvc_iucv_private->lock
 
 639 static  int hvc_iucv_path_pending(struct iucv_path *path,
 
 640                                   u8 ipvmid[8], u8 ipuser[16])
 
 642         struct hvc_iucv_private *priv;
 
 647         for (i = 0; i < hvc_iucv_devices; i++)
 
 648                 if (hvc_iucv_table[i] &&
 
 649                     (0 == memcmp(hvc_iucv_table[i]->srv_name, ipuser, 8))) {
 
 650                         priv = hvc_iucv_table[i];
 
 656         spin_lock(&priv->lock);
 
 658         /* If the terminal is already connected or being severed, then sever
 
 659          * this path to enforce that there is only ONE established communication
 
 660          * path per terminal. */
 
 661         if (priv->iucv_state != IUCV_DISCONN) {
 
 662                 iucv_path_sever(path, ipuser);
 
 663                 iucv_path_free(path);
 
 664                 goto out_path_handled;
 
 668         memcpy(nuser_data, ipuser + 8, 8);  /* remote service (for af_iucv) */
 
 669         memcpy(nuser_data + 8, ipuser, 8);  /* local service  (for af_iucv) */
 
 670         path->msglim = 0xffff;              /* IUCV MSGLIMIT */
 
 671         path->flags &= ~IUCV_IPRMDATA;      /* TODO: use IUCV_IPRMDATA */
 
 672         rc = iucv_path_accept(path, &hvc_iucv_handler, nuser_data, priv);
 
 674                 iucv_path_sever(path, ipuser);
 
 675                 iucv_path_free(path);
 
 676                 goto out_path_handled;
 
 679         priv->iucv_state = IUCV_CONNECTED;
 
 681         /* flush buffered output data... */
 
 682         schedule_delayed_work(&priv->sndbuf_work, 5);
 
 685         spin_unlock(&priv->lock);
 
 690  * hvc_iucv_path_severed() - IUCV handler to process a path sever.
 
 691  * @path:       Pending path (struct iucv_path)
 
 692  * @ipuser:     User specified data for this path
 
 693  *              (AF_IUCV: port/service name and originator port)
 
 695  * The function also severs the path (as required by the IUCV protocol) and
 
 696  * sets the iucv state to IUCV_SEVERED for the associated struct
 
 697  * hvc_iucv_private instance. Later, the IUCV_SEVERED state triggers a tty
 
 698  * hangup (hvc_iucv_get_chars() / hvc_iucv_write()).
 
 699  * If tty portion of the HVC is closed, clean up the outqueue.
 
 701  * Locking:     struct hvc_iucv_private->lock
 
 703 static void hvc_iucv_path_severed(struct iucv_path *path, u8 ipuser[16])
 
 705         struct hvc_iucv_private *priv = path->private;
 
 707         spin_lock(&priv->lock);
 
 708         priv->iucv_state = IUCV_SEVERED;
 
 710         /* If the tty has not yet been opened, clean up the hvc_iucv_private
 
 711          * structure to allow re-connects.
 
 712          * This is also done for our console device because console hangups
 
 713          * are handled specially and no notifier is called by HVC.
 
 714          * The tty session is active (TTY_OPEN) and ready for re-connects...
 
 716          * If it has been opened, let get_chars() return -EPIPE to signal the
 
 717          * HVC layer to hang up the tty.
 
 718          * If so, we need to wake up the HVC thread to call get_chars()...
 
 721         if (priv->tty_state == TTY_CLOSED)
 
 722                 hvc_iucv_cleanup(priv);
 
 724                 if (priv->is_console) {
 
 725                         hvc_iucv_cleanup(priv);
 
 726                         priv->tty_state = TTY_OPENED;
 
 729         spin_unlock(&priv->lock);
 
 731         /* finally sever path (outside of priv->lock due to lock ordering) */
 
 732         iucv_path_sever(path, ipuser);
 
 733         iucv_path_free(path);
 
 737  * hvc_iucv_msg_pending() - IUCV handler to process an incoming IUCV message.
 
 738  * @path:       Pending path (struct iucv_path)
 
 739  * @msg:        Pointer to the IUCV message
 
 741  * The function puts an incoming message on the input queue for later
 
 742  * processing (by hvc_iucv_get_chars() / hvc_iucv_write()).
 
 743  * If the tty has not yet been opened, the message is rejected.
 
 745  * Locking:     struct hvc_iucv_private->lock
 
 747 static void hvc_iucv_msg_pending(struct iucv_path *path,
 
 748                                  struct iucv_message *msg)
 
 750         struct hvc_iucv_private *priv = path->private;
 
 751         struct iucv_tty_buffer *rb;
 
 753         /* reject messages that exceed max size of iucv_tty_msg->datalen */
 
 754         if (msg->length > MSG_SIZE(MSG_MAX_DATALEN)) {
 
 755                 iucv_message_reject(path, msg);
 
 759         spin_lock(&priv->lock);
 
 761         /* reject messages if tty has not yet been opened */
 
 762         if (priv->tty_state == TTY_CLOSED) {
 
 763                 iucv_message_reject(path, msg);
 
 767         /* allocate tty buffer to save iucv msg only */
 
 768         rb = alloc_tty_buffer(0, GFP_ATOMIC);
 
 770                 iucv_message_reject(path, msg);
 
 771                 goto unlock_return;     /* -ENOMEM */
 
 775         list_add_tail(&rb->list, &priv->tty_inqueue);
 
 777         hvc_kick();     /* wake up hvc thread */
 
 780         spin_unlock(&priv->lock);
 
 784  * hvc_iucv_msg_complete() - IUCV handler to process message completion
 
 785  * @path:       Pending path (struct iucv_path)
 
 786  * @msg:        Pointer to the IUCV message
 
 788  * The function is called upon completion of message delivery to remove the
 
 789  * message from the outqueue. Additional delivery information can be found
 
 790  * msg->audit: rejected messages (0x040000 (IPADRJCT)), and
 
 791  *             purged messages   (0x010000 (IPADPGNR)).
 
 793  * Locking:     struct hvc_iucv_private->lock
 
 795 static void hvc_iucv_msg_complete(struct iucv_path *path,
 
 796                                   struct iucv_message *msg)
 
 798         struct hvc_iucv_private *priv = path->private;
 
 799         struct iucv_tty_buffer  *ent, *next;
 
 800         LIST_HEAD(list_remove);
 
 802         spin_lock(&priv->lock);
 
 803         list_for_each_entry_safe(ent, next, &priv->tty_outqueue, list)
 
 804                 if (ent->msg.id == msg->id) {
 
 805                         list_move(&ent->list, &list_remove);
 
 808         wake_up(&priv->sndbuf_waitq);
 
 809         spin_unlock(&priv->lock);
 
 810         destroy_tty_buffer_list(&list_remove);
 
 815 static struct hv_ops hvc_iucv_ops = {
 
 816         .get_chars = hvc_iucv_get_chars,
 
 817         .put_chars = hvc_iucv_put_chars,
 
 818         .notifier_add = hvc_iucv_notifier_add,
 
 819         .notifier_del = hvc_iucv_notifier_del,
 
 820         .notifier_hangup = hvc_iucv_notifier_hangup,
 
 824  * hvc_iucv_alloc() - Allocates a new struct hvc_iucv_private instance
 
 825  * @id:                 hvc_iucv_table index
 
 826  * @is_console:         Flag if the instance is used as Linux console
 
 828  * This function allocates a new hvc_iucv_private structure and stores
 
 829  * the instance in hvc_iucv_table at index @id.
 
 830  * Returns 0 on success; otherwise non-zero.
 
 832 static int __init hvc_iucv_alloc(int id, unsigned int is_console)
 
 834         struct hvc_iucv_private *priv;
 
 838         priv = kzalloc(sizeof(struct hvc_iucv_private), GFP_KERNEL);
 
 842         spin_lock_init(&priv->lock);
 
 843         INIT_LIST_HEAD(&priv->tty_outqueue);
 
 844         INIT_LIST_HEAD(&priv->tty_inqueue);
 
 845         INIT_DELAYED_WORK(&priv->sndbuf_work, hvc_iucv_sndbuf_work);
 
 846         init_waitqueue_head(&priv->sndbuf_waitq);
 
 848         priv->sndbuf = (void *) get_zeroed_page(GFP_KERNEL);
 
 854         /* set console flag */
 
 855         priv->is_console = is_console;
 
 857         /* finally allocate hvc */
 
 858         priv->hvc = hvc_alloc(HVC_IUCV_MAGIC + id, /*             PAGE_SIZE */
 
 859                               HVC_IUCV_MAGIC + id, &hvc_iucv_ops, 256);
 
 860         if (IS_ERR(priv->hvc)) {
 
 861                 rc = PTR_ERR(priv->hvc);
 
 862                 free_page((unsigned long) priv->sndbuf);
 
 867         /* notify HVC thread instead of using polling */
 
 868         priv->hvc->irq_requested = 1;
 
 870         /* setup iucv related information */
 
 871         snprintf(name, 9, "lnxhvc%-2d", id);
 
 872         memcpy(priv->srv_name, name, 8);
 
 873         ASCEBC(priv->srv_name, 8);
 
 875         hvc_iucv_table[id] = priv;
 
 880  * hvc_iucv_init() - z/VM IUCV HVC device driver initialization
 
 882 static int __init hvc_iucv_init(void)
 
 887         if (!MACHINE_IS_VM) {
 
 888                 pr_info("The z/VM IUCV HVC device driver cannot "
 
 889                            "be used without z/VM\n");
 
 893         if (!hvc_iucv_devices)
 
 896         if (hvc_iucv_devices > MAX_HVC_IUCV_LINES)
 
 899         hvc_iucv_buffer_cache = kmem_cache_create(KMSG_COMPONENT,
 
 900                                            sizeof(struct iucv_tty_buffer),
 
 902         if (!hvc_iucv_buffer_cache) {
 
 903                 pr_err("Allocating memory failed with reason code=%d\n", 1);
 
 907         hvc_iucv_mempool = mempool_create_slab_pool(MEMPOOL_MIN_NR,
 
 908                                                     hvc_iucv_buffer_cache);
 
 909         if (!hvc_iucv_mempool) {
 
 910                 pr_err("Allocating memory failed with reason code=%d\n", 2);
 
 911                 kmem_cache_destroy(hvc_iucv_buffer_cache);
 
 915         /* register the first terminal device as console
 
 916          * (must be done before allocating hvc terminal devices) */
 
 917         rc = hvc_instantiate(HVC_IUCV_MAGIC, IUCV_HVC_CON_IDX, &hvc_iucv_ops);
 
 919                 pr_err("Registering HVC terminal device as "
 
 920                        "Linux console failed\n");
 
 921                 goto out_error_memory;
 
 924         /* allocate hvc_iucv_private structs */
 
 925         for (i = 0; i < hvc_iucv_devices; i++) {
 
 926                 rc = hvc_iucv_alloc(i, (i == IUCV_HVC_CON_IDX) ? 1 : 0);
 
 928                         pr_err("Creating a new HVC terminal device "
 
 929                                 "failed with error code=%d\n", rc);
 
 934         /* register IUCV callback handler */
 
 935         rc = iucv_register(&hvc_iucv_handler, 0);
 
 937                 pr_err("Registering IUCV handlers failed with error code=%d\n",
 
 945         iucv_unregister(&hvc_iucv_handler, 0);
 
 947         for (i = 0; i < hvc_iucv_devices; i++)
 
 948                 if (hvc_iucv_table[i]) {
 
 949                         if (hvc_iucv_table[i]->hvc)
 
 950                                 hvc_remove(hvc_iucv_table[i]->hvc);
 
 951                         kfree(hvc_iucv_table[i]);
 
 954         mempool_destroy(hvc_iucv_mempool);
 
 955         kmem_cache_destroy(hvc_iucv_buffer_cache);
 
 960  * hvc_iucv_config() - Parsing of hvc_iucv=  kernel command line parameter
 
 961  * @val:        Parameter value (numeric)
 
 963 static  int __init hvc_iucv_config(char *val)
 
 965          return strict_strtoul(val, 10, &hvc_iucv_devices);
 
 969 device_initcall(hvc_iucv_init);
 
 970 __setup("hvc_iucv=", hvc_iucv_config);