a11e1d432b
The poll() changes were not well thought out, and completely unexplained. They also caused a huge performance regression, because "->poll()" was no longer a trivial file operation that just called down to the underlying file operations, but instead did at least two indirect calls. Indirect calls are sadly slow now with the Spectre mitigation, but the performance problem could at least be largely mitigated by changing the "->get_poll_head()" operation to just have a per-file-descriptor pointer to the poll head instead. That gets rid of one of the new indirections. But that doesn't fix the new complexity that is completely unwarranted for the regular case. The (undocumented) reason for the poll() changes was some alleged AIO poll race fixing, but we don't make the common case slower and more complex for some uncommon special case, so this all really needs way more explanations and most likely a fundamental redesign. [ This revert is a revert of about 30 different commits, not reverted individually because that would just be unnecessarily messy - Linus ] Cc: Al Viro <viro@zeniv.linux.org.uk> Cc: Christoph Hellwig <hch@lst.de> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
165 lines
4.1 KiB
C
165 lines
4.1 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Copyright 2006 IBM Corporation
|
|
* IUCV protocol stack for Linux on zSeries
|
|
* Version 1.0
|
|
* Author(s): Jennifer Hunt <jenhunt@us.ibm.com>
|
|
*
|
|
*/
|
|
|
|
#ifndef __AFIUCV_H
|
|
#define __AFIUCV_H
|
|
|
|
#include <asm/types.h>
|
|
#include <asm/byteorder.h>
|
|
#include <linux/list.h>
|
|
#include <linux/poll.h>
|
|
#include <linux/socket.h>
|
|
#include <net/iucv/iucv.h>
|
|
|
|
#ifndef AF_IUCV
|
|
#define AF_IUCV 32
|
|
#define PF_IUCV AF_IUCV
|
|
#endif
|
|
|
|
/* Connection and socket states */
|
|
enum {
|
|
IUCV_CONNECTED = 1,
|
|
IUCV_OPEN,
|
|
IUCV_BOUND,
|
|
IUCV_LISTEN,
|
|
IUCV_DISCONN,
|
|
IUCV_CLOSING,
|
|
IUCV_CLOSED
|
|
};
|
|
|
|
#define IUCV_QUEUELEN_DEFAULT 65535
|
|
#define IUCV_HIPER_MSGLIM_DEFAULT 128
|
|
#define IUCV_CONN_TIMEOUT (HZ * 40)
|
|
#define IUCV_DISCONN_TIMEOUT (HZ * 2)
|
|
#define IUCV_CONN_IDLE_TIMEOUT (HZ * 60)
|
|
#define IUCV_BUFSIZE_DEFAULT 32768
|
|
|
|
/* IUCV socket address */
|
|
struct sockaddr_iucv {
|
|
sa_family_t siucv_family;
|
|
unsigned short siucv_port; /* Reserved */
|
|
unsigned int siucv_addr; /* Reserved */
|
|
char siucv_nodeid[8]; /* Reserved */
|
|
char siucv_user_id[8]; /* Guest User Id */
|
|
char siucv_name[8]; /* Application Name */
|
|
};
|
|
|
|
|
|
/* Common socket structures and functions */
|
|
struct sock_msg_q {
|
|
struct iucv_path *path;
|
|
struct iucv_message msg;
|
|
struct list_head list;
|
|
spinlock_t lock;
|
|
};
|
|
|
|
#define AF_IUCV_FLAG_ACK 0x1
|
|
#define AF_IUCV_FLAG_SYN 0x2
|
|
#define AF_IUCV_FLAG_FIN 0x4
|
|
#define AF_IUCV_FLAG_WIN 0x8
|
|
#define AF_IUCV_FLAG_SHT 0x10
|
|
|
|
struct af_iucv_trans_hdr {
|
|
u16 magic;
|
|
u8 version;
|
|
u8 flags;
|
|
u16 window;
|
|
char destNodeID[8];
|
|
char destUserID[8];
|
|
char destAppName[16];
|
|
char srcNodeID[8];
|
|
char srcUserID[8];
|
|
char srcAppName[16]; /* => 70 bytes */
|
|
struct iucv_message iucv_hdr; /* => 33 bytes */
|
|
u8 pad; /* total 104 bytes */
|
|
} __packed;
|
|
|
|
enum iucv_tx_notify {
|
|
/* transmission of skb is completed and was successful */
|
|
TX_NOTIFY_OK = 0,
|
|
/* target is unreachable */
|
|
TX_NOTIFY_UNREACHABLE = 1,
|
|
/* transfer pending queue full */
|
|
TX_NOTIFY_TPQFULL = 2,
|
|
/* general error */
|
|
TX_NOTIFY_GENERALERROR = 3,
|
|
/* transmission of skb is pending - may interleave
|
|
* with TX_NOTIFY_DELAYED_* */
|
|
TX_NOTIFY_PENDING = 4,
|
|
/* transmission of skb was done successfully (delayed) */
|
|
TX_NOTIFY_DELAYED_OK = 5,
|
|
/* target unreachable (detected delayed) */
|
|
TX_NOTIFY_DELAYED_UNREACHABLE = 6,
|
|
/* general error (detected delayed) */
|
|
TX_NOTIFY_DELAYED_GENERALERROR = 7,
|
|
};
|
|
|
|
#define iucv_sk(__sk) ((struct iucv_sock *) __sk)
|
|
|
|
#define AF_IUCV_TRANS_IUCV 0
|
|
#define AF_IUCV_TRANS_HIPER 1
|
|
|
|
struct iucv_sock {
|
|
struct sock sk;
|
|
char src_user_id[8];
|
|
char src_name[8];
|
|
char dst_user_id[8];
|
|
char dst_name[8];
|
|
struct list_head accept_q;
|
|
spinlock_t accept_q_lock;
|
|
struct sock *parent;
|
|
struct iucv_path *path;
|
|
struct net_device *hs_dev;
|
|
struct sk_buff_head send_skb_q;
|
|
struct sk_buff_head backlog_skb_q;
|
|
struct sock_msg_q message_q;
|
|
unsigned int send_tag;
|
|
u8 flags;
|
|
u16 msglimit;
|
|
u16 msglimit_peer;
|
|
atomic_t msg_sent;
|
|
atomic_t msg_recv;
|
|
atomic_t pendings;
|
|
int transport;
|
|
void (*sk_txnotify)(struct sk_buff *skb,
|
|
enum iucv_tx_notify n);
|
|
};
|
|
|
|
struct iucv_skb_cb {
|
|
u32 class; /* target class of message */
|
|
u32 tag; /* tag associated with message */
|
|
u32 offset; /* offset for skb receival */
|
|
};
|
|
|
|
#define IUCV_SKB_CB(__skb) ((struct iucv_skb_cb *)&((__skb)->cb[0]))
|
|
|
|
/* iucv socket options (SOL_IUCV) */
|
|
#define SO_IPRMDATA_MSG 0x0080 /* send/recv IPRM_DATA msgs */
|
|
#define SO_MSGLIMIT 0x1000 /* get/set IUCV MSGLIMIT */
|
|
#define SO_MSGSIZE 0x0800 /* get maximum msgsize */
|
|
|
|
/* iucv related control messages (scm) */
|
|
#define SCM_IUCV_TRGCLS 0x0001 /* target class control message */
|
|
|
|
struct iucv_sock_list {
|
|
struct hlist_head head;
|
|
rwlock_t lock;
|
|
atomic_t autobind_name;
|
|
};
|
|
|
|
__poll_t iucv_sock_poll(struct file *file, struct socket *sock,
|
|
poll_table *wait);
|
|
void iucv_sock_link(struct iucv_sock_list *l, struct sock *s);
|
|
void iucv_sock_unlink(struct iucv_sock_list *l, struct sock *s);
|
|
void iucv_accept_enqueue(struct sock *parent, struct sock *sk);
|
|
void iucv_accept_unlink(struct sock *sk);
|
|
struct sock *iucv_accept_dequeue(struct sock *parent, struct socket *newsock);
|
|
|
|
#endif /* __IUCV_H */
|