| /* |
| * MPC85xx System descriptions |
| * |
| * Maintainer: Kumar Gala <galak@kernel.crashing.org> |
| * |
| * Copyright 2005 Freescale Semiconductor Inc. |
| * |
| * This program is free software; you can redistribute it and/or modify it |
| * under the terms of the GNU General Public License as published by the |
| * Free Software Foundation; either version 2 of the License, or (at your |
| * option) any later version. |
| */ |
| |
| #include <linux/init.h> |
| #include <linux/module.h> |
| #include <linux/device.h> |
| #include <asm/ppc_sys.h> |
| |
| struct ppc_sys_spec *cur_ppc_sys_spec; |
| struct ppc_sys_spec ppc_sys_specs[] = { |
| { |
| .ppc_sys_name = "8540", |
| .mask = 0xFFFF0000, |
| .value = 0x80300000, |
| .num_devices = 11, |
| .device_list = (enum ppc_sys_devices[]) |
| { |
| MPC85xx_TSEC1, MPC85xx_TSEC2, MPC85xx_FEC, MPC85xx_IIC1, |
| MPC85xx_DMA0, MPC85xx_DMA1, MPC85xx_DMA2, MPC85xx_DMA3, |
| MPC85xx_PERFMON, MPC85xx_DUART, MPC85xx_MDIO, |
| }, |
| }, |
| { |
| .ppc_sys_name = "8560", |
| .mask = 0xFFFF0000, |
| .value = 0x80700000, |
| .num_devices = 20, |
| .device_list = (enum ppc_sys_devices[]) |
| { |
| MPC85xx_TSEC1, MPC85xx_TSEC2, MPC85xx_IIC1, |
| MPC85xx_DMA0, MPC85xx_DMA1, MPC85xx_DMA2, MPC85xx_DMA3, |
| MPC85xx_PERFMON, |
| MPC85xx_CPM_SPI, MPC85xx_CPM_I2C, MPC85xx_CPM_SCC1, |
| MPC85xx_CPM_SCC2, MPC85xx_CPM_SCC3, MPC85xx_CPM_SCC4, |
| MPC85xx_CPM_FCC1, MPC85xx_CPM_FCC2, MPC85xx_CPM_FCC3, |
| MPC85xx_CPM_MCC1, MPC85xx_CPM_MCC2, MPC85xx_MDIO, |
| }, |
| }, |
| { |
| .ppc_sys_name = "8541", |
| .mask = 0xFFFF0000, |
| .value = 0x80720000, |
| .num_devices = 14, |
| .device_list = (enum ppc_sys_devices[]) |
| { |
| MPC85xx_TSEC1, MPC85xx_TSEC2, MPC85xx_IIC1, |
| MPC85xx_DMA0, MPC85xx_DMA1, MPC85xx_DMA2, MPC85xx_DMA3, |
| MPC85xx_PERFMON, MPC85xx_DUART, |
| MPC85xx_CPM_SPI, MPC85xx_CPM_I2C, |
| MPC85xx_CPM_FCC1, MPC85xx_CPM_FCC2, |
| MPC85xx_MDIO, |
| }, |
| }, |
| { |
| .ppc_sys_name = "8541E", |
| .mask = 0xFFFF0000, |
| .value = 0x807A0000, |
| .num_devices = 15, |
| .device_list = (enum ppc_sys_devices[]) |
| { |
| MPC85xx_TSEC1, MPC85xx_TSEC2, MPC85xx_IIC1, |
| MPC85xx_DMA0, MPC85xx_DMA1, MPC85xx_DMA2, MPC85xx_DMA3, |
| MPC85xx_PERFMON, MPC85xx_DUART, MPC85xx_SEC2, |
| MPC85xx_CPM_SPI, MPC85xx_CPM_I2C, |
| MPC85xx_CPM_FCC1, MPC85xx_CPM_FCC2, |
| MPC85xx_MDIO, |
| }, |
| }, |
| { |
| .ppc_sys_name = "8555", |
| .mask = 0xFFFF0000, |
| .value = 0x80710000, |
| .num_devices = 20, |
| .device_list = (enum ppc_sys_devices[]) |
| { |
| MPC85xx_TSEC1, MPC85xx_TSEC2, MPC85xx_IIC1, |
| MPC85xx_DMA0, MPC85xx_DMA1, MPC85xx_DMA2, MPC85xx_DMA3, |
| MPC85xx_PERFMON, MPC85xx_DUART, |
| MPC85xx_CPM_SPI, MPC85xx_CPM_I2C, MPC85xx_CPM_SCC1, |
| MPC85xx_CPM_SCC2, MPC85xx_CPM_SCC3, |
| MPC85xx_CPM_FCC1, MPC85xx_CPM_FCC2, |
| MPC85xx_CPM_SMC1, MPC85xx_CPM_SMC2, |
| MPC85xx_CPM_USB, |
| MPC85xx_MDIO, |
| }, |
| }, |
| { |
| .ppc_sys_name = "8555E", |
| .mask = 0xFFFF0000, |
| .value = 0x80790000, |
| .num_devices = 21, |
| .device_list = (enum ppc_sys_devices[]) |
| { |
| MPC85xx_TSEC1, MPC85xx_TSEC2, MPC85xx_IIC1, |
| MPC85xx_DMA0, MPC85xx_DMA1, MPC85xx_DMA2, MPC85xx_DMA3, |
| MPC85xx_PERFMON, MPC85xx_DUART, MPC85xx_SEC2, |
| MPC85xx_CPM_SPI, MPC85xx_CPM_I2C, MPC85xx_CPM_SCC1, |
| MPC85xx_CPM_SCC2, MPC85xx_CPM_SCC3, |
| MPC85xx_CPM_FCC1, MPC85xx_CPM_FCC2, |
| MPC85xx_CPM_SMC1, MPC85xx_CPM_SMC2, |
| MPC85xx_CPM_USB, |
| MPC85xx_MDIO, |
| }, |
| }, |
| /* SVRs on 8548 rev1.0 matches for 8548/8547/8545 */ |
| { |
| .ppc_sys_name = "8548E", |
| .mask = 0xFFFF00F0, |
| .value = 0x80390010, |
| .num_devices = 14, |
| .device_list = (enum ppc_sys_devices[]) |
| { |
| MPC85xx_eTSEC1, MPC85xx_eTSEC2, MPC85xx_eTSEC3, |
| MPC85xx_eTSEC4, MPC85xx_IIC1, MPC85xx_IIC2, |
| MPC85xx_DMA0, MPC85xx_DMA1, MPC85xx_DMA2, MPC85xx_DMA3, |
| MPC85xx_PERFMON, MPC85xx_DUART, MPC85xx_SEC2, |
| MPC85xx_MDIO, |
| }, |
| }, |
| { |
| .ppc_sys_name = "8548", |
| .mask = 0xFFFF00F0, |
| .value = 0x80310010, |
| .num_devices = 13, |
| .device_list = (enum ppc_sys_devices[]) |
| { |
| MPC85xx_eTSEC1, MPC85xx_eTSEC2, MPC85xx_eTSEC3, |
| MPC85xx_eTSEC4, MPC85xx_IIC1, MPC85xx_IIC2, |
| MPC85xx_DMA0, MPC85xx_DMA1, MPC85xx_DMA2, MPC85xx_DMA3, |
| MPC85xx_PERFMON, MPC85xx_DUART, |
| MPC85xx_MDIO, |
| }, |
| }, |
| { |
| .ppc_sys_name = "8547E", |
| .mask = 0xFFFF00F0, |
| .value = 0x80390010, |
| .num_devices = 14, |
| .device_list = (enum ppc_sys_devices[]) |
| { |
| MPC85xx_eTSEC1, MPC85xx_eTSEC2, MPC85xx_eTSEC3, |
| MPC85xx_eTSEC4, MPC85xx_IIC1, MPC85xx_IIC2, |
| MPC85xx_DMA0, MPC85xx_DMA1, MPC85xx_DMA2, MPC85xx_DMA3, |
| MPC85xx_PERFMON, MPC85xx_DUART, MPC85xx_SEC2, |
| MPC85xx_MDIO, |
| }, |
| }, |
| { |
| .ppc_sys_name = "8547", |
| .mask = 0xFFFF00F0, |
| .value = 0x80310010, |
| .num_devices = 13, |
| .device_list = (enum ppc_sys_devices[]) |
| { |
| MPC85xx_eTSEC1, MPC85xx_eTSEC2, MPC85xx_eTSEC3, |
| MPC85xx_eTSEC4, MPC85xx_IIC1, MPC85xx_IIC2, |
| MPC85xx_DMA0, MPC85xx_DMA1, MPC85xx_DMA2, MPC85xx_DMA3, |
| MPC85xx_PERFMON, MPC85xx_DUART, |
| MPC85xx_MDIO, |
| }, |
| }, |
| { |
| .ppc_sys_name = "8545E", |
| .mask = 0xFFFF00F0, |
| .value = 0x80390010, |
| .num_devices = 12, |
| .device_list = (enum ppc_sys_devices[]) |
| { |
| MPC85xx_eTSEC1, MPC85xx_eTSEC2, |
| MPC85xx_IIC1, MPC85xx_IIC2, |
| MPC85xx_DMA0, MPC85xx_DMA1, MPC85xx_DMA2, MPC85xx_DMA3, |
| MPC85xx_PERFMON, MPC85xx_DUART, MPC85xx_SEC2, |
| MPC85xx_MDIO, |
| }, |
| }, |
| { |
| .ppc_sys_name = "8545", |
| .mask = 0xFFFF00F0, |
| .value = 0x80310010, |
| .num_devices = 11, |
| .device_list = (enum ppc_sys_devices[]) |
| { |
| MPC85xx_eTSEC1, MPC85xx_eTSEC2, |
| MPC85xx_IIC1, MPC85xx_IIC2, |
| MPC85xx_DMA0, MPC85xx_DMA1, MPC85xx_DMA2, MPC85xx_DMA3, |
| MPC85xx_PERFMON, MPC85xx_DUART, |
| MPC85xx_MDIO, |
| }, |
| }, |
| { |
| .ppc_sys_name = "8543E", |
| .mask = 0xFFFF00F0, |
| .value = 0x803A0010, |
| .num_devices = 12, |
| .device_list = (enum ppc_sys_devices[]) |
| { |
| MPC85xx_eTSEC1, MPC85xx_eTSEC2, |
| MPC85xx_IIC1, MPC85xx_IIC2, |
| MPC85xx_DMA0, MPC85xx_DMA1, MPC85xx_DMA2, MPC85xx_DMA3, |
| MPC85xx_PERFMON, MPC85xx_DUART, MPC85xx_SEC2, |
| MPC85xx_MDIO, |
| }, |
| }, |
| { |
| .ppc_sys_name = "8543", |
| .mask = 0xFFFF00F0, |
| .value = 0x80320010, |
| .num_devices = 11, |
| .device_list = (enum ppc_sys_devices[]) |
| { |
| MPC85xx_eTSEC1, MPC85xx_eTSEC2, |
| MPC85xx_IIC1, MPC85xx_IIC2, |
| MPC85xx_DMA0, MPC85xx_DMA1, MPC85xx_DMA2, MPC85xx_DMA3, |
| MPC85xx_PERFMON, MPC85xx_DUART, |
| MPC85xx_MDIO, |
| }, |
| }, |
| { /* default match */ |
| .ppc_sys_name = "", |
| .mask = 0x00000000, |
| .value = 0x00000000, |
| }, |
| }; |