QE/U-QE: Add U-QE support
Modify code to adapt to both u-qe and qe. U_QE is a kind of cutted QE. the differences between U_QE and QE 1. UCC: U_QE supports 2 UCCs while QE supports up to 8 UCCs. 2. IMMR: have different immr base addr. 3. iopin: U_QE doesn't need to config iopin. Signed-off-by: Zhao Qiang <B45475@freescale.com> Reviewed-by: York Sun <yorksun@freescale.com>
This commit is contained in:
parent
dcf1d774bf
commit
2a44efeb21
@ -33,6 +33,9 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "../../../../drivers/block/fsl_sata.h"
|
#include "../../../../drivers/block/fsl_sata.h"
|
||||||
|
#ifdef CONFIG_U_QE
|
||||||
|
#include "../../../../drivers/qe/qe.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
DECLARE_GLOBAL_DATA_PTR;
|
DECLARE_GLOBAL_DATA_PTR;
|
||||||
|
|
||||||
@ -84,7 +87,7 @@ void fsl_erratum_a006261_workaround(struct ccsr_usb_phy __iomem *usb_phy)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#ifdef CONFIG_QE
|
#if defined(CONFIG_QE) && !defined(CONFIG_U_QE)
|
||||||
extern qe_iop_conf_t qe_iop_conf_tab[];
|
extern qe_iop_conf_t qe_iop_conf_tab[];
|
||||||
extern void qe_config_iopin(u8 port, u8 pin, int dir,
|
extern void qe_config_iopin(u8 port, u8 pin, int dir,
|
||||||
int open_drain, int assign);
|
int open_drain, int assign);
|
||||||
@ -323,10 +326,12 @@ void cpu_init_f (void)
|
|||||||
#if defined(CONFIG_CPM2)
|
#if defined(CONFIG_CPM2)
|
||||||
m8560_cpm_reset();
|
m8560_cpm_reset();
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_QE
|
|
||||||
|
#if defined(CONFIG_QE) && !defined(CONFIG_U_QE)
|
||||||
/* Config QE ioports */
|
/* Config QE ioports */
|
||||||
config_qe_ioports();
|
config_qe_ioports();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_FSL_DMA)
|
#if defined(CONFIG_FSL_DMA)
|
||||||
dma_init();
|
dma_init();
|
||||||
#endif
|
#endif
|
||||||
@ -810,8 +815,13 @@ int sata_initialize(void)
|
|||||||
|
|
||||||
void cpu_secondary_init_r(void)
|
void cpu_secondary_init_r(void)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_QE
|
#ifdef CONFIG_U_QE
|
||||||
|
uint qe_base = CONFIG_SYS_IMMR + 0x00140000; /* QE immr base */
|
||||||
|
#elif defined CONFIG_QE
|
||||||
uint qe_base = CONFIG_SYS_IMMR + 0x00080000; /* QE immr base */
|
uint qe_base = CONFIG_SYS_IMMR + 0x00080000; /* QE immr base */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_QE
|
||||||
#ifdef CONFIG_SYS_QE_FMAN_FW_IN_NAND
|
#ifdef CONFIG_SYS_QE_FMAN_FW_IN_NAND
|
||||||
int ret;
|
int ret;
|
||||||
size_t fw_length = CONFIG_SYS_QE_FMAN_FW_LENGTH;
|
size_t fw_length = CONFIG_SYS_QE_FMAN_FW_LENGTH;
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
#include "asm/io.h"
|
#include "asm/io.h"
|
||||||
#include "asm/immap_85xx.h"
|
#include "asm/immap_85xx.h"
|
||||||
|
|
||||||
#if defined(CONFIG_QE)
|
#if defined(CONFIG_QE) && !defined(CONFIG_U_QE)
|
||||||
#define NUM_OF_PINS 32
|
#define NUM_OF_PINS 32
|
||||||
void qe_config_iopin(u8 port, u8 pin, int dir, int open_drain, int assign)
|
void qe_config_iopin(u8 port, u8 pin, int dir, int open_drain, int assign)
|
||||||
{
|
{
|
||||||
|
@ -336,6 +336,10 @@ void get_sys_info(sys_info_t *sys_info)
|
|||||||
|
|
||||||
#endif /* CONFIG_SYS_FSL_QORIQ_CHASSIS2 */
|
#endif /* CONFIG_SYS_FSL_QORIQ_CHASSIS2 */
|
||||||
|
|
||||||
|
#ifdef CONFIG_U_QE
|
||||||
|
sys_info->freq_qe = sys_info->freq_systembus / 2;
|
||||||
|
#endif
|
||||||
|
|
||||||
#else /* CONFIG_FSL_CORENET */
|
#else /* CONFIG_FSL_CORENET */
|
||||||
uint plat_ratio, e500_ratio, half_freq_systembus;
|
uint plat_ratio, e500_ratio, half_freq_systembus;
|
||||||
int i;
|
int i;
|
||||||
|
@ -46,6 +46,7 @@ struct liodn_id_table liodn_tbl[] = {
|
|||||||
SET_DMA_LIODN(2, 227),
|
SET_DMA_LIODN(2, 227),
|
||||||
|
|
||||||
/* SET_NEXUS_LIODN(557), -- not yet implemented */
|
/* SET_NEXUS_LIODN(557), -- not yet implemented */
|
||||||
|
SET_QE_LIODN(559),
|
||||||
};
|
};
|
||||||
int liodn_tbl_sz = ARRAY_SIZE(liodn_tbl);
|
int liodn_tbl_sz = ARRAY_SIZE(liodn_tbl);
|
||||||
|
|
||||||
|
@ -736,6 +736,9 @@ defined(CONFIG_PPC_T1020) || defined(CONFIG_PPC_T1022)
|
|||||||
#define CONFIG_SYS_CCSRBAR_DEFAULT 0xfe000000
|
#define CONFIG_SYS_CCSRBAR_DEFAULT 0xfe000000
|
||||||
#define CONFIG_SYS_FSL_ERRATUM_ESDHC111
|
#define CONFIG_SYS_FSL_ERRATUM_ESDHC111
|
||||||
#define ESDHCI_QUIRK_BROKEN_TIMEOUT_VALUE
|
#define ESDHCI_QUIRK_BROKEN_TIMEOUT_VALUE
|
||||||
|
#define QE_MURAM_SIZE 0x6000UL
|
||||||
|
#define MAX_QE_RISC 1
|
||||||
|
#define QE_NUM_OF_SNUM 28
|
||||||
|
|
||||||
#elif defined(CONFIG_PPC_T2080) || defined(CONFIG_PPC_T2081)
|
#elif defined(CONFIG_PPC_T2080) || defined(CONFIG_PPC_T2081)
|
||||||
#define CONFIG_E6500
|
#define CONFIG_E6500
|
||||||
|
@ -99,6 +99,10 @@ extern void fdt_fixup_liodn(void *blob);
|
|||||||
SET_GUTS_LIODN("fsl,esdhc", liodn, sdmmc##sdhcNum##liodnr,\
|
SET_GUTS_LIODN("fsl,esdhc", liodn, sdmmc##sdhcNum##liodnr,\
|
||||||
CONFIG_SYS_MPC85xx_ESDHC_OFFSET)
|
CONFIG_SYS_MPC85xx_ESDHC_OFFSET)
|
||||||
|
|
||||||
|
#define SET_QE_LIODN(liodn) \
|
||||||
|
SET_GUTS_LIODN("fsl,qe", liodn, qeliodnr,\
|
||||||
|
CONFIG_SYS_MPC85xx_QE_OFFSET)
|
||||||
|
|
||||||
#define SET_QMAN_LIODN(liodn) \
|
#define SET_QMAN_LIODN(liodn) \
|
||||||
SET_LIODN_ENTRY_1("fsl,qman", liodn, offsetof(ccsr_qman_t, liodnr) + \
|
SET_LIODN_ENTRY_1("fsl,qman", liodn, offsetof(ccsr_qman_t, liodnr) + \
|
||||||
CONFIG_SYS_FSL_QMAN_OFFSET, \
|
CONFIG_SYS_FSL_QMAN_OFFSET, \
|
||||||
|
@ -1889,7 +1889,9 @@ defined(CONFIG_PPC_T1020) || defined(CONFIG_PPC_T1022)
|
|||||||
u32 sata2liodnr; /* SATA 2 LIODN */
|
u32 sata2liodnr; /* SATA 2 LIODN */
|
||||||
u32 sata3liodnr; /* SATA 3 LIODN */
|
u32 sata3liodnr; /* SATA 3 LIODN */
|
||||||
u32 sata4liodnr; /* SATA 4 LIODN */
|
u32 sata4liodnr; /* SATA 4 LIODN */
|
||||||
u8 res22[32];
|
u8 res22[24];
|
||||||
|
u32 qeliodnr; /* QE LIODN */
|
||||||
|
u8 res_57c[4];
|
||||||
u32 dma1liodnr; /* DMA 1 LIODN */
|
u32 dma1liodnr; /* DMA 1 LIODN */
|
||||||
u32 dma2liodnr; /* DMA 2 LIODN */
|
u32 dma2liodnr; /* DMA 2 LIODN */
|
||||||
u32 dma3liodnr; /* DMA 3 LIODN */
|
u32 dma3liodnr; /* DMA 3 LIODN */
|
||||||
@ -2877,6 +2879,7 @@ struct ccsr_pman {
|
|||||||
#define CONFIG_SYS_MPC85xx_LBC_OFFSET 0x124000
|
#define CONFIG_SYS_MPC85xx_LBC_OFFSET 0x124000
|
||||||
#define CONFIG_SYS_MPC85xx_IFC_OFFSET 0x124000
|
#define CONFIG_SYS_MPC85xx_IFC_OFFSET 0x124000
|
||||||
#define CONFIG_SYS_MPC85xx_GPIO_OFFSET 0x130000
|
#define CONFIG_SYS_MPC85xx_GPIO_OFFSET 0x130000
|
||||||
|
#define CONFIG_SYS_MPC85xx_QE_OFFSET 0x140000
|
||||||
#define CONFIG_SYS_FSL_CORENET_RMAN_OFFSET 0x1e0000
|
#define CONFIG_SYS_FSL_CORENET_RMAN_OFFSET 0x1e0000
|
||||||
#if defined(CONFIG_SYS_FSL_QORIQ_CHASSIS2) && !defined(CONFIG_PPC_B4860)\
|
#if defined(CONFIG_SYS_FSL_QORIQ_CHASSIS2) && !defined(CONFIG_PPC_B4860)\
|
||||||
&& !defined(CONFIG_PPC_B4420)
|
&& !defined(CONFIG_PPC_B4420)
|
||||||
|
@ -282,5 +282,7 @@ int qe_set_mii_clk_src(int ucc_num);
|
|||||||
int qe_upload_firmware(const struct qe_firmware *firmware);
|
int qe_upload_firmware(const struct qe_firmware *firmware);
|
||||||
struct qe_firmware_info *qe_get_firmware_info(void);
|
struct qe_firmware_info *qe_get_firmware_info(void);
|
||||||
void ft_qe_setup(void *blob);
|
void ft_qe_setup(void *blob);
|
||||||
|
void qe_init(uint qe_base);
|
||||||
|
void qe_reset(void);
|
||||||
|
|
||||||
#endif /* __QE_H__ */
|
#endif /* __QE_H__ */
|
||||||
|
Loading…
Reference in New Issue
Block a user