// SPDX-License-Identifier: GPL-2.0 /* * PCI Endpoint *Controller* Address Space Management * * Copyright (C) 2017 Texas Instruments * Author: Kishon Vijay Abraham I <[email protected]> */ #include <linux/io.h> #include <linux/module.h> #include <linux/slab.h> #include <linux/pci-epc.h> /** * pci_epc_mem_get_order() - determine the allocation order of a memory size * @mem: address space of the endpoint controller * @size: the size for which to get the order * * Reimplement get_order() for mem->page_size since the generic get_order * always gets order with a constant PAGE_SIZE. */ static int pci_epc_mem_get_order(struct pci_epc_mem *mem, size_t size) { … } /** * pci_epc_multi_mem_init() - initialize the pci_epc_mem structure * @epc: the EPC device that invoked pci_epc_mem_init * @windows: pointer to windows supported by the device * @num_windows: number of windows device supports * * Invoke to initialize the pci_epc_mem structure used by the * endpoint functions to allocate mapped PCI address. */ int pci_epc_multi_mem_init(struct pci_epc *epc, struct pci_epc_mem_window *windows, unsigned int num_windows) { … } EXPORT_SYMBOL_GPL(…); /** * pci_epc_mem_init() - Initialize the pci_epc_mem structure * @epc: the EPC device that invoked pci_epc_mem_init * @base: Physical address of the window region * @size: Total Size of the window region * @page_size: Page size of the window region * * Invoke to initialize a single pci_epc_mem structure used by the * endpoint functions to allocate memory for mapping the PCI host memory */ int pci_epc_mem_init(struct pci_epc *epc, phys_addr_t base, size_t size, size_t page_size) { … } EXPORT_SYMBOL_GPL(…); /** * pci_epc_mem_exit() - cleanup the pci_epc_mem structure * @epc: the EPC device that invoked pci_epc_mem_exit * * Invoke to cleanup the pci_epc_mem structure allocated in * pci_epc_mem_init(). */ void pci_epc_mem_exit(struct pci_epc *epc) { … } EXPORT_SYMBOL_GPL(…); /** * pci_epc_mem_alloc_addr() - allocate memory address from EPC addr space * @epc: the EPC device on which memory has to be allocated * @phys_addr: populate the allocated physical address here * @size: the size of the address space that has to be allocated * * Invoke to allocate memory address from the EPC address space. This * is usually done to map the remote RC address into the local system. */ void __iomem *pci_epc_mem_alloc_addr(struct pci_epc *epc, phys_addr_t *phys_addr, size_t size) { … } EXPORT_SYMBOL_GPL(…); static struct pci_epc_mem *pci_epc_get_matching_window(struct pci_epc *epc, phys_addr_t phys_addr) { … } /** * pci_epc_mem_free_addr() - free the allocated memory address * @epc: the EPC device on which memory was allocated * @phys_addr: the allocated physical address * @virt_addr: virtual address of the allocated mem space * @size: the size of the allocated address space * * Invoke to free the memory allocated using pci_epc_mem_alloc_addr. */ void pci_epc_mem_free_addr(struct pci_epc *epc, phys_addr_t phys_addr, void __iomem *virt_addr, size_t size) { … } EXPORT_SYMBOL_GPL(…); MODULE_DESCRIPTION(…) …; MODULE_AUTHOR(…) …;