123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209 |
- /* SPDX-License-Identifier: GPL-2.0+ */
- /*
- * linux/drivers/misc/ibmvmc.h
- *
- * IBM Power Systems Virtual Management Channel Support.
- *
- * Copyright (c) 2004, 2018 IBM Corp.
- * Dave Engebretsen [email protected]
- * Steven Royer [email protected]
- * Adam Reznechek [email protected]
- * Bryant G. Ly <[email protected]>
- */
- #ifndef IBMVMC_H
- #define IBMVMC_H
- #include <linux/types.h>
- #include <linux/cdev.h>
- #include <asm/vio.h>
- #define IBMVMC_PROTOCOL_VERSION 0x0101
- #define MIN_BUF_POOL_SIZE 16
- #define MIN_HMCS 1
- #define MIN_MTU 4096
- #define MAX_BUF_POOL_SIZE 64
- #define MAX_HMCS 2
- #define MAX_MTU (4 * 4096)
- #define DEFAULT_BUF_POOL_SIZE 32
- #define DEFAULT_HMCS 1
- #define DEFAULT_MTU 4096
- #define HMC_ID_LEN 32
- #define VMC_INVALID_BUFFER_ID 0xFFFF
- /* ioctl numbers */
- #define VMC_BASE 0xCC
- #define VMC_IOCTL_SETHMCID _IOW(VMC_BASE, 0x00, unsigned char *)
- #define VMC_IOCTL_QUERY _IOR(VMC_BASE, 0x01, struct ibmvmc_query_struct)
- #define VMC_IOCTL_REQUESTVMC _IOR(VMC_BASE, 0x02, u32)
- #define VMC_MSG_CAP 0x01
- #define VMC_MSG_CAP_RESP 0x81
- #define VMC_MSG_OPEN 0x02
- #define VMC_MSG_OPEN_RESP 0x82
- #define VMC_MSG_CLOSE 0x03
- #define VMC_MSG_CLOSE_RESP 0x83
- #define VMC_MSG_ADD_BUF 0x04
- #define VMC_MSG_ADD_BUF_RESP 0x84
- #define VMC_MSG_REM_BUF 0x05
- #define VMC_MSG_REM_BUF_RESP 0x85
- #define VMC_MSG_SIGNAL 0x06
- #define VMC_MSG_SUCCESS 0
- #define VMC_MSG_INVALID_HMC_INDEX 1
- #define VMC_MSG_INVALID_BUFFER_ID 2
- #define VMC_MSG_CLOSED_HMC 3
- #define VMC_MSG_INTERFACE_FAILURE 4
- #define VMC_MSG_NO_BUFFER 5
- #define VMC_BUF_OWNER_ALPHA 0
- #define VMC_BUF_OWNER_HV 1
- enum ibmvmc_states {
- ibmvmc_state_sched_reset = -1,
- ibmvmc_state_initial = 0,
- ibmvmc_state_crqinit = 1,
- ibmvmc_state_capabilities = 2,
- ibmvmc_state_ready = 3,
- ibmvmc_state_failed = 4,
- };
- enum ibmhmc_states {
- /* HMC connection not established */
- ibmhmc_state_free = 0,
- /* HMC connection established (open called) */
- ibmhmc_state_initial = 1,
- /* open msg sent to HV, due to ioctl(1) call */
- ibmhmc_state_opening = 2,
- /* HMC connection ready, open resp msg from HV */
- ibmhmc_state_ready = 3,
- /* HMC connection failure */
- ibmhmc_state_failed = 4,
- };
- struct ibmvmc_buffer {
- u8 valid; /* 1 when DMA storage allocated to buffer */
- u8 free; /* 1 when buffer available for the Alpha Partition */
- u8 owner;
- u16 id;
- u32 size;
- u32 msg_len;
- dma_addr_t dma_addr_local;
- dma_addr_t dma_addr_remote;
- void *real_addr_local;
- };
- struct ibmvmc_admin_crq_msg {
- u8 valid; /* RPA Defined */
- u8 type; /* ibmvmc msg type */
- u8 status; /* Response msg status. Zero is success and on failure,
- * either 1 - General Failure, or 2 - Invalid Version is
- * returned.
- */
- u8 rsvd[2];
- u8 max_hmc; /* Max # of independent HMC connections supported */
- __be16 pool_size; /* Maximum number of buffers supported per HMC
- * connection
- */
- __be32 max_mtu; /* Maximum message size supported (bytes) */
- __be16 crq_size; /* # of entries available in the CRQ for the
- * source partition. The target partition must
- * limit the number of outstanding messages to
- * one half or less.
- */
- __be16 version; /* Indicates the code level of the management partition
- * or the hypervisor with the high-order byte
- * indicating a major version and the low-order byte
- * indicating a minor version.
- */
- };
- struct ibmvmc_crq_msg {
- u8 valid; /* RPA Defined */
- u8 type; /* ibmvmc msg type */
- u8 status; /* Response msg status */
- union {
- u8 rsvd; /* Reserved */
- u8 owner;
- } var1;
- u8 hmc_session; /* Session Identifier for the current VMC connection */
- u8 hmc_index; /* A unique HMC Idx would be used if multiple management
- * applications running concurrently were desired
- */
- union {
- __be16 rsvd;
- __be16 buffer_id;
- } var2;
- __be32 rsvd;
- union {
- __be32 rsvd;
- __be32 lioba;
- __be32 msg_len;
- } var3;
- };
- /* an RPA command/response transport queue */
- struct crq_queue {
- struct ibmvmc_crq_msg *msgs;
- int size, cur;
- dma_addr_t msg_token;
- spinlock_t lock;
- };
- /* VMC server adapter settings */
- struct crq_server_adapter {
- struct device *dev;
- struct crq_queue queue;
- u32 liobn;
- u32 riobn;
- struct tasklet_struct work_task;
- wait_queue_head_t reset_wait_queue;
- struct task_struct *reset_task;
- };
- /* Driver wide settings */
- struct ibmvmc_struct {
- u32 state;
- u32 max_mtu;
- u32 max_buffer_pool_size;
- u32 max_hmc_index;
- struct crq_server_adapter *adapter;
- struct cdev cdev;
- u32 vmc_drc_index;
- };
- struct ibmvmc_file_session;
- /* Connection specific settings */
- struct ibmvmc_hmc {
- u8 session;
- u8 index;
- u32 state;
- struct crq_server_adapter *adapter;
- spinlock_t lock;
- unsigned char hmc_id[HMC_ID_LEN];
- struct ibmvmc_buffer buffer[MAX_BUF_POOL_SIZE];
- unsigned short queue_outbound_msgs[MAX_BUF_POOL_SIZE];
- int queue_head, queue_tail;
- struct ibmvmc_file_session *file_session;
- };
- struct ibmvmc_file_session {
- struct file *file;
- struct ibmvmc_hmc *hmc;
- bool valid;
- };
- struct ibmvmc_query_struct {
- int have_vmc;
- int state;
- int vmc_drc_index;
- };
- #endif /* __IBMVMC_H */
|