/linux/drivers/s390/char/ |
H A D | sclp_early.c | 29 struct read_info_sccb *sccb; in sclp_early_facilities_detect() local 32 sccb = sclp_early_get_info(); in sclp_early_facilities_detect() 33 if (!sccb) in sclp_early_facilities_detect() 36 sclp.facilities = sccb->facilities; in sclp_early_facilities_detect() 37 sclp.has_sprp = !!(sccb->fac84 & 0x02); in sclp_early_facilities_detect() 38 sclp.has_core_type = !!(sccb->fac84 & 0x01); in sclp_early_facilities_detect() 39 sclp.has_gsls = !!(sccb->fac85 & 0x80); in sclp_early_facilities_detect() 40 sclp.has_64bscao = !!(sccb->fac116 & 0x80); in sclp_early_facilities_detect() 41 sclp.has_cmma = !!(sccb->fac116 & 0x40); in sclp_early_facilities_detect() 42 sclp.has_esca = !!(sccb->fac116 & 0x08); in sclp_early_facilities_detect() [all …]
|
H A D | sclp_early_core.c | 65 int sclp_early_cmd(sclp_cmdw_t cmd, void *sccb) in sclp_early_cmd() argument 71 rc = sclp_service_call(cmd, sccb); in sclp_early_cmd() 90 struct write_sccb *sccb; in sclp_early_print_lm() local 96 sccb = (struct write_sccb *) sclp_early_sccb; in sclp_early_print_lm() 97 end = (unsigned char *) sccb + EARLY_SCCB_SIZE - 1; in sclp_early_print_lm() 98 memset(sccb, 0, sizeof(*sccb)); in sclp_early_print_lm() 99 ptr = (unsigned char *) &sccb->msg.mdb.mto; in sclp_early_print_lm() 115 len = ptr - (unsigned char *) sccb; in sclp_early_print_lm() 116 sccb->header.length = len - offsetof(struct write_sccb, header); in sclp_early_print_lm() 117 msg = &sccb->msg; in sclp_early_print_lm() [all …]
|
H A D | sclp_cmd.c | 44 int sclp_sync_request(sclp_cmdw_t cmd, void *sccb) in sclp_sync_request() argument 46 return sclp_sync_request_timeout(cmd, sccb, 0); in sclp_sync_request() 49 int sclp_sync_request_timeout(sclp_cmdw_t cmd, void *sccb, int timeout) in sclp_sync_request_timeout() argument 61 request->sccb = sccb; in sclp_sync_request_timeout() 95 struct read_cpu_info_sccb *sccb; in _sclp_get_core_info() local 100 sccb = (void *)__get_free_pages(GFP_KERNEL | GFP_DMA | __GFP_ZERO, get_order(length)); in _sclp_get_core_info() 101 if (!sccb) in _sclp_get_core_info() 103 sccb->header.length = length; in _sclp_get_core_info() 104 sccb->header.control_mask[2] = 0x80; in _sclp_get_core_info() 105 rc = sclp_sync_request_timeout(SCLP_CMDW_READ_CPU_INFO, sccb, in _sclp_get_core_info() [all …]
|
H A D | sclp_sdias.c | 61 struct sdias_sccb *sccb = sclp_sdias_sccb; in sdias_sclp_send() local 82 if (!(sccb->evbuf.hdr.flags & 0x80)) { in sdias_sclp_send() 84 sccb->evbuf.hdr.flags); in sdias_sclp_send() 91 memcpy(&sdias_evbuf, &sccb->evbuf, sizeof(sdias_evbuf)); in sdias_sclp_send() 108 struct sdias_sccb *sccb = sclp_sdias_sccb; in sclp_sdias_blk_count() local 114 memset(sccb, 0, sizeof(*sccb)); in sclp_sdias_blk_count() 117 sccb->hdr.length = sizeof(*sccb); in sclp_sdias_blk_count() 118 sccb->evbuf.hdr.length = sizeof(struct sdias_evbuf); in sclp_sdias_blk_count() 119 sccb->evbuf.hdr.type = EVTYP_SDIAS; in sclp_sdias_blk_count() 120 sccb->evbuf.event_qual = SDIAS_EQ_SIZE; in sclp_sdias_blk_count() [all …]
|
H A D | sclp_ftp.c | 43 req->sccb, 24, req->sccb); in sclp_ftp_txcb() 91 struct sclp_diag_sccb *sccb; in sclp_ftp_et7() local 97 sccb = (void *) get_zeroed_page(GFP_KERNEL | GFP_DMA); in sclp_ftp_et7() 98 if (!req || !sccb) { in sclp_ftp_et7() 103 sccb->hdr.length = SCLP_DIAG_FTP_EVBUF_LEN + in sclp_ftp_et7() 105 sccb->evbuf.hdr.type = EVTYP_DIAG_TEST; in sclp_ftp_et7() 106 sccb->evbuf.hdr.length = SCLP_DIAG_FTP_EVBUF_LEN; in sclp_ftp_et7() 107 sccb->evbuf.hdr.flags = 0; /* clear processed-buffer */ in sclp_ftp_et7() 108 sccb->evbuf.route = SCLP_DIAG_FTP_ROUTE; in sclp_ftp_et7() 109 sccb->evbuf.mdd.ftp.pcx = SCLP_DIAG_FTP_XPCX; in sclp_ftp_et7() [all …]
|
H A D | sclp_rw.c | 44 struct sccb_header *sccb; in sclp_make_buffer() local 46 sccb = (struct sccb_header *) page; in sclp_make_buffer() 51 buffer = ((struct sclp_buffer *) ((addr_t) sccb + PAGE_SIZE)) - 1; in sclp_make_buffer() 52 buffer->sccb = sccb; in sclp_make_buffer() 62 memset(sccb, 0, sizeof(struct sccb_header)); in sclp_make_buffer() 63 sccb->length = sizeof(struct sccb_header); in sclp_make_buffer() 75 return buffer->sccb; in sclp_unmake_buffer() 85 struct sccb_header *sccb; in sclp_initialize_mto() local 96 sccb = buffer->sccb; in sclp_initialize_mto() 97 if ((MAX_SCCB_ROOM - sccb->length) < msg_size) in sclp_initialize_mto() [all …]
|
H A D | sclp.c | 110 static inline int abbrev_len(sclp_cmdw_t cmd, struct sccb_header *sccb) in abbrev_len() argument 112 struct evbuf_header *evbuf = (struct evbuf_header *)(sccb + 1); in abbrev_len() 113 int len = sccb->length, limit = SCLP_TRACE_MAX_SIZE; in abbrev_len() 128 sclp_cmdw_t cmd, struct sccb_header *sccb, in sclp_trace_sccb() argument 132 if (sccb) { in sclp_trace_sccb() 133 sclp_trace_bin(prio + 1, sccb, abbrev_len(cmd, sccb), in sclp_trace_sccb() 134 err ? sccb->length : 0); in sclp_trace_sccb() 150 struct sccb_header *sccb = req->sccb; in sclp_trace_req() local 162 summary.response = sccb ? sccb->response_code : 0; in sclp_trace_req() 166 sclp_trace(prio, id, __pa(sccb), summary.b, err); in sclp_trace_req() [all …]
|
H A D | sclp_vt220.c | 123 page = request->sclp_req.sccb; in sclp_vt220_process_queue() 155 struct sclp_vt220_sccb *sccb; in sclp_vt220_callback() local 162 sccb = (struct sclp_vt220_sccb *) vt220_request->sclp_req.sccb; in sclp_vt220_callback() 165 switch (sccb->header.response_code) { in sclp_vt220_callback() 176 if (sclp_remove_processed((struct sccb_header *) sccb) > 0) { in sclp_vt220_callback() 178 sccb->header.response_code = 0x0000; in sclp_vt220_callback() 188 sccb->header.response_code = 0x0000; in sclp_vt220_callback() 223 struct sclp_vt220_sccb *sccb; in sclp_vt220_emit_current() local 227 sccb = (struct sclp_vt220_sccb *) in sclp_vt220_emit_current() 228 sclp_vt220_current_request->sclp_req.sccb; in sclp_vt220_emit_current() [all …]
|
H A D | sclp_ctl.c | 58 struct sccb_header *sccb; in sclp_ctl_ioctl_sccb() local 66 sccb = (void *) get_zeroed_page(GFP_KERNEL | GFP_DMA); in sclp_ctl_ioctl_sccb() 67 if (!sccb) in sclp_ctl_ioctl_sccb() 70 copy_from_user(sccb, u64_to_uptr(ctl_sccb.sccb), PAGE_SIZE); in sclp_ctl_ioctl_sccb() 72 sizeof(sccb->length) > copied || sccb->length > copied) { in sclp_ctl_ioctl_sccb() 76 if (sccb->length < 8) { in sclp_ctl_ioctl_sccb() 80 rc = sclp_sync_request(ctl_sccb.cmdw, sccb); in sclp_ctl_ioctl_sccb() 83 if (copy_to_user(u64_to_uptr(ctl_sccb.sccb), sccb, sccb->length)) in sclp_ctl_ioctl_sccb() 86 free_page((unsigned long) sccb); in sclp_ctl_ioctl_sccb()
|
H A D | sclp_ap.c | 24 struct ap_cfg_sccb *sccb; in do_ap_configure() local 30 sccb = (struct ap_cfg_sccb *) get_zeroed_page(GFP_KERNEL | GFP_DMA); in do_ap_configure() 31 if (!sccb) in do_ap_configure() 34 sccb->header.length = PAGE_SIZE; in do_ap_configure() 36 rc = sclp_sync_request(cmd, sccb); in do_ap_configure() 39 switch (sccb->header.response_code) { in do_ap_configure() 44 apid, cmd, sccb->header.response_code); in do_ap_configure() 49 free_page((unsigned long) sccb); in do_ap_configure()
|
H A D | sclp_config.c | 95 struct sclp_ofb_sccb *sccb; in sclp_ofb_send_req() local 100 sccb = (struct sclp_ofb_sccb *) get_zeroed_page(GFP_KERNEL | GFP_DMA); in sclp_ofb_send_req() 101 if (!sccb) in sclp_ofb_send_req() 104 sccb->header.length = sizeof(struct sclp_ofb_sccb); in sclp_ofb_send_req() 105 sccb->ofb_evbuf.header.length = sizeof(struct sclp_ofb_evbuf); in sclp_ofb_send_req() 106 sccb->ofb_evbuf.header.type = EVTYP_CONFMGMDATA; in sclp_ofb_send_req() 107 sccb->ofb_evbuf.cm_data.ev_qualifier = EV_QUAL_OPEN4BUSINESS; in sclp_ofb_send_req() 108 memcpy(sccb->ofb_evbuf.ev_data, ev_data, len); in sclp_ofb_send_req() 115 rc = sclp_sync_request(SCLP_CMDW_WRITE_EVENT_DATA, sccb); in sclp_ofb_send_req() 119 response = sccb->header.response_code; in sclp_ofb_send_req() [all …]
|
H A D | sclp_sd.c | 195 struct sclp_sd_sccb *sccb = (void *) page; in sclp_sd_sync() local 204 sclp_sd_listener_init(&listener, __pa(sccb)); in sclp_sd_sync() 208 memset(sccb, 0, PAGE_SIZE); in sclp_sd_sync() 209 sccb->hdr.length = sizeof(sccb->hdr) + sizeof(sccb->evbuf); in sclp_sd_sync() 210 evbuf = &sccb->evbuf; in sclp_sd_sync() 224 rc = sclp_sync_request(SCLP_CMDW_WRITE_EVENT_DATA, sccb); in sclp_sd_sync() 230 if (sccb->hdr.response_code == 0x73f0) { in sclp_sd_sync() 235 if (sccb->hdr.response_code != 0x0020 || !(evbuf->hdr.flags & 0x80)) { in sclp_sd_sync() 271 eq, di, sccb->hdr.response_code, evbuf->hdr.flags, in sclp_sd_sync()
|
H A D | sclp_rw.h | 68 void *sccb; member
|
/linux/drivers/scsi/ |
H A D | FlashPoint.c | 28 struct sccb; 29 typedef void (*CALL_BK_FN) (struct sccb *); 74 struct sccb { struct 108 struct sccb *Sccb_forwardlink; argument 109 struct sccb *Sccb_backlink; argument 212 struct sccb *TarSelQ_Head; 213 struct sccb *TarSelQ_Tail; 249 struct sccb *currentSCCB; 262 struct sccb *discQ_Tbl[QUEUE_DEPTH]; 767 struct sccb *pCurrSCCB); [all …]
|
/linux/arch/s390/include/uapi/asm/ |
H A D | sclp_ctl.h | 17 __u64 sccb; member
|
/linux/drivers/base/regmap/ |
H A D | Makefile | 20 obj-$(CONFIG_REGMAP_SCCB) += regmap-sccb.o
|
/linux/arch/s390/include/asm/ |
H A D | sclp.h | 130 void sclp_early_set_buffer(void *sccb);
|