mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-19 14:03:33 +08:00
441 lines
16 KiB
C
441 lines
16 KiB
C
|
/*
|
||
|
* Copyright (c) 2006-2023, RT-Thread Development Team
|
||
|
*
|
||
|
* SPDX-License-Identifier: Apache-2.0
|
||
|
*
|
||
|
* Change Logs:
|
||
|
* Date Author Notes
|
||
|
* 2023-09-23 GuEe-GUI first version
|
||
|
*/
|
||
|
|
||
|
#ifndef __PCIE_DESIGNWARE_H__
|
||
|
#define __PCIE_DESIGNWARE_H__
|
||
|
|
||
|
#include <rtthread.h>
|
||
|
#include <rtdevice.h>
|
||
|
|
||
|
/* Parameters for the waiting for link up routine */
|
||
|
#define LINK_WAIT_MAX_RETRIES 10
|
||
|
#define LINK_WAIT_USLEEP_MIN 90000
|
||
|
#define LINK_WAIT_USLEEP_MAX 100000
|
||
|
|
||
|
/* Parameters for the waiting for iATU enabled routine */
|
||
|
#define LINK_WAIT_MAX_IATU_RETRIES 5
|
||
|
#define LINK_WAIT_IATU 9
|
||
|
|
||
|
/* Synopsys-specific PCIe configuration registers */
|
||
|
#define PCIE_PORT_AFR 0x70c
|
||
|
#define PORT_AFR_N_FTS_MASK RT_GENMASK(15, 8)
|
||
|
#define PORT_AFR_N_FTS(n) RT_FIELD_PREP(PORT_AFR_N_FTS_MASK, n)
|
||
|
#define PORT_AFR_CC_N_FTS_MASK RT_GENMASK(23, 16)
|
||
|
#define PORT_AFR_CC_N_FTS(n) RT_FIELD_PREP(PORT_AFR_CC_N_FTS_MASK, n)
|
||
|
#define PORT_AFR_ENTER_ASPM RT_BIT(30)
|
||
|
#define PORT_AFR_L0S_ENTRANCE_LAT_SHIFT 24
|
||
|
#define PORT_AFR_L0S_ENTRANCE_LAT_MASK RT_GENMASK(26, 24)
|
||
|
#define PORT_AFR_L1_ENTRANCE_LAT_SHIFT 27
|
||
|
#define PORT_AFR_L1_ENTRANCE_LAT_MASK RT_GENMASK(29, 27)
|
||
|
|
||
|
#define PCIE_PORT_LINK_CONTROL 0x710
|
||
|
#define PORT_LINK_LPBK_ENABLE RT_BIT(2)
|
||
|
#define PORT_LINK_DLL_LINK_EN RT_BIT(5)
|
||
|
#define PORT_LINK_FAST_LINK_MODE RT_BIT(7)
|
||
|
#define PORT_LINK_MODE_MASK RT_GENMASK(21, 16)
|
||
|
#define PORT_LINK_MODE(n) RT_FIELD_PREP(PORT_LINK_MODE_MASK, n)
|
||
|
#define PORT_LINK_MODE_1_LANES PORT_LINK_MODE(0x1)
|
||
|
#define PORT_LINK_MODE_2_LANES PORT_LINK_MODE(0x3)
|
||
|
#define PORT_LINK_MODE_4_LANES PORT_LINK_MODE(0x7)
|
||
|
#define PORT_LINK_MODE_8_LANES PORT_LINK_MODE(0xf)
|
||
|
|
||
|
#define PCIE_PORT_DEBUG0 0x728
|
||
|
#define PORT_LOGIC_LTSSM_STATE_MASK 0x1f
|
||
|
#define PORT_LOGIC_LTSSM_STATE_L0 0x11
|
||
|
#define PCIE_PORT_DEBUG1 0x72c
|
||
|
#define PCIE_PORT_DEBUG1_LINK_UP RT_BIT(4)
|
||
|
#define PCIE_PORT_DEBUG1_LINK_IN_TRAINING RT_BIT(29)
|
||
|
|
||
|
#define PCIE_LINK_WIDTH_SPEED_CONTROL 0x80c
|
||
|
#define PORT_LOGIC_N_FTS_MASK RT_GENMASK(7, 0)
|
||
|
#define PORT_LOGIC_SPEED_CHANGE RT_BIT(17)
|
||
|
#define PORT_LOGIC_LINK_WIDTH_MASK RT_GENMASK(12, 8)
|
||
|
#define PORT_LOGIC_LINK_WIDTH(n) RT_FIELD_PREP(PORT_LOGIC_LINK_WIDTH_MASK, n)
|
||
|
#define PORT_LOGIC_LINK_WIDTH_1_LANES PORT_LOGIC_LINK_WIDTH(0x1)
|
||
|
#define PORT_LOGIC_LINK_WIDTH_2_LANES PORT_LOGIC_LINK_WIDTH(0x2)
|
||
|
#define PORT_LOGIC_LINK_WIDTH_4_LANES PORT_LOGIC_LINK_WIDTH(0x4)
|
||
|
#define PORT_LOGIC_LINK_WIDTH_8_LANES PORT_LOGIC_LINK_WIDTH(0x8)
|
||
|
|
||
|
#define PCIE_MSI_ADDR_LO 0x820
|
||
|
#define PCIE_MSI_ADDR_HI 0x824
|
||
|
#define PCIE_MSI_INTR0_ENABLE 0x828
|
||
|
#define PCIE_MSI_INTR0_MASK 0x82c
|
||
|
#define PCIE_MSI_INTR0_STATUS 0x830
|
||
|
|
||
|
#define PCIE_PORT_MULTI_LANE_CTRL 0x8c0
|
||
|
#define PORT_MLTI_UPCFG_SUPPORT RT_BIT(7)
|
||
|
|
||
|
#define PCIE_ATU_VIEWPORT 0x900
|
||
|
#define PCIE_ATU_REGION_INBOUND RT_BIT(31)
|
||
|
#define PCIE_ATU_REGION_OUTBOUND 0
|
||
|
#define PCIE_ATU_CR1 0x904
|
||
|
#define PCIE_ATU_TYPE_MEM 0x0
|
||
|
#define PCIE_ATU_TYPE_IO 0x2
|
||
|
#define PCIE_ATU_TYPE_CFG0 0x4
|
||
|
#define PCIE_ATU_TYPE_CFG1 0x5
|
||
|
#define PCIE_ATU_FUNC_NUM(pf) ((pf) << 20)
|
||
|
#define PCIE_ATU_CR2 0x908
|
||
|
#define PCIE_ATU_ENABLE RT_BIT(31)
|
||
|
#define PCIE_ATU_BAR_MODE_ENABLE RT_BIT(30)
|
||
|
#define PCIE_ATU_FUNC_NUM_MATCH_EN RT_BIT(19)
|
||
|
#define PCIE_ATU_LOWER_BASE 0x90c
|
||
|
#define PCIE_ATU_UPPER_BASE 0x910
|
||
|
#define PCIE_ATU_LIMIT 0x914
|
||
|
#define PCIE_ATU_LOWER_TARGET 0x918
|
||
|
#define PCIE_ATU_BUS(x) RT_FIELD_PREP(RT_GENMASK(31, 24), x)
|
||
|
#define PCIE_ATU_DEV(x) RT_FIELD_PREP(RT_GENMASK(23, 19), x)
|
||
|
#define PCIE_ATU_FUNC(x) RT_FIELD_PREP(RT_GENMASK(18, 16), x)
|
||
|
#define PCIE_ATU_UPPER_TARGET 0x91c
|
||
|
|
||
|
#define PCIE_MISC_CONTROL_1_OFF 0x8bc
|
||
|
#define PCIE_DBI_RO_WR_EN RT_BIT(0)
|
||
|
|
||
|
#define PCIE_MSIX_DOORBELL 0x948
|
||
|
#define PCIE_MSIX_DOORBELL_PF_SHIFT 24
|
||
|
|
||
|
#define PCIE_PL_CHK_REG_CONTROL_STATUS 0xb20
|
||
|
#define PCIE_PL_CHK_REG_CHK_REG_START RT_BIT(0)
|
||
|
#define PCIE_PL_CHK_REG_CHK_REG_CONTINUOUS RT_BIT(1)
|
||
|
#define PCIE_PL_CHK_REG_CHK_REG_COMPARISON_ERROR RT_BIT(16)
|
||
|
#define PCIE_PL_CHK_REG_CHK_REG_LOGIC_ERROR RT_BIT(17)
|
||
|
#define PCIE_PL_CHK_REG_CHK_REG_COMPLETE RT_BIT(18)
|
||
|
|
||
|
#define PCIE_PL_CHK_REG_ERR_ADDR 0xb28
|
||
|
|
||
|
/*
|
||
|
* iATU Unroll-specific register definitions
|
||
|
* From 4.80 core version the address translation will be made by unroll
|
||
|
*/
|
||
|
#define PCIE_ATU_UNR_REGION_CTRL1 0x00
|
||
|
#define PCIE_ATU_UNR_REGION_CTRL2 0x04
|
||
|
#define PCIE_ATU_UNR_LOWER_BASE 0x08
|
||
|
#define PCIE_ATU_UNR_UPPER_BASE 0x0C
|
||
|
#define PCIE_ATU_UNR_LOWER_LIMIT 0x10
|
||
|
#define PCIE_ATU_UNR_LOWER_TARGET 0x14
|
||
|
#define PCIE_ATU_UNR_UPPER_TARGET 0x18
|
||
|
#define PCIE_ATU_UNR_UPPER_LIMIT 0x20
|
||
|
|
||
|
/*
|
||
|
* The default address offset between dbi_base and atu_base. Root controller
|
||
|
* drivers are not required to initialize atu_base if the offset matches this
|
||
|
* default; the driver core automatically derives atu_base from dbi_base using
|
||
|
* this offset, if atu_base not set.
|
||
|
*/
|
||
|
#define DEFAULT_DBI_ATU_OFFSET (0x3 << 20)
|
||
|
|
||
|
/* Register address builder */
|
||
|
#define PCIE_GET_ATU_OUTB_UNR_REG_OFFSET(region) ((region) << 9)
|
||
|
#define PCIE_GET_ATU_INB_UNR_REG_OFFSET(region) (((region) << 9) | RT_BIT(8))
|
||
|
|
||
|
#define MAX_MSI_IRQS 256
|
||
|
#define MAX_MSI_IRQS_PER_CTRL 32
|
||
|
#define MAX_MSI_CTRLS (MAX_MSI_IRQS / MAX_MSI_IRQS_PER_CTRL)
|
||
|
#define MSI_REG_CTRL_BLOCK_SIZE 12
|
||
|
#define MSI_DEF_NUM_VECTORS 32
|
||
|
|
||
|
/* Maximum number of inbound/outbound iATUs */
|
||
|
#define MAX_IATU_IN 256
|
||
|
#define MAX_IATU_OUT 256
|
||
|
|
||
|
#define DWC_IATU_UNROLL_EN RT_BIT(0)
|
||
|
#define DWC_IATU_IOCFG_SHARED RT_BIT(1)
|
||
|
|
||
|
struct dw_pcie_host_ops;
|
||
|
struct dw_pcie_ep_ops;
|
||
|
struct dw_pcie_ops;
|
||
|
|
||
|
enum dw_pcie_region_type
|
||
|
{
|
||
|
DW_PCIE_REGION_UNKNOWN,
|
||
|
DW_PCIE_REGION_INBOUND,
|
||
|
DW_PCIE_REGION_OUTBOUND,
|
||
|
};
|
||
|
|
||
|
enum dw_pcie_device_mode
|
||
|
{
|
||
|
DW_PCIE_UNKNOWN_TYPE,
|
||
|
DW_PCIE_EP_TYPE,
|
||
|
DW_PCIE_LEG_EP_TYPE,
|
||
|
DW_PCIE_RC_TYPE,
|
||
|
};
|
||
|
|
||
|
enum dw_pcie_aspace_type
|
||
|
{
|
||
|
DW_PCIE_ASPACE_UNKNOWN,
|
||
|
DW_PCIE_ASPACE_MEM,
|
||
|
DW_PCIE_ASPACE_IO,
|
||
|
};
|
||
|
|
||
|
struct dw_pcie_port
|
||
|
{
|
||
|
void *cfg0_base;
|
||
|
rt_uint64_t cfg0_addr;
|
||
|
rt_uint64_t cfg0_size;
|
||
|
|
||
|
rt_ubase_t io_addr;
|
||
|
rt_ubase_t io_bus_addr;
|
||
|
rt_size_t io_size;
|
||
|
|
||
|
const struct dw_pcie_host_ops *ops;
|
||
|
|
||
|
int sys_irq;
|
||
|
int msi_irq;
|
||
|
struct rt_pic *irq_pic;
|
||
|
struct rt_pic *msi_pic;
|
||
|
|
||
|
void *msi_data;
|
||
|
rt_ubase_t msi_data_phy;
|
||
|
|
||
|
rt_uint32_t irq_count;
|
||
|
rt_uint32_t irq_mask[MAX_MSI_CTRLS];
|
||
|
|
||
|
struct rt_pci_host_bridge *bridge;
|
||
|
const struct rt_pci_ops *bridge_child_ops;
|
||
|
|
||
|
struct rt_spinlock lock;
|
||
|
RT_BITMAP_DECLARE(msi_map, MAX_MSI_IRQS);
|
||
|
};
|
||
|
|
||
|
struct dw_pcie_host_ops
|
||
|
{
|
||
|
rt_err_t (*host_init)(struct dw_pcie_port *port);
|
||
|
rt_err_t (*msi_host_init)(struct dw_pcie_port *port);
|
||
|
void (*set_irq_count)(struct dw_pcie_port *port);
|
||
|
};
|
||
|
|
||
|
struct dw_pcie_ep_func
|
||
|
{
|
||
|
rt_list_t list;
|
||
|
|
||
|
rt_uint8_t func_no;
|
||
|
rt_uint8_t msi_cap; /* MSI capability offset */
|
||
|
rt_uint8_t msix_cap; /* MSI-X capability offset */
|
||
|
};
|
||
|
|
||
|
struct dw_pcie_ep
|
||
|
{
|
||
|
struct rt_pci_ep *epc;
|
||
|
struct rt_pci_ep_bar *epc_bar[PCI_STD_NUM_BARS];
|
||
|
|
||
|
rt_list_t func_nodes;
|
||
|
|
||
|
const struct dw_pcie_ep_ops *ops;
|
||
|
|
||
|
rt_uint64_t aspace;
|
||
|
rt_uint64_t aspace_size;
|
||
|
rt_size_t page_size;
|
||
|
|
||
|
rt_uint8_t bar_to_atu[PCI_STD_NUM_BARS];
|
||
|
rt_ubase_t *outbound_addr;
|
||
|
|
||
|
rt_bitmap_t *ib_window_map;
|
||
|
rt_bitmap_t *ob_window_map;
|
||
|
rt_uint32_t num_ib_windows;
|
||
|
rt_uint32_t num_ob_windows;
|
||
|
|
||
|
void *msi_mem;
|
||
|
rt_ubase_t msi_mem_phy;
|
||
|
};
|
||
|
|
||
|
struct dw_pcie_ep_ops
|
||
|
{
|
||
|
rt_err_t (*ep_init)(struct dw_pcie_ep *ep);
|
||
|
rt_err_t (*raise_irq)(struct dw_pcie_ep *ep, rt_uint8_t func_no, enum rt_pci_ep_irq type, unsigned irq);
|
||
|
rt_off_t (*func_select)(struct dw_pcie_ep *ep, rt_uint8_t func_no);
|
||
|
};
|
||
|
|
||
|
struct dw_pcie
|
||
|
{
|
||
|
struct rt_device *dev;
|
||
|
|
||
|
void *dbi_base;
|
||
|
void *dbi_base2;
|
||
|
void *atu_base;
|
||
|
|
||
|
rt_uint32_t version;
|
||
|
rt_uint32_t num_viewport;
|
||
|
rt_uint32_t num_lanes;
|
||
|
rt_uint32_t link_gen;
|
||
|
rt_uint32_t user_speed;
|
||
|
rt_uint8_t iatu_unroll_enabled; /* Internal Address Translation Unit */
|
||
|
rt_uint8_t fts_number[2]; /* Fast Training Sequences */
|
||
|
|
||
|
struct dw_pcie_port port;
|
||
|
struct dw_pcie_ep endpoint;
|
||
|
const struct dw_pcie_ops *ops;
|
||
|
|
||
|
void *priv;
|
||
|
};
|
||
|
|
||
|
struct dw_pcie_ops
|
||
|
{
|
||
|
rt_uint64_t (*cpu_addr_fixup)(struct dw_pcie *pcie, rt_uint64_t cpu_addr);
|
||
|
rt_uint32_t (*read_dbi)(struct dw_pcie *pcie, void *base, rt_uint32_t reg, rt_size_t size);
|
||
|
void (*write_dbi)(struct dw_pcie *pcie, void *base, rt_uint32_t reg, rt_size_t size, rt_uint32_t val);
|
||
|
void (*write_dbi2)(struct dw_pcie *pcie, void *base, rt_uint32_t reg, rt_size_t size, rt_uint32_t val);
|
||
|
rt_bool_t (*link_up)(struct dw_pcie *pcie);
|
||
|
rt_err_t (*start_link)(struct dw_pcie *pcie);
|
||
|
void (*stop_link)(struct dw_pcie *pcie);
|
||
|
};
|
||
|
|
||
|
#define to_dw_pcie_from_port(ptr) rt_container_of((ptr), struct dw_pcie, port)
|
||
|
#define to_dw_pcie_from_endpoint(ptr) rt_container_of((ptr), struct dw_pcie, endpoint)
|
||
|
|
||
|
#ifdef RT_PCI_DW_HOST
|
||
|
#undef RT_PCI_DW_HOST
|
||
|
#define RT_PCI_DW_HOST 1
|
||
|
#define HOST_API
|
||
|
#define HOST_RET(...) ;
|
||
|
#else
|
||
|
#define HOST_API rt_inline
|
||
|
#define HOST_RET(...) { return __VA_ARGS__; }
|
||
|
#endif
|
||
|
|
||
|
#ifdef RT_PCI_DW_EP
|
||
|
#undef RT_PCI_DW_EP
|
||
|
#define RT_PCI_DW_EP 1
|
||
|
#define EP_API
|
||
|
#define EP_RET(...) ;
|
||
|
#else
|
||
|
#define EP_API rt_inline
|
||
|
#define EP_RET(...) { return __VA_ARGS__; }
|
||
|
#endif
|
||
|
|
||
|
rt_uint8_t dw_pcie_find_capability(struct dw_pcie *pci, rt_uint8_t cap);
|
||
|
rt_uint16_t dw_pcie_find_ext_capability(struct dw_pcie *pci, rt_uint8_t cap);
|
||
|
|
||
|
rt_err_t dw_pcie_read(void *addr, rt_size_t size, rt_uint32_t *out_val);
|
||
|
rt_err_t dw_pcie_write(void *addr, rt_size_t size, rt_uint32_t val);
|
||
|
|
||
|
rt_uint32_t dw_pcie_read_dbi(struct dw_pcie *pci, rt_uint32_t reg, rt_size_t size);
|
||
|
void dw_pcie_write_dbi(struct dw_pcie *pci, rt_uint32_t reg, rt_size_t size, rt_uint32_t val);
|
||
|
void dw_pcie_write_dbi2(struct dw_pcie *pci, rt_uint32_t reg, rt_size_t size, rt_uint32_t val);
|
||
|
rt_uint32_t dw_pcie_readl_atu(struct dw_pcie *pci, rt_uint32_t reg);
|
||
|
void dw_pcie_writel_atu(struct dw_pcie *pci, rt_uint32_t reg, rt_uint32_t val);
|
||
|
rt_bool_t dw_pcie_link_up(struct dw_pcie *pci);
|
||
|
void dw_pcie_upconfig_setup(struct dw_pcie *pci);
|
||
|
rt_err_t dw_pcie_wait_for_link(struct dw_pcie *pci);
|
||
|
void dw_pcie_prog_outbound_atu(struct dw_pcie *pci, int index, int type, rt_uint64_t cpu_addr, rt_uint64_t pci_addr, rt_size_t size);
|
||
|
void dw_pcie_prog_ep_outbound_atu(struct dw_pcie *pci, rt_uint8_t func_no, int index, int type, rt_uint64_t cpu_addr, rt_uint64_t pci_addr, rt_size_t size);
|
||
|
rt_err_t dw_pcie_prog_inbound_atu(struct dw_pcie *pci, rt_uint8_t func_no, int index, int bar, rt_uint64_t cpu_addr, enum dw_pcie_aspace_type aspace_type);
|
||
|
void dw_pcie_disable_atu(struct dw_pcie *pci, int index, enum dw_pcie_region_type type);
|
||
|
void dw_pcie_setup(struct dw_pcie *pci);
|
||
|
|
||
|
rt_inline void dw_pcie_writel_dbi(struct dw_pcie *pci, rt_uint32_t reg, rt_uint32_t val)
|
||
|
{
|
||
|
dw_pcie_write_dbi(pci, reg, 0x4, val);
|
||
|
}
|
||
|
|
||
|
rt_inline rt_uint32_t dw_pcie_readl_dbi(struct dw_pcie *pci, rt_uint32_t reg)
|
||
|
{
|
||
|
return dw_pcie_read_dbi(pci, reg, 0x4);
|
||
|
}
|
||
|
|
||
|
rt_inline void dw_pcie_writew_dbi(struct dw_pcie *pci, rt_uint32_t reg, rt_uint16_t val)
|
||
|
{
|
||
|
dw_pcie_write_dbi(pci, reg, 0x2, val);
|
||
|
}
|
||
|
|
||
|
rt_inline rt_uint16_t dw_pcie_readw_dbi(struct dw_pcie *pci, rt_uint32_t reg)
|
||
|
{
|
||
|
return dw_pcie_read_dbi(pci, reg, 0x2);
|
||
|
}
|
||
|
|
||
|
rt_inline void dw_pcie_writeb_dbi(struct dw_pcie *pci, rt_uint32_t reg, rt_uint8_t val)
|
||
|
{
|
||
|
dw_pcie_write_dbi(pci, reg, 0x1, val);
|
||
|
}
|
||
|
|
||
|
rt_inline rt_uint8_t dw_pcie_readb_dbi(struct dw_pcie *pci, rt_uint32_t reg)
|
||
|
{
|
||
|
return dw_pcie_read_dbi(pci, reg, 0x1);
|
||
|
}
|
||
|
|
||
|
rt_inline void dw_pcie_writel_dbi2(struct dw_pcie *pci, rt_uint32_t reg, rt_uint32_t val)
|
||
|
{
|
||
|
dw_pcie_write_dbi2(pci, reg, 0x4, val);
|
||
|
}
|
||
|
|
||
|
rt_inline void dw_pcie_dbi_ro_writable_enable(struct dw_pcie *pci, rt_bool_t enable)
|
||
|
{
|
||
|
const rt_uint32_t reg = PCIE_MISC_CONTROL_1_OFF;
|
||
|
|
||
|
if (enable)
|
||
|
{
|
||
|
dw_pcie_writel_dbi(pci, reg, dw_pcie_readl_dbi(pci, reg) | PCIE_DBI_RO_WR_EN);
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
dw_pcie_writel_dbi(pci, reg, dw_pcie_readl_dbi(pci, reg) & ~PCIE_DBI_RO_WR_EN);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
rt_inline rt_uint8_t dw_pcie_iatu_unroll_enabled(struct dw_pcie *pci)
|
||
|
{
|
||
|
return dw_pcie_readl_dbi(pci, PCIE_ATU_VIEWPORT) == 0xffffffff ? 1 : 0;
|
||
|
}
|
||
|
|
||
|
rt_inline rt_uint32_t dw_pcie_readl_ob_unroll(struct dw_pcie *pci,
|
||
|
rt_uint32_t index, rt_uint32_t reg)
|
||
|
{
|
||
|
return dw_pcie_readl_atu(pci, PCIE_GET_ATU_OUTB_UNR_REG_OFFSET(index) + reg);
|
||
|
}
|
||
|
|
||
|
rt_inline void dw_pcie_writel_ob_unroll(struct dw_pcie *pci,
|
||
|
rt_uint32_t index, rt_uint32_t reg, rt_uint32_t val)
|
||
|
{
|
||
|
dw_pcie_writel_atu(pci, PCIE_GET_ATU_OUTB_UNR_REG_OFFSET(index) + reg, val);
|
||
|
}
|
||
|
|
||
|
rt_inline rt_uint32_t dw_pcie_readl_ib_unroll(struct dw_pcie *pci,
|
||
|
rt_uint32_t index, rt_uint32_t reg)
|
||
|
{
|
||
|
return dw_pcie_readl_atu(pci, PCIE_GET_ATU_INB_UNR_REG_OFFSET(index) + reg);
|
||
|
}
|
||
|
|
||
|
rt_inline void dw_pcie_writel_ib_unroll(struct dw_pcie *pci,
|
||
|
rt_uint32_t index, rt_uint32_t reg, rt_uint32_t val)
|
||
|
{
|
||
|
dw_pcie_writel_atu(pci, reg + PCIE_GET_ATU_INB_UNR_REG_OFFSET(index), val);
|
||
|
}
|
||
|
|
||
|
HOST_API rt_err_t dw_handle_msi_irq(struct dw_pcie_port *port) HOST_RET(-RT_ENOSYS)
|
||
|
HOST_API void dw_pcie_msi_init(struct dw_pcie_port *port) HOST_RET()
|
||
|
HOST_API void dw_pcie_free_msi(struct dw_pcie_port *port) HOST_RET()
|
||
|
|
||
|
HOST_API void dw_pcie_setup_rc(struct dw_pcie_port *port) HOST_RET()
|
||
|
|
||
|
HOST_API rt_err_t dw_pcie_host_init(struct dw_pcie_port *port) HOST_RET(-RT_ENOSYS)
|
||
|
HOST_API void dw_pcie_host_deinit(struct dw_pcie_port *port) HOST_RET()
|
||
|
|
||
|
HOST_API void dw_pcie_host_free(struct dw_pcie_port *port) HOST_RET()
|
||
|
|
||
|
HOST_API void *dw_pcie_own_conf_map(struct rt_pci_bus *bus, rt_uint32_t devfn, int reg) HOST_RET(RT_NULL)
|
||
|
|
||
|
EP_API rt_err_t dw_pcie_ep_init(struct dw_pcie_ep *ep) EP_RET(-RT_ENOSYS)
|
||
|
EP_API rt_err_t dw_pcie_ep_init_complete(struct dw_pcie_ep *ep) EP_RET(-RT_ENOSYS)
|
||
|
EP_API void dw_pcie_ep_exit(struct dw_pcie_ep *ep) EP_RET()
|
||
|
|
||
|
EP_API rt_err_t dw_pcie_ep_raise_legacy_irq(struct dw_pcie_ep *ep, rt_uint8_t func_no) EP_RET(-RT_ENOSYS)
|
||
|
EP_API rt_err_t dw_pcie_ep_raise_msi_irq(struct dw_pcie_ep *ep, rt_uint8_t func_no, unsigned irq) EP_RET(-RT_ENOSYS)
|
||
|
EP_API rt_err_t dw_pcie_ep_raise_msix_irq(struct dw_pcie_ep *ep, rt_uint8_t func_no, unsigned irq) EP_RET(-RT_ENOSYS)
|
||
|
EP_API rt_err_t dw_pcie_ep_raise_msix_irq_doorbell(struct dw_pcie_ep *ep, rt_uint8_t func_no, unsigned irq) EP_RET(-RT_ENOSYS)
|
||
|
|
||
|
EP_API void dw_pcie_ep_reset_bar(struct dw_pcie *pci, int bar_idx) EP_RET()
|
||
|
|
||
|
EP_API rt_err_t dw_pcie_ep_inbound_atu(struct dw_pcie_ep *ep, rt_uint8_t func_no,
|
||
|
int bar_idx, rt_ubase_t cpu_addr, enum dw_pcie_aspace_type aspace_type) EP_RET(-RT_ENOSYS)
|
||
|
EP_API rt_err_t dw_pcie_ep_outbound_atu(struct dw_pcie_ep *ep, rt_uint8_t func_no,
|
||
|
rt_ubase_t phys_addr, rt_uint64_t pci_addr, rt_size_t size) EP_RET(-RT_ENOSYS)
|
||
|
|
||
|
EP_API struct dw_pcie_ep_func *dw_pcie_ep_get_func_from_ep(struct dw_pcie_ep *ep, rt_uint8_t func_no) EP_RET()
|
||
|
|
||
|
#endif /* __PCIE_DESIGNWARE_H__ */
|