#include <linux/unaligned.h>
#include <linux/io-64-nonatomic-lo-hi.h>
#include <linux/moduleparam.h>
#include <linux/module.h>
#include <linux/delay.h>
#include <linux/sizes.h>
#include <linux/mutex.h>
#include <linux/list.h>
#include <linux/pci.h>
#include <linux/aer.h>
#include <linux/io.h>
#include <cxl/mailbox.h>
#include "cxlmem.h"
#include "cxlpci.h"
#include "cxl.h"
#include "pmu.h"
#define cxl_doorbell_busy(cxlds) …
#define CXL_MAILBOX_TIMEOUT_MS …
static unsigned short mbox_ready_timeout = …;
module_param(mbox_ready_timeout, ushort, 0644);
MODULE_PARM_DESC(…) …;
static int cxl_pci_mbox_wait_for_doorbell(struct cxl_dev_state *cxlds)
{ … }
#define cxl_err(dev, status, msg) …
#define cxl_cmd_err(dev, cmd, status, msg) …
struct cxl_dev_id { … };
static int cxl_request_irq(struct cxl_dev_state *cxlds, int irq,
irq_handler_t thread_fn)
{ … }
static bool cxl_mbox_background_complete(struct cxl_dev_state *cxlds)
{ … }
static irqreturn_t cxl_pci_mbox_irq(int irq, void *id)
{ … }
static void cxl_mbox_sanitize_work(struct work_struct *work)
{ … }
static int __cxl_pci_mbox_send_cmd(struct cxl_mailbox *cxl_mbox,
struct cxl_mbox_cmd *mbox_cmd)
{ … }
static int cxl_pci_mbox_send(struct cxl_mailbox *cxl_mbox,
struct cxl_mbox_cmd *cmd)
{ … }
static int cxl_pci_setup_mailbox(struct cxl_memdev_state *mds, bool irq_avail)
{ … }
static bool is_cxl_restricted(struct pci_dev *pdev)
{ … }
static int cxl_rcrb_get_comp_regs(struct pci_dev *pdev,
struct cxl_register_map *map)
{ … }
static int cxl_pci_setup_regs(struct pci_dev *pdev, enum cxl_regloc_type type,
struct cxl_register_map *map)
{ … }
static int cxl_pci_ras_unmask(struct pci_dev *pdev)
{ … }
static void free_event_buf(void *buf)
{ … }
static int cxl_mem_alloc_event_buf(struct cxl_memdev_state *mds)
{ … }
static bool cxl_alloc_irq_vectors(struct pci_dev *pdev)
{ … }
static irqreturn_t cxl_event_thread(int irq, void *id)
{ … }
static int cxl_event_req_irq(struct cxl_dev_state *cxlds, u8 setting)
{ … }
static int cxl_event_get_int_policy(struct cxl_memdev_state *mds,
struct cxl_event_interrupt_policy *policy)
{ … }
static int cxl_event_config_msgnums(struct cxl_memdev_state *mds,
struct cxl_event_interrupt_policy *policy)
{ … }
static int cxl_event_irqsetup(struct cxl_memdev_state *mds)
{ … }
static bool cxl_event_int_is_fw(u8 setting)
{ … }
static int cxl_event_config(struct pci_host_bridge *host_bridge,
struct cxl_memdev_state *mds, bool irq_avail)
{ … }
static int cxl_pci_type3_init_mailbox(struct cxl_dev_state *cxlds)
{ … }
static int cxl_pci_probe(struct pci_dev *pdev, const struct pci_device_id *id)
{ … }
static const struct pci_device_id cxl_mem_pci_tbl[] = …;
MODULE_DEVICE_TABLE(pci, cxl_mem_pci_tbl);
static pci_ers_result_t cxl_slot_reset(struct pci_dev *pdev)
{ … }
static void cxl_error_resume(struct pci_dev *pdev)
{ … }
static void cxl_reset_done(struct pci_dev *pdev)
{ … }
static const struct pci_error_handlers cxl_error_handlers = …;
static struct pci_driver cxl_pci_driver = …;
#define CXL_EVENT_HDR_FLAGS_REC_SEVERITY …
static void cxl_handle_cper_event(enum cxl_event_type ev_type,
struct cxl_cper_event_rec *rec)
{ … }
static void cxl_cper_work_fn(struct work_struct *work)
{ … }
static DECLARE_WORK(cxl_cper_work, cxl_cper_work_fn);
static int __init cxl_pci_driver_init(void)
{ … }
static void __exit cxl_pci_driver_exit(void)
{ … }
module_init(…) …;
module_exit(cxl_pci_driver_exit);
MODULE_DESCRIPTION(…) …;
MODULE_LICENSE(…) …;
MODULE_IMPORT_NS(…);