diff options
Diffstat (limited to 'nvme-print-binary.c')
-rw-r--r-- | nvme-print-binary.c | 386 |
1 files changed, 386 insertions, 0 deletions
diff --git a/nvme-print-binary.c b/nvme-print-binary.c new file mode 100644 index 0000000..e9371e5 --- /dev/null +++ b/nvme-print-binary.c @@ -0,0 +1,386 @@ +/* SPDX-License-Identifier: GPL-2.0-or-later */ + +#include "nvme-print.h" + +static struct print_ops binary_print_ops; + +static void binary_predictable_latency_per_nvmset( + struct nvme_nvmset_predictable_lat_log *plpns_log, + __u16 nvmset_id, const char *devname) +{ + d_raw((unsigned char *)plpns_log, sizeof(*plpns_log)); +} + +static void binary_predictable_latency_event_agg_log( + struct nvme_aggregate_predictable_lat_event *pea_log, + __u64 log_entries, __u32 size, const char *devname) +{ + d_raw((unsigned char *)pea_log, size); +} + +static void binary_persistent_event_log(void *pevent_log_info, + __u8 action, __u32 size, const char *devname) +{ + d_raw((unsigned char *)pevent_log_info, size); +} + +static void binary_endurance_group_event_agg_log( + struct nvme_aggregate_predictable_lat_event *endurance_log, + __u64 log_entries, __u32 size, const char *devname) +{ + d_raw((unsigned char *)endurance_log, size); +} + +static void binary_lba_status_log(void *lba_status, __u32 size, + const char *devname) +{ + d_raw((unsigned char *)lba_status, size); +} + +static void binary_resv_notif_log(struct nvme_resv_notification_log *resv, + const char *devname) +{ + d_raw((unsigned char *)resv, sizeof(*resv)); +} + +static void binary_fid_support_effects_log( + struct nvme_fid_supported_effects_log *fid_log, + const char *devname) +{ + d_raw((unsigned char *)fid_log, sizeof(*fid_log)); +} + +static void binary_mi_cmd_support_effects_log( + struct nvme_mi_cmd_supported_effects_log *mi_cmd_log, + const char *devname) +{ + d_raw((unsigned char *)mi_cmd_log, sizeof(*mi_cmd_log)); +} + +static void binary_boot_part_log(void *bp_log, const char *devname, + __u32 size) +{ + d_raw((unsigned char *)bp_log, size); +} + +static void binary_phy_rx_eom_log(struct nvme_phy_rx_eom_log *log, + __u16 controller) +{ + size_t len; + if (log->eomip == NVME_PHY_RX_EOM_COMPLETED) + len = log->hsize + log->dsize * log->nd; + else + len = log->hsize; + + d_raw((unsigned char *)log, len); +} + +static void binary_media_unit_stat_log(struct nvme_media_unit_stat_log *mus_log) +{ + d_raw((unsigned char *)mus_log, sizeof(*mus_log)); +} + +static void binary_fdp_configs(struct nvme_fdp_config_log *log, size_t len) +{ + d_raw((unsigned char *)log, len); +} + +static void binary_fdp_usage(struct nvme_fdp_ruhu_log *log, size_t len) +{ + + d_raw((unsigned char *)log, len); +} + +static void binary_fdp_stats(struct nvme_fdp_stats_log *log) +{ + d_raw((unsigned char*)log, sizeof(*log)); +} + +static void binary_fdp_events(struct nvme_fdp_events_log *log) +{ + d_raw((unsigned char*)log, sizeof(*log)); +} + +static void binary_fdp_ruh_status(struct nvme_fdp_ruh_status *status, size_t len) +{ + d_raw((unsigned char *)status, len); +} + +static void binary_supported_cap_config_log( + struct nvme_supported_cap_config_list_log *cap) +{ + d_raw((unsigned char *)cap, sizeof(*cap)); +} + +static void binary_ctrl_registers(void *bar, bool fabrics) +{ + const unsigned int reg_size = 0x0e1c; /* 0x0000 to 0x0e1b */ + + d_raw((unsigned char *)bar, reg_size); +} + +static void binary_id_ns(struct nvme_id_ns *ns, unsigned int nsid, + unsigned int lba_index, bool cap_only) +{ + d_raw((unsigned char *)ns, sizeof(*ns)); +} + + +static void binary_cmd_set_independent_id_ns( + struct nvme_id_independent_id_ns *ns, unsigned int nsid) +{ + d_raw((unsigned char *)ns, sizeof(*ns)); +} + +static void binary_id_ns_descs(void *data, unsigned nsid) +{ + d_raw((unsigned char *)data, 0x1000); +} + +static void binary_id_ctrl(struct nvme_id_ctrl *ctrl, + void (*vendor_show)(__u8 *vs, struct json_object *root)) +{ + d_raw((unsigned char *)ctrl, sizeof(*ctrl)); +} + +static void binary_id_ctrl_nvm(struct nvme_id_ctrl_nvm *ctrl_nvm) +{ + d_raw((unsigned char *)ctrl_nvm, sizeof(*ctrl_nvm)); +} + +static void binary_nvm_id_ns(struct nvme_nvm_id_ns *nvm_ns, unsigned int nsid, + struct nvme_id_ns *ns, unsigned int lba_index, + bool cap_only) +{ + d_raw((unsigned char *)nvm_ns, sizeof(*nvm_ns)); +} + +static void binary_zns_id_ctrl(struct nvme_zns_id_ctrl *ctrl) +{ + d_raw((unsigned char *)ctrl, sizeof(*ctrl)); +} + +static void binary_zns_id_ns(struct nvme_zns_id_ns *ns, struct nvme_id_ns *id_ns) +{ + d_raw((unsigned char *)ns, sizeof(*ns)); +} + +static void binary_zns_changed(struct nvme_zns_changed_zone_log *log) +{ + d_raw((unsigned char *)log, sizeof(*log)); +} + +static void binary_zns_report_zones(void *report, __u32 descs, + __u8 ext_size, __u32 report_size, + struct json_object *zone_list) +{ + d_raw((unsigned char *)report, report_size); +} + +static void binary_list_ctrl(struct nvme_ctrl_list *ctrl_list) +{ + d_raw((unsigned char *)ctrl_list, sizeof(*ctrl_list)); +} + +static void binary_id_nvmset(struct nvme_id_nvmset_list *nvmset, unsigned nvmset_id) +{ + d_raw((unsigned char *)nvmset, sizeof(*nvmset)); +} + +static void binary_primary_ctrl_cap(const struct nvme_primary_ctrl_cap *caps) +{ + d_raw((unsigned char *)caps, sizeof(*caps)); +} + +static void binary_list_secondary_ctrl( + const struct nvme_secondary_ctrl_list *sc_list, + __u32 count) +{ + d_raw((unsigned char *)sc_list, sizeof(*sc_list)); +} + +static void binary_id_ns_granularity_list( + const struct nvme_id_ns_granularity_list *glist) +{ + d_raw((unsigned char *)glist, sizeof(*glist)); +} + +static void binary_id_uuid_list(const struct nvme_id_uuid_list *uuid_list) +{ + d_raw((unsigned char *)uuid_list, sizeof(*uuid_list)); +} + +static void binary_id_domain_list(struct nvme_id_domain_list *id_dom) +{ + d_raw((unsigned char *)id_dom, sizeof(*id_dom)); +} + +static void binary_error_log(struct nvme_error_log_page *err_log, int entries, + const char *devname) +{ + d_raw((unsigned char *)err_log, entries * sizeof(*err_log)); +} + +static void binary_resv_report(struct nvme_resv_status *status, int bytes, + bool eds) +{ + d_raw((unsigned char *)status, bytes); +} + +static void binary_fw_log(struct nvme_firmware_slot *fw_log, + const char *devname) +{ + d_raw((unsigned char *)fw_log, sizeof(*fw_log)); +} + +static void binary_changed_ns_list_log(struct nvme_ns_list *log, + const char *devname) +{ + d_raw((unsigned char *)log, sizeof(*log)); +} + + +static void binary_supported_log(struct nvme_supported_log_pages *support_log, + const char *devname) +{ + d_raw((unsigned char *)support_log, sizeof(*support_log)); +} + +static void binary_endurance_log(struct nvme_endurance_group_log *endurance_log, __u16 group_id, + const char *devname) +{ + return d_raw((unsigned char *)endurance_log, sizeof(*endurance_log)); +} + +static void binary_smart_log(struct nvme_smart_log *smart, unsigned int nsid, + const char *devname) +{ + d_raw((unsigned char *)smart, sizeof(*smart)); +} + +static void binary_ana_log(struct nvme_ana_log *ana_log, const char *devname, + size_t len) +{ + d_raw((unsigned char *)ana_log, len); +} + +static void binary_self_test_log(struct nvme_self_test_log *self_test, __u8 dst_entries, + __u32 size, const char *devname) +{ + d_raw((unsigned char *)self_test, size); +} + +static void binary_sanitize_log(struct nvme_sanitize_log_page *sanitize, + const char *devname) +{ + d_raw((unsigned char *)sanitize, sizeof(*sanitize)); +} + +static void binary_directive(__u8 type, __u8 oper, __u16 spec, __u32 nsid, __u32 result, + void *buf, __u32 len) +{ + if (!buf) + return; + + d_raw(buf, len); +} + +static void binary_lba_status(struct nvme_lba_status *list, unsigned long len) +{ + d_raw((unsigned char *)list, len); +} + +static void binary_discovery_log(struct nvmf_discovery_log *log, int numrec) +{ + d_raw((unsigned char *)log, + sizeof(struct nvmf_discovery_log) + + numrec * sizeof(struct nvmf_disc_log_entry)); +} + +static struct print_ops binary_print_ops = { + /* libnvme types.h print functions */ + .ana_log = binary_ana_log, + .boot_part_log = binary_boot_part_log, + .phy_rx_eom_log = binary_phy_rx_eom_log, + .ctrl_list = binary_list_ctrl, + .ctrl_registers = binary_ctrl_registers, + .directive = binary_directive, + .discovery_log = binary_discovery_log, + .effects_log_list = NULL, + .endurance_group_event_agg_log = binary_endurance_group_event_agg_log, + .endurance_group_list = NULL, + .endurance_log = binary_endurance_log, + .error_log = binary_error_log, + .fdp_config_log = binary_fdp_configs, + .fdp_event_log = binary_fdp_events, + .fdp_ruh_status = binary_fdp_ruh_status, + .fdp_stats_log = binary_fdp_stats, + .fdp_usage_log = binary_fdp_usage, + .fid_supported_effects_log = binary_fid_support_effects_log, + .fw_log = binary_fw_log, + .id_ctrl = binary_id_ctrl, + .id_ctrl_nvm = binary_id_ctrl_nvm, + .id_domain_list = binary_id_domain_list, + .id_independent_id_ns = binary_cmd_set_independent_id_ns, + .id_iocs = NULL, + .id_ns = binary_id_ns, + .id_ns_descs = binary_id_ns_descs, + .id_ns_granularity_list = binary_id_ns_granularity_list, + .id_nvmset_list = binary_id_nvmset, + .id_uuid_list = binary_id_uuid_list, + .lba_status = binary_lba_status, + .lba_status_log = binary_lba_status_log, + .media_unit_stat_log = binary_media_unit_stat_log, + .mi_cmd_support_effects_log = binary_mi_cmd_support_effects_log, + .ns_list = NULL, + .ns_list_log = binary_changed_ns_list_log, + .nvm_id_ns = binary_nvm_id_ns, + .persistent_event_log = binary_persistent_event_log, + .predictable_latency_event_agg_log = binary_predictable_latency_event_agg_log, + .predictable_latency_per_nvmset = binary_predictable_latency_per_nvmset, + .primary_ctrl_cap = binary_primary_ctrl_cap, + .resv_notification_log = binary_resv_notif_log, + .resv_report = binary_resv_report, + .sanitize_log_page = binary_sanitize_log, + .secondary_ctrl_list = binary_list_secondary_ctrl, + .select_result = NULL, + .self_test_log = binary_self_test_log, + .single_property = NULL, + .smart_log = binary_smart_log, + .supported_cap_config_list_log = binary_supported_cap_config_log, + .supported_log_pages = binary_supported_log, + .zns_start_zone_list = NULL, + .zns_changed_zone_log = binary_zns_changed, + .zns_finish_zone_list = NULL, + .zns_id_ctrl = binary_zns_id_ctrl, + .zns_id_ns = binary_zns_id_ns, + .zns_report_zones = binary_zns_report_zones, + .show_feature = NULL, + .show_feature_fields = NULL, + .id_ctrl_rpmbs = NULL, + .lba_range = NULL, + .lba_status_info = NULL, + .d = NULL, + .show_init = NULL, + .show_finish = NULL, + + /* libnvme tree print functions */ + .list_item = NULL, + .list_items = NULL, + .print_nvme_subsystem_list = NULL, + .topology_ctrl = NULL, + .topology_namespace = NULL, + + /* status and error messages */ + .connect_msg = NULL, + .show_message = NULL, + .show_perror = NULL, + .show_status = NULL, + .show_error_status = NULL, +}; + +struct print_ops *nvme_get_binary_print_ops(enum nvme_print_flags flags) +{ + binary_print_ops.flags = flags; + return &binary_print_ops; +} |