| /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */ |
| /* |
| * ioctl interface for /dev/chsc |
| * |
| * Copyright IBM Corp. 2008, 2012 |
| * Author(s): Cornelia Huck <cornelia.huck@de.ibm.com> |
| */ |
| |
| #ifndef _ASM_CHSC_H |
| #define _ASM_CHSC_H |
| |
| #include <linux/types.h> |
| #include <linux/ioctl.h> |
| #include <asm/chpid.h> |
| #include <asm/schid.h> |
| |
| #define CHSC_SIZE 0x1000 |
| |
| struct chsc_async_header { |
| __u16 length; |
| __u16 code; |
| __u32 cmd_dependend; |
| __u32 key : 4; |
| __u32 : 28; |
| struct subchannel_id sid; |
| }; |
| |
| struct chsc_async_area { |
| struct chsc_async_header header; |
| __u8 data[CHSC_SIZE - sizeof(struct chsc_async_header)]; |
| }; |
| |
| struct chsc_header { |
| __u16 length; |
| __u16 code; |
| }; |
| |
| struct chsc_sync_area { |
| struct chsc_header header; |
| __u8 data[CHSC_SIZE - sizeof(struct chsc_header)]; |
| }; |
| |
| struct chsc_response_struct { |
| __u16 length; |
| __u16 code; |
| __u32 parms; |
| __u8 data[CHSC_SIZE - 2 * sizeof(__u16) - sizeof(__u32)]; |
| }; |
| |
| struct chsc_chp_cd { |
| struct chp_id chpid; |
| int m; |
| int fmt; |
| struct chsc_response_struct cpcb; |
| }; |
| |
| struct chsc_cu_cd { |
| __u16 cun; |
| __u8 cssid; |
| int m; |
| int fmt; |
| struct chsc_response_struct cucb; |
| }; |
| |
| struct chsc_sch_cud { |
| struct subchannel_id schid; |
| int fmt; |
| struct chsc_response_struct scub; |
| }; |
| |
| struct conf_id { |
| int m; |
| __u8 cssid; |
| __u8 ssid; |
| }; |
| |
| struct chsc_conf_info { |
| struct conf_id id; |
| int fmt; |
| struct chsc_response_struct scid; |
| }; |
| |
| struct ccl_parm_chpid { |
| int m; |
| struct chp_id chp; |
| }; |
| |
| struct ccl_parm_cssids { |
| __u8 f_cssid; |
| __u8 l_cssid; |
| }; |
| |
| struct chsc_comp_list { |
| struct { |
| enum { |
| CCL_CU_ON_CHP = 1, |
| CCL_CHP_TYPE_CAP = 2, |
| CCL_CSS_IMG = 4, |
| CCL_CSS_IMG_CONF_CHAR = 5, |
| CCL_IOP_CHP = 6, |
| } ctype; |
| int fmt; |
| struct ccl_parm_chpid chpid; |
| struct ccl_parm_cssids cssids; |
| } req; |
| struct chsc_response_struct sccl; |
| }; |
| |
| struct chsc_dcal { |
| struct { |
| enum { |
| DCAL_CSS_IID_PN = 4, |
| } atype; |
| __u32 list_parm[2]; |
| int fmt; |
| } req; |
| struct chsc_response_struct sdcal; |
| }; |
| |
| struct chsc_cpd_info { |
| struct chp_id chpid; |
| int m; |
| int fmt; |
| int rfmt; |
| int c; |
| struct chsc_response_struct chpdb; |
| }; |
| |
| #define CHSC_IOCTL_MAGIC 'c' |
| |
| #define CHSC_START _IOWR(CHSC_IOCTL_MAGIC, 0x81, struct chsc_async_area) |
| #define CHSC_INFO_CHANNEL_PATH _IOWR(CHSC_IOCTL_MAGIC, 0x82, \ |
| struct chsc_chp_cd) |
| #define CHSC_INFO_CU _IOWR(CHSC_IOCTL_MAGIC, 0x83, struct chsc_cu_cd) |
| #define CHSC_INFO_SCH_CU _IOWR(CHSC_IOCTL_MAGIC, 0x84, struct chsc_sch_cud) |
| #define CHSC_INFO_CI _IOWR(CHSC_IOCTL_MAGIC, 0x85, struct chsc_conf_info) |
| #define CHSC_INFO_CCL _IOWR(CHSC_IOCTL_MAGIC, 0x86, struct chsc_comp_list) |
| #define CHSC_INFO_CPD _IOWR(CHSC_IOCTL_MAGIC, 0x87, struct chsc_cpd_info) |
| #define CHSC_INFO_DCAL _IOWR(CHSC_IOCTL_MAGIC, 0x88, struct chsc_dcal) |
| #define CHSC_START_SYNC _IOWR(CHSC_IOCTL_MAGIC, 0x89, struct chsc_sync_area) |
| #define CHSC_ON_CLOSE_SET _IOWR(CHSC_IOCTL_MAGIC, 0x8a, struct chsc_async_area) |
| #define CHSC_ON_CLOSE_REMOVE _IO(CHSC_IOCTL_MAGIC, 0x8b) |
| |
| #endif |