Merge git://git.kernel.org/pub/scm/linux/kernel/git/paulus/powerpc
* git://git.kernel.org/pub/scm/linux/kernel/git/paulus/powerpc: (29 commits) [POWERPC] Fix rheap alignment problem [POWERPC] Use check_legacy_ioport() for ISAPnP [POWERPC] Avoid NULL pointer in gpio1_interrupt [POWERPC] Enable generic rtc hook for the MPC8349 mITX [POWERPC] Add powerpc get/set_rtc_time interface to new generic rtc class [POWERPC] Create a "wrapper" script and use it in arch/powerpc/boot [POWERPC] fix spin lock nesting in hvc_iseries [POWERPC] EEH failure to mark pci slot as frozen. [POWERPC] update powerpc defconfig files after libata kconfig breakage [POWERPC] enable sysrq in pmac32_defconfig [POWERPC] UPIO_TSI cleanup [POWERPC] rewrite mkprep and mkbugboot in sane C [POWERPC] maple/pci iomem annotations [POWERPC] powerpc oprofile __user annotations [POWERPC] cell spufs iomem annotations [POWERPC] NULL noise removal: spufs [POWERPC] ppc math-emu needs -fno-builtin-fabs for math.c and fabs.c [POWERPC] update mpc8349_itx_defconfig and remove some debug settings [POWERPC] Always call cede in pseries dedicated idle loop [POWERPC] Fix loop logic in irq_alloc_virt() ...
This commit is contained in:
@@ -55,6 +55,30 @@ static inline int fs_get_scc_index(enum fs_id id)
|
||||
return -1;
|
||||
}
|
||||
|
||||
static inline int fs_fec_index2id(int index)
|
||||
{
|
||||
int id = fsid_fec1 + index - 1;
|
||||
if (id >= fsid_fec1 && id <= fsid_fec2)
|
||||
return id;
|
||||
return FS_MAX_INDEX;
|
||||
}
|
||||
|
||||
static inline int fs_fcc_index2id(int index)
|
||||
{
|
||||
int id = fsid_fcc1 + index - 1;
|
||||
if (id >= fsid_fcc1 && id <= fsid_fcc3)
|
||||
return id;
|
||||
return FS_MAX_INDEX;
|
||||
}
|
||||
|
||||
static inline int fs_scc_index2id(int index)
|
||||
{
|
||||
int id = fsid_scc1 + index - 1;
|
||||
if (id >= fsid_scc1 && id <= fsid_scc4)
|
||||
return id;
|
||||
return FS_MAX_INDEX;
|
||||
}
|
||||
|
||||
enum fs_mii_method {
|
||||
fsmii_fixed,
|
||||
fsmii_fec,
|
||||
@@ -87,18 +111,21 @@ struct fs_mii_bb_platform_info {
|
||||
};
|
||||
|
||||
struct fs_platform_info {
|
||||
|
||||
void(*init_ioports)(void);
|
||||
|
||||
void(*init_ioports)(struct fs_platform_info *);
|
||||
/* device specific information */
|
||||
int fs_no; /* controller index */
|
||||
char fs_type[4]; /* controller type */
|
||||
|
||||
u32 cp_page; /* CPM page */
|
||||
u32 cp_block; /* CPM sblock */
|
||||
|
||||
|
||||
u32 clk_trx; /* some stuff for pins & mux configuration*/
|
||||
u32 clk_rx;
|
||||
u32 clk_tx;
|
||||
u32 clk_route;
|
||||
u32 clk_mask;
|
||||
|
||||
|
||||
u32 mem_offset;
|
||||
u32 dpram_offset;
|
||||
u32 fcc_regs_c;
|
||||
@@ -124,4 +151,16 @@ struct fs_mii_fec_platform_info {
|
||||
u32 irq[32];
|
||||
u32 mii_speed;
|
||||
};
|
||||
|
||||
static inline int fs_get_id(struct fs_platform_info *fpi)
|
||||
{
|
||||
if(strstr(fpi->fs_type, "SCC"))
|
||||
return fs_scc_index2id(fpi->fs_no);
|
||||
if(strstr(fpi->fs_type, "FCC"))
|
||||
return fs_fcc_index2id(fpi->fs_no);
|
||||
if(strstr(fpi->fs_type, "FEC"))
|
||||
return fs_fec_index2id(fpi->fs_no);
|
||||
return fpi->fs_no;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
@@ -46,15 +46,27 @@ static inline int fs_uart_id_fsid2smc(int id)
|
||||
}
|
||||
|
||||
struct fs_uart_platform_info {
|
||||
void(*init_ioports)(void);
|
||||
void(*init_ioports)(struct fs_uart_platform_info *);
|
||||
/* device specific information */
|
||||
int fs_no; /* controller index */
|
||||
char fs_type[4]; /* controller type */
|
||||
u32 uart_clk;
|
||||
u8 tx_num_fifo;
|
||||
u8 tx_buf_size;
|
||||
u8 rx_num_fifo;
|
||||
u8 rx_buf_size;
|
||||
u8 brg;
|
||||
u8 clk_rx;
|
||||
u8 clk_tx;
|
||||
};
|
||||
|
||||
static inline int fs_uart_get_id(struct fs_uart_platform_info *fpi)
|
||||
{
|
||||
if(strstr(fpi->fs_type, "SMC"))
|
||||
return fs_uart_id_smc2fsid(fpi->fs_no);
|
||||
if(strstr(fpi->fs_type, "SCC"))
|
||||
return fs_uart_id_scc2fsid(fpi->fs_no);
|
||||
return fpi->fs_no;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
Reference in New Issue
Block a user