/linux/drivers/infiniband/hw/hfi1/ |
H A D | init.c | 88 struct hfi1_ctxtdata *rcd; in hfi1_create_kctxt() local 94 ret = hfi1_create_ctxtdata(ppd, dd->node, &rcd); in hfi1_create_kctxt() 105 rcd->flags = HFI1_CAP_KGET(MULTI_PKT_EGR) | in hfi1_create_kctxt() 111 if (rcd->ctxt == HFI1_CTRL_CTXT) in hfi1_create_kctxt() 112 rcd->flags |= HFI1_CAP_DMA_RTAIL; in hfi1_create_kctxt() 113 rcd->fast_handler = get_dma_rtail_setting(rcd) ? in hfi1_create_kctxt() 117 hfi1_set_seq_cnt(rcd, 1); in hfi1_create_kctxt() 119 rcd->sc = sc_alloc(dd, SC_ACK, rcd->rcvhdrqentsize, dd->node); in hfi1_create_kctxt() 120 if (!rcd->sc) { in hfi1_create_kctxt() 124 hfi1_init_ctxt(rcd->sc); in hfi1_create_kctxt() [all …]
|
H A D | aspm.c | 129 void __aspm_ctx_disable(struct hfi1_ctxtdata *rcd) in __aspm_ctx_disable() argument 136 spin_lock_irqsave(&rcd->aspm_lock, flags); in __aspm_ctx_disable() 138 if (!rcd->aspm_intr_enable) in __aspm_ctx_disable() 141 prev = rcd->aspm_ts_last_intr; in __aspm_ctx_disable() 143 rcd->aspm_ts_last_intr = now; in __aspm_ctx_disable() 149 restart_timer = ktime_to_ns(ktime_sub(now, rcd->aspm_ts_timer_sched)) > in __aspm_ctx_disable() 154 if (rcd->aspm_enabled && close_interrupts) { in __aspm_ctx_disable() 155 aspm_disable_inc(rcd->dd); in __aspm_ctx_disable() 156 rcd->aspm_enabled = false; in __aspm_ctx_disable() 161 mod_timer(&rcd->aspm_timer, in __aspm_ctx_disable() [all …]
|
H A D | driver.c | 156 static inline void *get_egrbuf(const struct hfi1_ctxtdata *rcd, u64 rhf, in get_egrbuf() argument 161 *update |= !(idx & (rcd->egrbufs.threshold - 1)) && !offset; in get_egrbuf() 162 return (void *)(((u64)(rcd->egrbufs.rcvtids[idx].addr)) + in get_egrbuf() 166 static inline void *hfi1_get_header(struct hfi1_ctxtdata *rcd, in hfi1_get_header() argument 171 return (void *)(rhf_addr - rcd->rhf_offset + offset); in hfi1_get_header() 174 static inline struct ib_header *hfi1_get_msgheader(struct hfi1_ctxtdata *rcd, in hfi1_get_msgheader() argument 177 return (struct ib_header *)hfi1_get_header(rcd, rhf_addr); in hfi1_get_msgheader() 181 *hfi1_get_16B_header(struct hfi1_ctxtdata *rcd, in hfi1_get_16B_header() argument 184 return (struct hfi1_16b_header *)hfi1_get_header(rcd, rhf_addr); in hfi1_get_16B_header() 207 static void rcv_hdrerr(struct hfi1_ctxtdata *rcd, struct hfi1_pportdata *ppd, in rcv_hdrerr() argument [all …]
|
H A D | exp_rcv.c | 23 void hfi1_exp_tid_group_init(struct hfi1_ctxtdata *rcd) in hfi1_exp_tid_group_init() argument 25 hfi1_exp_tid_set_init(&rcd->tid_group_list); in hfi1_exp_tid_group_init() 26 hfi1_exp_tid_set_init(&rcd->tid_used_list); in hfi1_exp_tid_group_init() 27 hfi1_exp_tid_set_init(&rcd->tid_full_list); in hfi1_exp_tid_group_init() 34 int hfi1_alloc_ctxt_rcv_groups(struct hfi1_ctxtdata *rcd) in hfi1_alloc_ctxt_rcv_groups() argument 36 struct hfi1_devdata *dd = rcd->dd; in hfi1_alloc_ctxt_rcv_groups() 42 ngroups = rcd->expected_count / dd->rcv_entries.group_size; in hfi1_alloc_ctxt_rcv_groups() 43 rcd->groups = in hfi1_alloc_ctxt_rcv_groups() 44 kcalloc_node(ngroups, sizeof(*rcd->groups), in hfi1_alloc_ctxt_rcv_groups() 45 GFP_KERNEL, rcd->numa_id); in hfi1_alloc_ctxt_rcv_groups() [all …]
|
H A D | msix.c | 126 static int msix_request_rcd_irq_common(struct hfi1_ctxtdata *rcd, in msix_request_rcd_irq_common() argument 131 int nr = msix_request_irq(rcd->dd, rcd, handler, thread, in msix_request_rcd_irq_common() 132 rcd->is_vnic ? IRQ_NETDEVCTXT : IRQ_RCVCTXT, in msix_request_rcd_irq_common() 141 rcd->ireg = (IS_RCVAVAIL_START + rcd->ctxt) / 64; in msix_request_rcd_irq_common() 142 rcd->imask = ((u64)1) << ((IS_RCVAVAIL_START + rcd->ctxt) % 64); in msix_request_rcd_irq_common() 143 rcd->msix_intr = nr; in msix_request_rcd_irq_common() 144 remap_intr(rcd->dd, IS_RCVAVAIL_START + rcd->ctxt, nr); in msix_request_rcd_irq_common() 154 int msix_request_rcd_irq(struct hfi1_ctxtdata *rcd) in msix_request_rcd_irq() argument 159 rcd->dd->unit, rcd->ctxt); in msix_request_rcd_irq() 161 return msix_request_rcd_irq_common(rcd, receive_context_interrupt, in msix_request_rcd_irq() [all …]
|
H A D | tid_rdma.c | 133 struct hfi1_ctxtdata *rcd, 197 p->qp = (RVT_KDETH_QP_PREFIX << 16) | priv->rcd->ctxt; in tid_rdma_opfn_init() 199 p->jkey = priv->rcd->jkey; in tid_rdma_opfn_init() 203 p->urg = is_urg_masked(priv->rcd); in tid_rdma_opfn_init() 298 int hfi1_kern_exp_rcv_init(struct hfi1_ctxtdata *rcd, int reinit) in hfi1_kern_exp_rcv_init() argument 305 rcd->jkey = TID_RDMA_JKEY; in hfi1_kern_exp_rcv_init() 306 hfi1_set_ctxt_jkey(rcd->dd, rcd, rcd->jkey); in hfi1_kern_exp_rcv_init() 307 return hfi1_alloc_ctxt_rcv_groups(rcd); in hfi1_kern_exp_rcv_init() 335 return dd->rcd[ctxt]; in qp_to_rcd() 344 qpriv->rcd = qp_to_rcd(rdi, qp); in hfi1_qp_priv_init() [all …]
|
H A D | netdev_rx.c | 205 rc = hfi1_netdev_allot_ctxt(rx, &rxq->rcd); in hfi1_netdev_rxq_init() 209 hfi1_rcd_get(rxq->rcd); in hfi1_netdev_rxq_init() 211 rxq->rcd->napi = &rxq->napi; in hfi1_netdev_rxq_init() 213 i, rxq->rcd->ctxt); in hfi1_netdev_rxq_init() 220 rc = msix_netdev_request_rcd_irq(rxq->rcd); in hfi1_netdev_rxq_init() 232 if (rxq->rcd) { in hfi1_netdev_rxq_init() 233 hfi1_netdev_deallocate_ctxt(dd, rxq->rcd); in hfi1_netdev_rxq_init() 234 hfi1_rcd_put(rxq->rcd); in hfi1_netdev_rxq_init() 235 rxq->rcd = NULL; in hfi1_netdev_rxq_init() 253 hfi1_netdev_deallocate_ctxt(dd, rxq->rcd); in hfi1_netdev_rxq_deinit() [all …]
|
H A D | intr.c | 202 void handle_user_interrupt(struct hfi1_ctxtdata *rcd) in handle_user_interrupt() argument 204 struct hfi1_devdata *dd = rcd->dd; in handle_user_interrupt() 208 if (bitmap_empty(rcd->in_use_ctxts, HFI1_MAX_SHARED_CTXTS)) in handle_user_interrupt() 211 if (test_and_clear_bit(HFI1_CTXT_WAITING_RCV, &rcd->event_flags)) { in handle_user_interrupt() 212 wake_up_interruptible(&rcd->wait); in handle_user_interrupt() 213 hfi1_rcvctrl(dd, HFI1_RCVCTRL_INTRAVAIL_DIS, rcd); in handle_user_interrupt() 215 &rcd->event_flags)) { in handle_user_interrupt() 216 rcd->urgent++; in handle_user_interrupt() 217 wake_up_interruptible(&rcd->wait); in handle_user_interrupt()
|
H A D | exp_rcv.h | 151 hfi1_tid_group_to_idx(struct hfi1_ctxtdata *rcd, struct tid_group *grp) in hfi1_tid_group_to_idx() argument 153 return grp - &rcd->groups[0]; in hfi1_tid_group_to_idx() 162 hfi1_idx_to_tid_group(struct hfi1_ctxtdata *rcd, u16 idx) in hfi1_idx_to_tid_group() argument 164 return &rcd->groups[idx]; in hfi1_idx_to_tid_group() 167 int hfi1_alloc_ctxt_rcv_groups(struct hfi1_ctxtdata *rcd); 168 void hfi1_free_ctxt_rcv_groups(struct hfi1_ctxtdata *rcd); 169 void hfi1_exp_tid_group_init(struct hfi1_ctxtdata *rcd);
|
H A D | aspm.h | 22 void __aspm_ctx_disable(struct hfi1_ctxtdata *rcd); 26 static inline void aspm_ctx_disable(struct hfi1_ctxtdata *rcd) in aspm_ctx_disable() argument 29 if (likely(!rcd->aspm_intr_supported)) in aspm_ctx_disable() 32 __aspm_ctx_disable(rcd); in aspm_ctx_disable()
|
H A D | debugfs.c | 97 struct hfi1_ctxtdata *rcd; in _opcode_stats_seq_show() local 100 rcd = hfi1_rcd_get_by_index(dd, j); in _opcode_stats_seq_show() 101 if (rcd) { in _opcode_stats_seq_show() 102 n_packets += rcd->opstats->stats[i].n_packets; in _opcode_stats_seq_show() 103 n_bytes += rcd->opstats->stats[i].n_bytes; in _opcode_stats_seq_show() 105 hfi1_rcd_put(rcd); in _opcode_stats_seq_show() 188 struct hfi1_ctxtdata *rcd; in _ctx_stats_seq_show() local 198 rcd = hfi1_rcd_get_by_index_safe(dd, i); in _ctx_stats_seq_show() 199 if (!rcd) in _ctx_stats_seq_show() 202 for (j = 0; j < ARRAY_SIZE(rcd->opstats->stats); j++) in _ctx_stats_seq_show() [all …]
|
H A D | fault.c | 50 struct hfi1_ctxtdata *rcd; in _fault_stats_seq_show() local 53 rcd = hfi1_rcd_get_by_index(dd, j); in _fault_stats_seq_show() 54 if (rcd) { in _fault_stats_seq_show() 55 n_packets += rcd->opstats->stats[i].n_packets; in _fault_stats_seq_show() 56 n_bytes += rcd->opstats->stats[i].n_bytes; in _fault_stats_seq_show() 58 hfi1_rcd_put(rcd); in _fault_stats_seq_show() 320 struct hfi1_ibdev *ibd = &packet->rcd->dd->verbs_dev; in hfi1_dbg_should_fault_rx()
|
H A D | rc.h | 25 static inline void rc_defered_ack(struct hfi1_ctxtdata *rcd, in rc_defered_ack() argument 31 list_add_tail(&qp->rspwait, &rcd->qp_wait_list); in rc_defered_ack() 55 struct hfi1_ctxtdata *rcd);
|
H A D | tid_rdma.h | 99 struct hfi1_ctxtdata *rcd; member 209 int hfi1_kern_exp_rcv_init(struct hfi1_ctxtdata *rcd, int reinit); 236 int hfi1_kern_setup_hw_flow(struct hfi1_ctxtdata *rcd, struct rvt_qp *qp); 237 void hfi1_kern_clear_hw_flow(struct hfi1_ctxtdata *rcd, struct rvt_qp *qp); 238 void hfi1_kern_init_ctxt_generations(struct hfi1_ctxtdata *rcd); 255 bool hfi1_handle_kdeth_eflags(struct hfi1_ctxtdata *rcd,
|
H A D | msix.h | 16 int msix_request_rcd_irq(struct hfi1_ctxtdata *rcd); 22 int msix_netdev_request_rcd_irq(struct hfi1_ctxtdata *rcd);
|
H A D | verbs.c | 329 struct hfi1_ctxtdata *rcd = packet->rcd; in hfi1_kdeth_eager_rcv() local 332 struct hfi1_pportdata *ppd = rcd->ppd; in hfi1_kdeth_eager_rcv() 350 trace_input_ibhdr(rcd->dd, packet, !!(rhf_dc_info(packet->rhf))); in hfi1_kdeth_eager_rcv() 353 inc_opstats(tlen, &rcd->opstats->stats[opcode]); in hfi1_kdeth_eager_rcv() 383 struct hfi1_ctxtdata *rcd = packet->rcd; in hfi1_kdeth_expected_rcv() local 386 struct hfi1_pportdata *ppd = rcd->ppd; in hfi1_kdeth_expected_rcv() 404 trace_input_ibhdr(rcd->dd, packet, !!(rhf_dc_info(packet->rhf))); in hfi1_kdeth_expected_rcv() 407 inc_opstats(tlen, &rcd->opstats->stats[opcode]); in hfi1_kdeth_expected_rcv() 437 struct hfi1_ctxtdata *rcd = packet->rcd; in hfi1_do_pkey_check() local 438 struct hfi1_pportdata *ppd = rcd->ppd; in hfi1_do_pkey_check() [all …]
|
/linux/drivers/infiniband/hw/qib/ |
H A D | qib_file_ops.c | 101 struct qib_ctxtdata *rcd = ctxt_fp(fp); in qib_get_base_info() local 104 struct qib_devdata *dd = rcd->dd; in qib_get_base_info() 105 struct qib_pportdata *ppd = rcd->ppd; in qib_get_base_info() 110 subctxt_cnt = rcd->subctxt_cnt; in qib_get_base_info() 135 ret = dd->f_get_base_info(rcd, kinfo); in qib_get_base_info() 141 kinfo->spi_tidegrcnt = rcd->rcvegrcnt; in qib_get_base_info() 147 rcd->rcvegrbuf_chunks * rcd->rcvegrbuf_size; in qib_get_base_info() 148 kinfo->spi_rcv_egrperchunk = rcd->rcvegrbufs_perchunk; in qib_get_base_info() 150 rcd->rcvegrbuf_chunks; in qib_get_base_info() 184 kinfo->spi_rcvhdr_base = (u64) rcd->rcvhdrq_phys; in qib_get_base_info() [all …]
|
H A D | qib_init.c | 134 dd->rcd = kcalloc(dd->ctxtcnt, sizeof(*dd->rcd), GFP_KERNEL); in qib_create_ctxts() 135 if (!dd->rcd) in qib_create_ctxts() 141 struct qib_ctxtdata *rcd; in qib_create_ctxts() local 148 rcd = qib_create_ctxtdata(ppd, i, dd->assigned_node_id); in qib_create_ctxts() 149 if (!rcd) { in qib_create_ctxts() 152 kfree(dd->rcd); in qib_create_ctxts() 153 dd->rcd = NULL; in qib_create_ctxts() 156 rcd->pkeys[0] = QIB_DEFAULT_P_KEY; in qib_create_ctxts() 157 rcd->seq_cnt = 1; in qib_create_ctxts() 169 struct qib_ctxtdata *rcd; in qib_create_ctxtdata() local [all …]
|
H A D | qib_tx.c | 80 int qib_disarm_piobufs_ifneeded(struct qib_ctxtdata *rcd) in qib_disarm_piobufs_ifneeded() argument 82 struct qib_devdata *dd = rcd->dd; in qib_disarm_piobufs_ifneeded() 86 last = rcd->pio_base + rcd->piocnt; in qib_disarm_piobufs_ifneeded() 92 if (rcd->user_event_mask) { in qib_disarm_piobufs_ifneeded() 97 clear_bit(_QIB_EVENT_DISARM_BUFS_BIT, &rcd->user_event_mask[0]); in qib_disarm_piobufs_ifneeded() 98 for (i = 1; i < rcd->subctxt_cnt; i++) in qib_disarm_piobufs_ifneeded() 100 &rcd->user_event_mask[i]); in qib_disarm_piobufs_ifneeded() 103 for (i = rcd->pio_base; i < last; i++) { in qib_disarm_piobufs_ifneeded() 105 dd->f_sendctrl(rcd->ppd, QIB_SENDCTRL_DISARM_BUF(i)); in qib_disarm_piobufs_ifneeded() 131 struct qib_ctxtdata *rcd; in find_ctxt() local [all …]
|
H A D | qib_intr.c | 191 struct qib_ctxtdata *rcd; in qib_handle_urcv() local 196 for (i = dd->first_user_ctxt; dd->rcd && i < dd->cfgctxts; i++) { in qib_handle_urcv() 199 rcd = dd->rcd[i]; in qib_handle_urcv() 200 if (!rcd || !rcd->cnt) in qib_handle_urcv() 203 if (test_and_clear_bit(QIB_CTXT_WAITING_RCV, &rcd->flag)) { in qib_handle_urcv() 204 wake_up_interruptible(&rcd->wait); in qib_handle_urcv() 205 dd->f_rcvctrl(rcd->ppd, QIB_RCVCTRL_INTRAVAIL_DIS, in qib_handle_urcv() 206 rcd->ctxt); in qib_handle_urcv() 208 &rcd->flag)) { in qib_handle_urcv() 209 rcd->urgent++; in qib_handle_urcv() [all …]
|
H A D | qib_debugfs.c | 103 if (!dd->rcd[j]) in _opcode_stats_seq_show() 105 n_packets += dd->rcd[j]->opstats->stats[i].n_packets; in _opcode_stats_seq_show() 106 n_bytes += dd->rcd[j]->opstats->stats[i].n_bytes; in _opcode_stats_seq_show() 166 if (!dd->rcd[i]) in _ctx_stats_seq_show() 169 for (j = 0; j < ARRAY_SIZE(dd->rcd[i]->opstats->stats); j++) in _ctx_stats_seq_show() 170 n_packets += dd->rcd[i]->opstats->stats[j].n_packets; in _ctx_stats_seq_show()
|
/linux/arch/x86/kernel/cpu/mce/ |
H A D | apei.c | 195 struct cper_mce_record rcd; in apei_write_mce() local 197 memset(&rcd, 0, sizeof(rcd)); in apei_write_mce() 198 memcpy(rcd.hdr.signature, CPER_SIG_RECORD, CPER_SIG_SIZE); in apei_write_mce() 199 rcd.hdr.revision = CPER_RECORD_REV; in apei_write_mce() 200 rcd.hdr.signature_end = CPER_SIG_END; in apei_write_mce() 201 rcd.hdr.section_count = 1; in apei_write_mce() 202 rcd.hdr.error_severity = CPER_SEV_FATAL; in apei_write_mce() 204 rcd.hdr.validation_bits = 0; in apei_write_mce() 205 rcd.hdr.record_length = sizeof(rcd); in apei_write_mce() 206 rcd.hdr.creator_id = CPER_CREATOR_MCE; in apei_write_mce() [all …]
|
/linux/drivers/acpi/apei/ |
H A D | erst.c | 1074 struct cper_pstore_record *rcd; in erst_reader() local 1075 size_t rcd_len = sizeof(*rcd) + erst_info.bufsize; in erst_reader() 1080 rcd = kmalloc(rcd_len, GFP_KERNEL); in erst_reader() 1081 if (!rcd) { in erst_reader() 1096 len = erst_read_record(record_id, &rcd->hdr, rcd_len, sizeof(*rcd), in erst_reader() 1109 memcpy(record->buf, rcd->data, len - sizeof(*rcd)); in erst_reader() 1113 if (guid_equal(&rcd->sec_hdr.section_type, &CPER_SECTION_TYPE_DMESG_Z)) { in erst_reader() 1116 } else if (guid_equal(&rcd->sec_hdr.section_type, &CPER_SECTION_TYPE_DMESG)) in erst_reader() 1118 else if (guid_equal(&rcd->sec_hdr.section_type, &CPER_SECTION_TYPE_MCE)) in erst_reader() 1123 if (rcd->hdr.validation_bits & CPER_VALID_TIMESTAMP) in erst_reader() [all …]
|
/linux/drivers/net/ethernet/meta/fbnic/ |
H A D | fbnic_txrx.c | 201 fbnic_rx_csum(u64 rcd, struct sk_buff *skb, struct fbnic_ring *rcq) in fbnic_rx_csum() argument 208 if (FIELD_GET(FBNIC_RCD_META_L4_CSUM_UNNECESSARY, rcd)) { in fbnic_rx_csum() 211 u16 csum = FIELD_GET(FBNIC_RCD_META_L2_CSUM_MASK, rcd); in fbnic_rx_csum() 709 static void fbnic_pkt_prepare(struct fbnic_napi_vector *nv, u64 rcd, in fbnic_pkt_prepare() argument 713 unsigned int hdr_pg_idx = FIELD_GET(FBNIC_RCD_AL_BUFF_PAGE_MASK, rcd); in fbnic_pkt_prepare() 714 unsigned int hdr_pg_off = FIELD_GET(FBNIC_RCD_AL_BUFF_OFF_MASK, rcd); in fbnic_pkt_prepare() 716 unsigned int len = FIELD_GET(FBNIC_RCD_AL_BUFF_LEN_MASK, rcd); in fbnic_pkt_prepare() 724 hdr_pg_end = FIELD_GET(FBNIC_RCD_AL_PAGE_FIN, rcd) ? in fbnic_pkt_prepare() 731 hdr_pg_start += (FBNIC_RCD_AL_BUFF_FRAG_MASK & rcd) * in fbnic_pkt_prepare() 750 static void fbnic_add_rx_frag(struct fbnic_napi_vector *nv, u64 rcd, in fbnic_add_rx_frag() argument [all …]
|
/linux/drivers/cpufreq/ |
H A D | sa1110-cpufreq.c | 130 static inline void set_mdcas(u_int *mdcas, int delayed, u_int rcd) in set_mdcas() argument 134 rcd = 2 * rcd - 1; in set_mdcas() 135 shift = delayed + 1 + rcd; in set_mdcas() 137 mdcas[0] = (1 << rcd) - 1; in set_mdcas()
|