xref: /linux/drivers/cxl/core/core.h (revision 919464deeca24e5bf13b6c8efd0b1d25cc43866f)
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /* Copyright(c) 2020 Intel Corporation. */
3 
4 #ifndef __CXL_CORE_H__
5 #define __CXL_CORE_H__
6 
7 extern const struct device_type cxl_nvdimm_bridge_type;
8 extern const struct device_type cxl_nvdimm_type;
9 extern const struct device_type cxl_pmu_type;
10 
11 extern struct attribute_group cxl_base_attribute_group;
12 
13 #ifdef CONFIG_CXL_REGION
14 extern struct device_attribute dev_attr_create_pmem_region;
15 extern struct device_attribute dev_attr_create_ram_region;
16 extern struct device_attribute dev_attr_delete_region;
17 extern struct device_attribute dev_attr_region;
18 extern const struct device_type cxl_pmem_region_type;
19 extern const struct device_type cxl_dax_region_type;
20 extern const struct device_type cxl_region_type;
21 void cxl_decoder_kill_region(struct cxl_endpoint_decoder *cxled);
22 #define CXL_REGION_ATTR(x) (&dev_attr_##x.attr)
23 #define CXL_REGION_TYPE(x) (&cxl_region_type)
24 #define SET_CXL_REGION_ATTR(x) (&dev_attr_##x.attr),
25 #define CXL_PMEM_REGION_TYPE(x) (&cxl_pmem_region_type)
26 #define CXL_DAX_REGION_TYPE(x) (&cxl_dax_region_type)
27 int cxl_region_init(void);
28 void cxl_region_exit(void);
29 int cxl_get_poison_by_endpoint(struct cxl_port *port);
30 struct cxl_region *cxl_dpa_to_region(const struct cxl_memdev *cxlmd, u64 dpa);
31 u64 cxl_dpa_to_hpa(struct cxl_region *cxlr, const struct cxl_memdev *cxlmd,
32 		   u64 dpa);
33 
34 #else
35 static inline u64 cxl_dpa_to_hpa(struct cxl_region *cxlr,
36 				 const struct cxl_memdev *cxlmd, u64 dpa)
37 {
38 	return ULLONG_MAX;
39 }
40 static inline
41 struct cxl_region *cxl_dpa_to_region(const struct cxl_memdev *cxlmd, u64 dpa)
42 {
43 	return NULL;
44 }
45 static inline int cxl_get_poison_by_endpoint(struct cxl_port *port)
46 {
47 	return 0;
48 }
49 static inline void cxl_decoder_kill_region(struct cxl_endpoint_decoder *cxled)
50 {
51 }
52 static inline int cxl_region_init(void)
53 {
54 	return 0;
55 }
56 static inline void cxl_region_exit(void)
57 {
58 }
59 #define CXL_REGION_ATTR(x) NULL
60 #define CXL_REGION_TYPE(x) NULL
61 #define SET_CXL_REGION_ATTR(x)
62 #define CXL_PMEM_REGION_TYPE(x) NULL
63 #define CXL_DAX_REGION_TYPE(x) NULL
64 #endif
65 
66 struct cxl_send_command;
67 struct cxl_mem_query_commands;
68 int cxl_query_cmd(struct cxl_memdev *cxlmd,
69 		  struct cxl_mem_query_commands __user *q);
70 int cxl_send_cmd(struct cxl_memdev *cxlmd, struct cxl_send_command __user *s);
71 void __iomem *devm_cxl_iomap_block(struct device *dev, resource_size_t addr,
72 				   resource_size_t length);
73 
74 struct dentry *cxl_debugfs_create_dir(const char *dir);
75 int cxl_dpa_set_mode(struct cxl_endpoint_decoder *cxled,
76 		     enum cxl_decoder_mode mode);
77 int cxl_dpa_alloc(struct cxl_endpoint_decoder *cxled, unsigned long long size);
78 int cxl_dpa_free(struct cxl_endpoint_decoder *cxled);
79 resource_size_t cxl_dpa_size(struct cxl_endpoint_decoder *cxled);
80 resource_size_t cxl_dpa_resource_start(struct cxl_endpoint_decoder *cxled);
81 
82 enum cxl_rcrb {
83 	CXL_RCRB_DOWNSTREAM,
84 	CXL_RCRB_UPSTREAM,
85 };
86 struct cxl_rcrb_info;
87 resource_size_t __rcrb_to_component(struct device *dev,
88 				    struct cxl_rcrb_info *ri,
89 				    enum cxl_rcrb which);
90 u16 cxl_rcrb_to_aer(struct device *dev, resource_size_t rcrb);
91 
92 #define PCI_RCRB_CAP_LIST_ID_MASK	GENMASK(7, 0)
93 #define PCI_RCRB_CAP_HDR_ID_MASK	GENMASK(7, 0)
94 #define PCI_RCRB_CAP_HDR_NEXT_MASK	GENMASK(15, 8)
95 #define PCI_CAP_EXP_SIZEOF		0x3c
96 
97 extern struct rw_semaphore cxl_dpa_rwsem;
98 extern struct rw_semaphore cxl_region_rwsem;
99 
100 int cxl_memdev_init(void);
101 void cxl_memdev_exit(void);
102 void cxl_mbox_init(void);
103 
104 enum cxl_poison_trace_type {
105 	CXL_POISON_TRACE_LIST,
106 	CXL_POISON_TRACE_INJECT,
107 	CXL_POISON_TRACE_CLEAR,
108 };
109 
110 long cxl_pci_get_latency(struct pci_dev *pdev);
111 int cxl_pci_get_bandwidth(struct pci_dev *pdev, struct access_coordinate *c);
112 int cxl_update_hmat_access_coordinates(int nid, struct cxl_region *cxlr,
113 				       enum access_coordinate_class access);
114 bool cxl_need_node_perf_attrs_update(int nid);
115 int cxl_port_get_switch_dport_bandwidth(struct cxl_port *port,
116 					struct access_coordinate *c);
117 
118 #endif /* __CXL_CORE_H__ */
119