����JFIF���������
__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
/* SPDX-License-Identifier: GPL-2.0-only */
/*
* Trace point definitions for core RDMA functions.
*
* Author: Chuck Lever <chuck.lever@oracle.com>
*
* Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved.
*/
#undef TRACE_SYSTEM
#define TRACE_SYSTEM rdma_core
#if !defined(_TRACE_RDMA_CORE_H) || defined(TRACE_HEADER_MULTI_READ)
#define _TRACE_RDMA_CORE_H
#include <linux/tracepoint.h>
#include <rdma/ib_verbs.h>
/*
* enum ib_poll_context, from include/rdma/ib_verbs.h
*/
#define IB_POLL_CTX_LIST \
ib_poll_ctx(DIRECT) \
ib_poll_ctx(SOFTIRQ) \
ib_poll_ctx(WORKQUEUE) \
ib_poll_ctx_end(UNBOUND_WORKQUEUE)
#undef ib_poll_ctx
#undef ib_poll_ctx_end
#define ib_poll_ctx(x) TRACE_DEFINE_ENUM(IB_POLL_##x);
#define ib_poll_ctx_end(x) TRACE_DEFINE_ENUM(IB_POLL_##x);
IB_POLL_CTX_LIST
#undef ib_poll_ctx
#undef ib_poll_ctx_end
#define ib_poll_ctx(x) { IB_POLL_##x, #x },
#define ib_poll_ctx_end(x) { IB_POLL_##x, #x }
#define rdma_show_ib_poll_ctx(x) \
__print_symbolic(x, IB_POLL_CTX_LIST)
/**
** Completion Queue events
**/
TRACE_EVENT(cq_schedule,
TP_PROTO(
struct ib_cq *cq
),
TP_ARGS(cq),
TP_STRUCT__entry(
__field(u32, cq_id)
),
TP_fast_assign(
cq->timestamp = ktime_get();
cq->interrupt = true;
__entry->cq_id = cq->res.id;
),
TP_printk("cq.id=%u", __entry->cq_id)
);
TRACE_EVENT(cq_reschedule,
TP_PROTO(
struct ib_cq *cq
),
TP_ARGS(cq),
TP_STRUCT__entry(
__field(u32, cq_id)
),
TP_fast_assign(
cq->timestamp = ktime_get();
cq->interrupt = false;
__entry->cq_id = cq->res.id;
),
TP_printk("cq.id=%u", __entry->cq_id)
);
TRACE_EVENT(cq_process,
TP_PROTO(
const struct ib_cq *cq
),
TP_ARGS(cq),
TP_STRUCT__entry(
__field(u32, cq_id)
__field(bool, interrupt)
__field(s64, latency)
),
TP_fast_assign(
ktime_t latency = ktime_sub(ktime_get(), cq->timestamp);
__entry->cq_id = cq->res.id;
__entry->latency = ktime_to_us(latency);
__entry->interrupt = cq->interrupt;
),
TP_printk("cq.id=%u wake-up took %lld [us] from %s",
__entry->cq_id, __entry->latency,
__entry->interrupt ? "interrupt" : "reschedule"
)
);
TRACE_EVENT(cq_poll,
TP_PROTO(
const struct ib_cq *cq,
int requested,
int rc
),
TP_ARGS(cq, requested, rc),
TP_STRUCT__entry(
__field(u32, cq_id)
__field(int, requested)
__field(int, rc)
),
TP_fast_assign(
__entry->cq_id = cq->res.id;
__entry->requested = requested;
__entry->rc = rc;
),
TP_printk("cq.id=%u requested %d, returned %d",
__entry->cq_id, __entry->requested, __entry->rc
)
);
TRACE_EVENT(cq_drain_complete,
TP_PROTO(
const struct ib_cq *cq
),
TP_ARGS(cq),
TP_STRUCT__entry(
__field(u32, cq_id)
),
TP_fast_assign(
__entry->cq_id = cq->res.id;
),
TP_printk("cq.id=%u",
__entry->cq_id
)
);
TRACE_EVENT(cq_modify,
TP_PROTO(
const struct ib_cq *cq,
u16 comps,
u16 usec
),
TP_ARGS(cq, comps, usec),
TP_STRUCT__entry(
__field(u32, cq_id)
__field(unsigned int, comps)
__field(unsigned int, usec)
),
TP_fast_assign(
__entry->cq_id = cq->res.id;
__entry->comps = comps;
__entry->usec = usec;
),
TP_printk("cq.id=%u comps=%u usec=%u",
__entry->cq_id, __entry->comps, __entry->usec
)
);
TRACE_EVENT(cq_alloc,
TP_PROTO(
const struct ib_cq *cq,
int nr_cqe,
int comp_vector,
enum ib_poll_context poll_ctx
),
TP_ARGS(cq, nr_cqe, comp_vector, poll_ctx),
TP_STRUCT__entry(
__field(u32, cq_id)
__field(int, nr_cqe)
__field(int, comp_vector)
__field(unsigned long, poll_ctx)
),
TP_fast_assign(
__entry->cq_id = cq->res.id;
__entry->nr_cqe = nr_cqe;
__entry->comp_vector = comp_vector;
__entry->poll_ctx = poll_ctx;
),
TP_printk("cq.id=%u nr_cqe=%d comp_vector=%d poll_ctx=%s",
__entry->cq_id, __entry->nr_cqe, __entry->comp_vector,
rdma_show_ib_poll_ctx(__entry->poll_ctx)
)
);
TRACE_EVENT(cq_alloc_error,
TP_PROTO(
int nr_cqe,
int comp_vector,
enum ib_poll_context poll_ctx,
int rc
),
TP_ARGS(nr_cqe, comp_vector, poll_ctx, rc),
TP_STRUCT__entry(
__field(int, rc)
__field(int, nr_cqe)
__field(int, comp_vector)
__field(unsigned long, poll_ctx)
),
TP_fast_assign(
__entry->rc = rc;
__entry->nr_cqe = nr_cqe;
__entry->comp_vector = comp_vector;
__entry->poll_ctx = poll_ctx;
),
TP_printk("nr_cqe=%d comp_vector=%d poll_ctx=%s rc=%d",
__entry->nr_cqe, __entry->comp_vector,
rdma_show_ib_poll_ctx(__entry->poll_ctx), __entry->rc
)
);
TRACE_EVENT(cq_free,
TP_PROTO(
const struct ib_cq *cq
),
TP_ARGS(cq),
TP_STRUCT__entry(
__field(u32, cq_id)
),
TP_fast_assign(
__entry->cq_id = cq->res.id;
),
TP_printk("cq.id=%u", __entry->cq_id)
);
/**
** Memory Region events
**/
/*
* enum ib_mr_type, from include/rdma/ib_verbs.h
*/
#define IB_MR_TYPE_LIST \
ib_mr_type_item(MEM_REG) \
ib_mr_type_item(SG_GAPS) \
ib_mr_type_item(DM) \
ib_mr_type_item(USER) \
ib_mr_type_item(DMA) \
ib_mr_type_end(INTEGRITY)
#undef ib_mr_type_item
#undef ib_mr_type_end
#define ib_mr_type_item(x) TRACE_DEFINE_ENUM(IB_MR_TYPE_##x);
#define ib_mr_type_end(x) TRACE_DEFINE_ENUM(IB_MR_TYPE_##x);
IB_MR_TYPE_LIST
#undef ib_mr_type_item
#undef ib_mr_type_end
#define ib_mr_type_item(x) { IB_MR_TYPE_##x, #x },
#define ib_mr_type_end(x) { IB_MR_TYPE_##x, #x }
#define rdma_show_ib_mr_type(x) \
__print_symbolic(x, IB_MR_TYPE_LIST)
TRACE_EVENT(mr_alloc,
TP_PROTO(
const struct ib_pd *pd,
enum ib_mr_type mr_type,
u32 max_num_sg,
const struct ib_mr *mr
),
TP_ARGS(pd, mr_type, max_num_sg, mr),
TP_STRUCT__entry(
__field(u32, pd_id)
__field(u32, mr_id)
__field(u32, max_num_sg)
__field(int, rc)
__field(unsigned long, mr_type)
),
TP_fast_assign(
__entry->pd_id = pd->res.id;
if (IS_ERR(mr)) {
__entry->mr_id = 0;
__entry->rc = PTR_ERR(mr);
} else {
__entry->mr_id = mr->res.id;
__entry->rc = 0;
}
__entry->max_num_sg = max_num_sg;
__entry->mr_type = mr_type;
),
TP_printk("pd.id=%u mr.id=%u type=%s max_num_sg=%u rc=%d",
__entry->pd_id, __entry->mr_id,
rdma_show_ib_mr_type(__entry->mr_type),
__entry->max_num_sg, __entry->rc)
);
TRACE_EVENT(mr_integ_alloc,
TP_PROTO(
const struct ib_pd *pd,
u32 max_num_data_sg,
u32 max_num_meta_sg,
const struct ib_mr *mr
),
TP_ARGS(pd, max_num_data_sg, max_num_meta_sg, mr),
TP_STRUCT__entry(
__field(u32, pd_id)
__field(u32, mr_id)
__field(u32, max_num_data_sg)
__field(u32, max_num_meta_sg)
__field(int, rc)
),
TP_fast_assign(
__entry->pd_id = pd->res.id;
if (IS_ERR(mr)) {
__entry->mr_id = 0;
__entry->rc = PTR_ERR(mr);
} else {
__entry->mr_id = mr->res.id;
__entry->rc = 0;
}
__entry->max_num_data_sg = max_num_data_sg;
__entry->max_num_meta_sg = max_num_meta_sg;
),
TP_printk("pd.id=%u mr.id=%u max_num_data_sg=%u max_num_meta_sg=%u rc=%d",
__entry->pd_id, __entry->mr_id, __entry->max_num_data_sg,
__entry->max_num_meta_sg, __entry->rc)
);
TRACE_EVENT(mr_dereg,
TP_PROTO(
const struct ib_mr *mr
),
TP_ARGS(mr),
TP_STRUCT__entry(
__field(u32, id)
),
TP_fast_assign(
__entry->id = mr->res.id;
),
TP_printk("mr.id=%u", __entry->id)
);
#endif /* _TRACE_RDMA_CORE_H */
#include <trace/define_trace.h>
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| 9p.h | File | 5.1 KB | 0644 |
|
| afs.h | File | 56.24 KB | 0644 |
|
| alarmtimer.h | File | 2.04 KB | 0644 |
|
| asoc.h | File | 5.57 KB | 0644 |
|
| avc.h | File | 1.26 KB | 0644 |
|
| bcache.h | File | 11.44 KB | 0644 |
|
| block.h | File | 15.84 KB | 0644 |
|
| bpf_test_run.h | File | 1.23 KB | 0644 |
|
| bridge.h | File | 4.73 KB | 0644 |
|
| btrfs.h | File | 60.14 KB | 0644 |
|
| cachefiles.h | File | 22.77 KB | 0644 |
|
| cgroup.h | File | 6.3 KB | 0644 |
|
| clk.h | File | 6.17 KB | 0644 |
|
| cma.h | File | 2.95 KB | 0644 |
|
| compaction.h | File | 7.72 KB | 0644 |
|
| context_tracking.h | File | 1.15 KB | 0644 |
|
| cpuhp.h | File | 1.83 KB | 0644 |
|
| csd.h | File | 1.52 KB | 0644 |
|
| damon.h | File | 1.13 KB | 0644 |
|
| devfreq.h | File | 1.92 KB | 0644 |
|
| devlink.h | File | 7.21 KB | 0644 |
|
| dma.h | File | 13.33 KB | 0644 |
|
| dma_fence.h | File | 1.67 KB | 0644 |
|
| erofs.h | File | 6.31 KB | 0644 |
|
| error_report.h | File | 2.06 KB | 0644 |
|
| ext4.h | File | 74.52 KB | 0644 |
|
| f2fs.h | File | 45.15 KB | 0644 |
|
| fib.h | File | 2.52 KB | 0644 |
|
| fib6.h | File | 2.36 KB | 0644 |
|
| filelock.h | File | 7.33 KB | 0644 |
|
| filemap.h | File | 2.81 KB | 0644 |
|
| fs_dax.h | File | 8.26 KB | 0644 |
|
| fscache.h | File | 14.27 KB | 0644 |
|
| fsi.h | File | 2.81 KB | 0644 |
|
| fsi_master_aspeed.h | File | 2.06 KB | 0644 |
|
| fsi_master_ast_cf.h | File | 3.67 KB | 0644 |
|
| fsi_master_gpio.h | File | 3.92 KB | 0644 |
|
| gpio.h | File | 1.07 KB | 0644 |
|
| gpu_mem.h | File | 1.21 KB | 0644 |
|
| handshake.h | File | 8.21 KB | 0644 |
|
| host1x.h | File | 5.54 KB | 0644 |
|
| huge_memory.h | File | 6.6 KB | 0644 |
|
| hw_pressure.h | File | 698 B | 0644 |
|
| hwmon.h | File | 1.45 KB | 0644 |
|
| i2c.h | File | 3.95 KB | 0644 |
|
| i2c_slave.h | File | 1.84 KB | 0644 |
|
| ib_mad.h | File | 12.42 KB | 0644 |
|
| ib_umad.h | File | 4 KB | 0644 |
|
| initcall.h | File | 1.28 KB | 0644 |
|
| intel-sst.h | File | 2.51 KB | 0644 |
|
| intel_ifs.h | File | 1.38 KB | 0644 |
|
| intel_ish.h | File | 556 B | 0644 |
|
| io_uring.h | File | 16.8 KB | 0644 |
|
| iocost.h | File | 6.24 KB | 0644 |
|
| iommu.h | File | 3.02 KB | 0644 |
|
| ipi.h | File | 2.89 KB | 0644 |
|
| irq.h | File | 3.8 KB | 0644 |
|
| irq_matrix.h | File | 4.94 KB | 0644 |
|
| iscsi.h | File | 2.25 KB | 0644 |
|
| jbd2.h | File | 12.69 KB | 0644 |
|
| kmem.h | File | 8.63 KB | 0644 |
|
| ksm.h | File | 5.25 KB | 0644 |
|
| kvm.h | File | 10.93 KB | 0644 |
|
| kyber.h | File | 2.27 KB | 0644 |
|
| libata.h | File | 23.69 KB | 0644 |
|
| lock.h | File | 2.79 KB | 0644 |
|
| maple_tree.h | File | 2.69 KB | 0644 |
|
| mce.h | File | 2.53 KB | 0644 |
|
| mdio.h | File | 1.02 KB | 0644 |
|
| migrate.h | File | 3.71 KB | 0644 |
|
| mlxsw.h | File | 2.62 KB | 0644 |
|
| mmap.h | File | 2.72 KB | 0644 |
|
| mmap_lock.h | File | 2.17 KB | 0644 |
|
| mmc.h | File | 7.24 KB | 0644 |
|
| mmflags.h | File | 8.58 KB | 0644 |
|
| module.h | File | 2.78 KB | 0644 |
|
| mptcp.h | File | 4.59 KB | 0644 |
|
| napi.h | File | 1011 B | 0644 |
|
| nbd.h | File | 2.14 KB | 0644 |
|
| neigh.h | File | 7 KB | 0644 |
|
| net.h | File | 7.75 KB | 0644 |
|
| net_probe_common.h | File | 3.26 KB | 0644 |
|
| netfs.h | File | 9.46 KB | 0644 |
|
| netlink.h | File | 490 B | 0644 |
|
| nilfs2.h | File | 5.2 KB | 0644 |
|
| nmi.h | File | 780 B | 0644 |
|
| objagg.h | File | 4.58 KB | 0644 |
|
| oom.h | File | 3.88 KB | 0644 |
|
| osnoise.h | File | 5.27 KB | 0644 |
|
| page_isolation.h | File | 943 B | 0644 |
|
| page_pool.h | File | 2.6 KB | 0644 |
|
| page_ref.h | File | 2.96 KB | 0644 |
|
| pagemap.h | File | 2.14 KB | 0644 |
|
| percpu.h | File | 3.11 KB | 0644 |
|
| power.h | File | 12.67 KB | 0644 |
|
| power_cpu_migrate.h | File | 1.59 KB | 0644 |
|
| preemptirq.h | File | 2.11 KB | 0644 |
|
| printk.h | File | 786 B | 0644 |
|
| pwc.h | File | 1.67 KB | 0644 |
|
| pwm.h | File | 1.21 KB | 0644 |
|
| qdisc.h | File | 3.81 KB | 0644 |
|
| qla.h | File | 937 B | 0644 |
|
| qrtr.h | File | 2.54 KB | 0644 |
|
| rcu.h | File | 24.8 KB | 0644 |
|
| rdma_core.h | File | 7.02 KB | 0644 |
|
| regulator.h | File | 2.83 KB | 0644 |
|
| rpcgss.h | File | 14.79 KB | 0644 |
|
| rpcrdma.h | File | 50.45 KB | 0644 |
|
| rpm.h | File | 2.44 KB | 0644 |
|
| rseq.h | File | 1.26 KB | 0644 |
|
| rtc.h | File | 3.28 KB | 0644 |
|
| rwmmio.h | File | 2.67 KB | 0644 |
|
| rxrpc.h | File | 61.38 KB | 0644 |
|
| sched.h | File | 19.36 KB | 0644 |
|
| scmi.h | File | 4.63 KB | 0644 |
|
| scsi.h | File | 10.63 KB | 0644 |
|
| sctp.h | File | 2.38 KB | 0644 |
|
| signal.h | File | 3.4 KB | 0644 |
|
| siox.h | File | 1.99 KB | 0644 |
|
| skb.h | File | 2.04 KB | 0644 |
|
| smbus.h | File | 7.33 KB | 0644 |
|
| sock.h | File | 7.56 KB | 0644 |
|
| sof.h | File | 3.26 KB | 0644 |
|
| sof_intel.h | File | 4.01 KB | 0644 |
|
| spi.h | File | 5.81 KB | 0644 |
|
| spmi.h | File | 3.26 KB | 0644 |
|
| sunrpc.h | File | 60.87 KB | 0644 |
|
| sunvnet.h | File | 3.06 KB | 0644 |
|
| swiotlb.h | File | 1.03 KB | 0644 |
|
| syscalls.h | File | 1.47 KB | 0644 |
|
| target.h | File | 7.69 KB | 0644 |
|
| task.h | File | 1.49 KB | 0644 |
|
| tcp.h | File | 10.03 KB | 0644 |
|
| tegra_apb_dma.h | File | 1.61 KB | 0644 |
|
| thp.h | File | 2.48 KB | 0644 |
|
| timer.h | File | 10.65 KB | 0644 |
|
| tlb.h | File | 1.41 KB | 0644 |
|
| udp.h | File | 1.25 KB | 0644 |
|
| v4l2.h | File | 8.81 KB | 0644 |
|
| vb2.h | File | 1.73 KB | 0644 |
|
| vmalloc.h | File | 3.2 KB | 0644 |
|
| vmscan.h | File | 12.41 KB | 0644 |
|
| vsock_virtio_transport_common.h | File | 3.71 KB | 0644 |
|
| wbt.h | File | 3.82 KB | 0644 |
|
| workqueue.h | File | 2.93 KB | 0644 |
|
| writeback.h | File | 22.38 KB | 0644 |
|
| xdp.h | File | 10.03 KB | 0644 |
|
| xen.h | File | 13.9 KB | 0644 |
|