Author | Tokens | Token Proportion | Commits | Commit Proportion |
---|---|---|---|---|
Dan J Williams | 354 | 37.54% | 11 | 52.38% |
Arnd Bergmann | 215 | 22.80% | 1 | 4.76% |
Dave Jiang | 176 | 18.66% | 3 | 14.29% |
Yasunori Goto | 147 | 15.59% | 1 | 4.76% |
Vishal Verma | 39 | 4.14% | 1 | 4.76% |
Andy Shevchenko | 4 | 0.42% | 1 | 4.76% |
Gustavo A. R. Silva | 3 | 0.32% | 1 | 4.76% |
Nathan Chancellor | 3 | 0.32% | 1 | 4.76% |
Thomas Gleixner | 2 | 0.21% | 1 | 4.76% |
Total | 943 | 21 |
/* SPDX-License-Identifier: GPL-2.0-only */ /* * Copyright(c) 2013-2015 Intel Corporation. All rights reserved. */ #ifndef __NFIT_TEST_H__ #define __NFIT_TEST_H__ #include <linux/acpi.h> #include <linux/list.h> #include <linux/uuid.h> #include <linux/ioport.h> #include <linux/spinlock_types.h> struct nfit_test_request { struct list_head list; struct resource res; }; struct nfit_test_resource { struct list_head requests; struct list_head list; struct resource res; struct device *dev; spinlock_t lock; int req_count; void *buf; }; #define ND_TRANSLATE_SPA_STATUS_INVALID_SPA 2 #define NFIT_ARS_INJECT_INVALID 2 enum err_inj_options { ND_ARS_ERR_INJ_OPT_NOTIFY = 0, }; /* nfit commands */ enum nfit_cmd_num { NFIT_CMD_TRANSLATE_SPA = 5, NFIT_CMD_ARS_INJECT_SET = 7, NFIT_CMD_ARS_INJECT_CLEAR = 8, NFIT_CMD_ARS_INJECT_GET = 9, }; struct nd_cmd_translate_spa { __u64 spa; __u32 status; __u8 flags; __u8 _reserved[3]; __u64 translate_length; __u32 num_nvdimms; struct nd_nvdimm_device { __u32 nfit_device_handle; __u32 _reserved; __u64 dpa; } __packed devices[]; } __packed; struct nd_cmd_ars_err_inj { __u64 err_inj_spa_range_base; __u64 err_inj_spa_range_length; __u8 err_inj_options; __u32 status; } __packed; struct nd_cmd_ars_err_inj_clr { __u64 err_inj_clr_spa_range_base; __u64 err_inj_clr_spa_range_length; __u32 status; } __packed; struct nd_cmd_ars_err_inj_stat { __u32 status; __u32 inj_err_rec_count; struct nd_error_stat_query_record { __u64 err_inj_stat_spa_range_base; __u64 err_inj_stat_spa_range_length; } __packed record[]; } __packed; #define ND_INTEL_SMART 1 #define ND_INTEL_SMART_THRESHOLD 2 #define ND_INTEL_ENABLE_LSS_STATUS 10 #define ND_INTEL_FW_GET_INFO 12 #define ND_INTEL_FW_START_UPDATE 13 #define ND_INTEL_FW_SEND_DATA 14 #define ND_INTEL_FW_FINISH_UPDATE 15 #define ND_INTEL_FW_FINISH_QUERY 16 #define ND_INTEL_SMART_SET_THRESHOLD 17 #define ND_INTEL_SMART_INJECT 18 #define ND_INTEL_SMART_HEALTH_VALID (1 << 0) #define ND_INTEL_SMART_SPARES_VALID (1 << 1) #define ND_INTEL_SMART_USED_VALID (1 << 2) #define ND_INTEL_SMART_MTEMP_VALID (1 << 3) #define ND_INTEL_SMART_CTEMP_VALID (1 << 4) #define ND_INTEL_SMART_SHUTDOWN_COUNT_VALID (1 << 5) #define ND_INTEL_SMART_AIT_STATUS_VALID (1 << 6) #define ND_INTEL_SMART_PTEMP_VALID (1 << 7) #define ND_INTEL_SMART_ALARM_VALID (1 << 9) #define ND_INTEL_SMART_SHUTDOWN_VALID (1 << 10) #define ND_INTEL_SMART_VENDOR_VALID (1 << 11) #define ND_INTEL_SMART_SPARE_TRIP (1 << 0) #define ND_INTEL_SMART_TEMP_TRIP (1 << 1) #define ND_INTEL_SMART_CTEMP_TRIP (1 << 2) #define ND_INTEL_SMART_NON_CRITICAL_HEALTH (1 << 0) #define ND_INTEL_SMART_CRITICAL_HEALTH (1 << 1) #define ND_INTEL_SMART_FATAL_HEALTH (1 << 2) #define ND_INTEL_SMART_INJECT_MTEMP (1 << 0) #define ND_INTEL_SMART_INJECT_SPARE (1 << 1) #define ND_INTEL_SMART_INJECT_FATAL (1 << 2) #define ND_INTEL_SMART_INJECT_SHUTDOWN (1 << 3) struct nd_intel_smart_threshold { __u32 status; union { struct { __u16 alarm_control; __u8 spares; __u16 media_temperature; __u16 ctrl_temperature; __u8 reserved[1]; } __packed; __u8 data[8]; }; } __packed; struct nd_intel_smart_set_threshold { __u16 alarm_control; __u8 spares; __u16 media_temperature; __u16 ctrl_temperature; __u32 status; } __packed; struct nd_intel_smart_inject { __u64 flags; __u8 mtemp_enable; __u16 media_temperature; __u8 spare_enable; __u8 spares; __u8 fatal_enable; __u8 unsafe_shutdown_enable; __u32 status; } __packed; #define INTEL_FW_STORAGE_SIZE 0x100000 #define INTEL_FW_MAX_SEND_LEN 0xFFEC #define INTEL_FW_QUERY_INTERVAL 250000 #define INTEL_FW_QUERY_MAX_TIME 3000000 #define INTEL_FW_FIS_VERSION 0x0105 #define INTEL_FW_FAKE_VERSION 0xffffffffabcd enum intel_fw_update_state { FW_STATE_NEW = 0, FW_STATE_IN_PROGRESS, FW_STATE_VERIFY, FW_STATE_UPDATED, }; struct nd_intel_fw_info { __u32 status; __u32 storage_size; __u32 max_send_len; __u32 query_interval; __u32 max_query_time; __u8 update_cap; __u8 reserved[3]; __u32 fis_version; __u64 run_version; __u64 updated_version; } __packed; struct nd_intel_fw_start { __u32 status; __u32 context; } __packed; /* this one has the output first because the variable input data size */ struct nd_intel_fw_send_data { __u32 context; __u32 offset; __u32 length; __u8 data[]; /* this field is not declared due ot variable data from input */ /* __u32 status; */ } __packed; struct nd_intel_fw_finish_update { __u8 ctrl_flags; __u8 reserved[3]; __u32 context; __u32 status; } __packed; struct nd_intel_fw_finish_query { __u32 context; __u32 status; __u64 updated_fw_rev; } __packed; struct nd_intel_lss { __u8 enable; __u32 status; } __packed; typedef struct nfit_test_resource *(*nfit_test_lookup_fn)(resource_size_t); typedef union acpi_object *(*nfit_test_evaluate_dsm_fn)(acpi_handle handle, const guid_t *guid, u64 rev, u64 func, union acpi_object *argv4); void __iomem *__wrap_devm_ioremap(struct device *dev, resource_size_t offset, unsigned long size); void *__wrap_devm_memremap(struct device *dev, resource_size_t offset, size_t size, unsigned long flags); void *__wrap_devm_memremap_pages(struct device *dev, struct dev_pagemap *pgmap); pfn_t __wrap_phys_to_pfn_t(phys_addr_t addr, unsigned long flags); void *__wrap_memremap(resource_size_t offset, size_t size, unsigned long flags); void __wrap_devm_memunmap(struct device *dev, void *addr); void __iomem *__wrap_ioremap(resource_size_t offset, unsigned long size); void __iomem *__wrap_ioremap_wc(resource_size_t offset, unsigned long size); void __wrap_iounmap(volatile void __iomem *addr); void __wrap_memunmap(void *addr); struct resource *__wrap___request_region(struct resource *parent, resource_size_t start, resource_size_t n, const char *name, int flags); int __wrap_insert_resource(struct resource *parent, struct resource *res); int __wrap_remove_resource(struct resource *res); struct resource *__wrap___devm_request_region(struct device *dev, struct resource *parent, resource_size_t start, resource_size_t n, const char *name); void __wrap___release_region(struct resource *parent, resource_size_t start, resource_size_t n); void __wrap___devm_release_region(struct device *dev, struct resource *parent, resource_size_t start, resource_size_t n); acpi_status __wrap_acpi_evaluate_object(acpi_handle handle, acpi_string path, struct acpi_object_list *p, struct acpi_buffer *buf); union acpi_object * __wrap_acpi_evaluate_dsm(acpi_handle handle, const guid_t *guid, u64 rev, u64 func, union acpi_object *argv4); void nfit_test_setup(nfit_test_lookup_fn lookup, nfit_test_evaluate_dsm_fn evaluate); void nfit_test_teardown(void); struct nfit_test_resource *get_nfit_res(resource_size_t resource); #endif
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with Cregit http://github.com/cregit/cregit
Version 2.0-RC1