162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-or-later */
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * CXL Flash Device Driver
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * Written by: Matthew R. Ochs <mrochs@linux.vnet.ibm.com>, IBM Corporation
662306a36Sopenharmony_ci *	       Uma Krishnan <ukrishn@linux.vnet.ibm.com>, IBM Corporation
762306a36Sopenharmony_ci *
862306a36Sopenharmony_ci * Copyright (C) 2018 IBM Corporation
962306a36Sopenharmony_ci */
1062306a36Sopenharmony_ci
1162306a36Sopenharmony_ci#define OCXL_MAX_IRQS	4	/* Max interrupts per process */
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_cistruct ocxlflash_irqs {
1462306a36Sopenharmony_ci	int hwirq;
1562306a36Sopenharmony_ci	u32 virq;
1662306a36Sopenharmony_ci	void __iomem *vtrig;
1762306a36Sopenharmony_ci};
1862306a36Sopenharmony_ci
1962306a36Sopenharmony_ci/* OCXL hardware AFU associated with the host */
2062306a36Sopenharmony_cistruct ocxl_hw_afu {
2162306a36Sopenharmony_ci	struct ocxlflash_context *ocxl_ctx; /* Host context */
2262306a36Sopenharmony_ci	struct pci_dev *pdev;		/* PCI device */
2362306a36Sopenharmony_ci	struct device *dev;		/* Generic device */
2462306a36Sopenharmony_ci	bool perst_same_image;		/* Same image loaded on perst */
2562306a36Sopenharmony_ci
2662306a36Sopenharmony_ci	struct ocxl_fn_config fcfg;	/* DVSEC config of the function */
2762306a36Sopenharmony_ci	struct ocxl_afu_config acfg;	/* AFU configuration data */
2862306a36Sopenharmony_ci
2962306a36Sopenharmony_ci	int fn_actag_base;		/* Function acTag base */
3062306a36Sopenharmony_ci	int fn_actag_enabled;		/* Function acTag number enabled */
3162306a36Sopenharmony_ci	int afu_actag_base;		/* AFU acTag base */
3262306a36Sopenharmony_ci	int afu_actag_enabled;		/* AFU acTag number enabled */
3362306a36Sopenharmony_ci
3462306a36Sopenharmony_ci	phys_addr_t ppmmio_phys;	/* Per process MMIO space */
3562306a36Sopenharmony_ci	phys_addr_t gmmio_phys;		/* Global AFU MMIO space */
3662306a36Sopenharmony_ci	void __iomem *gmmio_virt;	/* Global MMIO map */
3762306a36Sopenharmony_ci
3862306a36Sopenharmony_ci	void *link_token;		/* Link token for the SPA */
3962306a36Sopenharmony_ci	struct idr idr;			/* IDR to manage contexts */
4062306a36Sopenharmony_ci	int max_pasid;			/* Maximum number of contexts */
4162306a36Sopenharmony_ci	bool is_present;		/* Function has AFUs defined */
4262306a36Sopenharmony_ci};
4362306a36Sopenharmony_ci
4462306a36Sopenharmony_cienum ocxlflash_ctx_state {
4562306a36Sopenharmony_ci	CLOSED,
4662306a36Sopenharmony_ci	OPENED,
4762306a36Sopenharmony_ci	STARTED
4862306a36Sopenharmony_ci};
4962306a36Sopenharmony_ci
5062306a36Sopenharmony_cistruct ocxlflash_context {
5162306a36Sopenharmony_ci	struct ocxl_hw_afu *hw_afu;	/* HW AFU back pointer */
5262306a36Sopenharmony_ci	struct address_space *mapping;	/* Mapping for pseudo filesystem */
5362306a36Sopenharmony_ci	bool master;			/* Whether this is a master context */
5462306a36Sopenharmony_ci	int pe;				/* Process element */
5562306a36Sopenharmony_ci
5662306a36Sopenharmony_ci	phys_addr_t psn_phys;		/* Process mapping */
5762306a36Sopenharmony_ci	u64 psn_size;			/* Process mapping size */
5862306a36Sopenharmony_ci
5962306a36Sopenharmony_ci	spinlock_t slock;		/* Protects irq/fault/event updates */
6062306a36Sopenharmony_ci	wait_queue_head_t wq;		/* Wait queue for poll and interrupts */
6162306a36Sopenharmony_ci	struct mutex state_mutex;	/* Mutex to update context state */
6262306a36Sopenharmony_ci	enum ocxlflash_ctx_state state;	/* Context state */
6362306a36Sopenharmony_ci
6462306a36Sopenharmony_ci	struct ocxlflash_irqs *irqs;	/* Pointer to array of structures */
6562306a36Sopenharmony_ci	int num_irqs;			/* Number of interrupts */
6662306a36Sopenharmony_ci	bool pending_irq;		/* Pending interrupt on the context */
6762306a36Sopenharmony_ci	ulong irq_bitmap;		/* Bits indicating pending irq num */
6862306a36Sopenharmony_ci
6962306a36Sopenharmony_ci	u64 fault_addr;			/* Address that triggered the fault */
7062306a36Sopenharmony_ci	u64 fault_dsisr;		/* Value of dsisr register at fault */
7162306a36Sopenharmony_ci	bool pending_fault;		/* Pending translation fault */
7262306a36Sopenharmony_ci};
73