* [PATCH 0/6] MPC5121 Updates
@ 2008-06-20 16:58 John Rigby
[not found] ` <1213981119-1979-2-git-send-email-jrigby@freescale.com>
0 siblings, 1 reply; 16+ messages in thread
From: John Rigby @ 2008-06-20 16:58 UTC (permalink / raw)
To: linuxppc-dev; +Cc: John Rigby
The following patches contain updates for MPC5121
1/6
Updates the device tree.
2/6
Adds a clock driver.
3/6
Adds support for generic boards. This is nearly identical to
David Jander's patch but does not delete the ADS board option.
ADS is not a candidate for generic since it has an on board
cpld that does pci interrupt routing.
4/6
Adds support for the CPLD on the MPC5121ADS board.
5/6
Adds pci
6/6
Hides the pci bridge
^ permalink raw reply [flat|nested] 16+ messages in thread[parent not found: <1213981119-1979-2-git-send-email-jrigby@freescale.com>]
* [PATCH 2/6] MPC5121 clock driver [not found] ` <1213981119-1979-2-git-send-email-jrigby@freescale.com> @ 2008-06-20 16:58 ` John Rigby 2008-06-20 16:58 ` [PATCH 3/6] MPC5121 Add generic board support John Rigby ` (2 more replies) 0 siblings, 3 replies; 16+ messages in thread From: John Rigby @ 2008-06-20 16:58 UTC (permalink / raw) To: linuxppc-dev; +Cc: John Rigby Implements the api defined in include/clk.h Current only getting frequencies is supported not setting. Signed-off-by: John Rigby <jrigby@freescale.com> --- arch/powerpc/platforms/512x/Makefile | 1 + arch/powerpc/platforms/512x/clock.c | 729 ++++++++++++++++++++++++++++++++++ 2 files changed, 730 insertions(+), 0 deletions(-) create mode 100644 arch/powerpc/platforms/512x/clock.c diff --git a/arch/powerpc/platforms/512x/Makefile b/arch/powerpc/platforms/512x/Makefile index 232c89f..ef6c925 100644 --- a/arch/powerpc/platforms/512x/Makefile +++ b/arch/powerpc/platforms/512x/Makefile @@ -1,4 +1,5 @@ # # Makefile for the Freescale PowerPC 512x linux kernel. # +obj-y := clock.o obj-$(CONFIG_MPC5121_ADS) += mpc5121_ads.o diff --git a/arch/powerpc/platforms/512x/clock.c b/arch/powerpc/platforms/512x/clock.c new file mode 100644 index 0000000..39db722 --- /dev/null +++ b/arch/powerpc/platforms/512x/clock.c @@ -0,0 +1,729 @@ +/* + * Copyright (C) 2007,2008 Freescale Semiconductor, Inc. All rights reserved. + * + * Author: John Rigby <jrigby@freescale.com> + * + * Implements the clk api defined in include/linux/clk.h + * + * Original based on linux/arch/arm/mach-integrator/clock.c + * + * Copyright (C) 2004 ARM Limited. + * Written by Deep Blue Solutions Limited. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + */ +#include <linux/module.h> +#include <linux/kernel.h> +#include <linux/list.h> +#include <linux/errno.h> +#include <linux/err.h> +#include <linux/string.h> +#include <linux/clk.h> +#include <linux/mutex.h> +#include <linux/io.h> + +#include <linux/of_platform.h> +#include <asm/mpc512x.h> + +static int clocks_initialized; + +struct module; + +#define CLK_HAS_RATE 0x1 /* has rate in MHz */ +#define CLK_HAS_CTRL 0x2 /* has control reg and bit */ + +struct clk { + struct list_head node; + char name[32]; + int flags; + struct device *dev; + unsigned long rate; + struct module *owner; + void (*calc) (struct clk *); + struct clk *parent; + int reg, bit; /* CLK_HAS_CTRL */ + int div_shift; /* only used by generic_div_clk_calc */ +}; + +static LIST_HEAD(clocks); +static DEFINE_MUTEX(clocks_mutex); + +struct clk *clk_get(struct device *dev, const char *id) +{ + struct clk *p, *clk = ERR_PTR(-ENOENT); + int dev_match = 0; + int id_match = 0; + + if (dev == NULL && id == NULL) + return NULL; + + mutex_lock(&clocks_mutex); + list_for_each_entry(p, &clocks, node) { + if (dev && dev == p->dev) + dev_match++; + if (strcmp(id, p->name) == 0) + id_match++; + if ((dev_match || id_match) && try_module_get(p->owner)) { + clk = p; + break; + } + } + mutex_unlock(&clocks_mutex); + + return clk; +} +EXPORT_SYMBOL(clk_get); + +#undef CLK_DEBUG +#ifdef CLK_DEBUG +void dump_clocks(void) +{ + struct clk *p; + + mutex_lock(&clocks_mutex); + printk(KERN_INFO "CLOCKS:\n"); + list_for_each_entry(p, &clocks, node) { + printk(KERN_INFO " %s %ld", p->name, p->rate); + if (p->parent) + printk(KERN_INFO " %s %ld", p->parent->name, + p->parent->rate); + if (p->flags & CLK_HAS_CTRL) + printk(KERN_INFO " reg/bit %d/%d", p->reg, p->bit); + printk("\n"); + } + mutex_unlock(&clocks_mutex); +} +#define DEBUG_CLK_DUMP() dump_clocks() +#else +#define DEBUG_CLK_DUMP() +#endif + + +void clk_put(struct clk *clk) +{ + module_put(clk->owner); +} +EXPORT_SYMBOL(clk_put); + +#define NRPSC 12 + +struct mpc512x_clockctl { + u32 spmr; /* System PLL Mode Reg */ + u32 sccr[2]; /* System Clk Ctrl Reg 1 & 2 */ + u32 scfr1; /* System Clk Freq Reg 1 */ + u32 scfr2; /* System Clk Freq Reg 2 */ + u32 reserved; + u32 bcr; /* Bread Crumb Reg */ + u32 pccr[NRPSC]; /* PSC Clk Ctrl Reg 0-11 */ + u32 spccr; /* SPDIF Clk Ctrl Reg */ + u32 cccr; /* CFM Clk Ctrl Reg */ + u32 dccr; /* DIU Clk Cnfg Reg */ +}; + +struct mpc512x_clockctl __iomem *clockctl; + +int clk_enable(struct clk *clk) +{ + unsigned int mask; + + if (clk->flags & CLK_HAS_CTRL) { + mask = in_be32(&clockctl->sccr[clk->reg]); + mask |= 1 << clk->bit; + out_be32(&clockctl->sccr[clk->reg], mask); + } + return 0; +} +EXPORT_SYMBOL(clk_enable); + +void clk_disable(struct clk *clk) +{ + unsigned int mask; + + if (clk->flags & CLK_HAS_CTRL) { + mask = in_be32(&clockctl->sccr[clk->reg]); + mask &= ~(1 << clk->bit); + out_be32(&clockctl->sccr[clk->reg], mask); + } +} +EXPORT_SYMBOL(clk_disable); + +unsigned long clk_get_rate(struct clk *clk) +{ + if (clk->flags & CLK_HAS_RATE) + return clk->rate; + else + return 0; +} +EXPORT_SYMBOL(clk_get_rate); + +long clk_round_rate(struct clk *clk, unsigned long rate) +{ + return rate; +} +EXPORT_SYMBOL(clk_round_rate); + +int clk_set_rate(struct clk *clk, unsigned long rate) +{ + return 0; +} +EXPORT_SYMBOL(clk_set_rate); + +static int clk_register(struct clk *clk) +{ + mutex_lock(&clocks_mutex); + list_add(&clk->node, &clocks); + mutex_unlock(&clocks_mutex); + return 0; +} + +static unsigned long spmf_mult(void) +{ + /* + * Convert spmf to multiplier + */ + static int spmf_to_mult[] = { + 68, 1, 12, 16, + 20, 24, 28, 32, + 36, 40, 44, 48, + 52, 56, 60, 64 + }; + int spmf = (clockctl->spmr >> 24) & 0xf; + return spmf_to_mult[spmf]; +} + +static unsigned long sysdiv_div_x_2(void) +{ + /* + * Convert sysdiv to divisor x 2 + * Some divisors have fractional parts so + * multiply by 2 then divide by this value + */ + static int sysdiv_to_div_x_2[] = { + 4, 5, 6, 7, + 8, 9, 10, 14, + 12, 16, 18, 22, + 20, 24, 26, 30, + 28, 32, 34, 38, + 36, 40, 42, 46, + 44, 48, 50, 54, + 52, 56, 58, 62, + 60, 64, 66, + }; + int sysdiv = (clockctl->scfr2 >> 26) & 0x3f; + return sysdiv_to_div_x_2[sysdiv]; +} + +static unsigned long ref_to_sys(unsigned long rate) +{ + rate *= spmf_mult(); + rate *= 2; + rate /= sysdiv_div_x_2(); + + return rate; +} + +static unsigned long sys_to_ref(unsigned long rate) +{ + rate *= sysdiv_div_x_2(); + rate /= 2; + rate /= spmf_mult(); + + return rate; +} + +static long ips_to_ref(unsigned long rate) +{ + int ips_div = (clockctl->scfr1 >> 23) & 0x7; + + rate *= ips_div; /* csb_clk = ips_clk * ips_div */ + rate *= 2; /* sys_clk = csb_clk * 2 */ + return sys_to_ref(rate); +} + +static unsigned long devtree_getfreq(char *nodetype, char *clockname) +{ + struct device_node *node; + const unsigned int *fp; + unsigned int val = 0; + + node = of_find_node_by_type(NULL, "soc"); + if (node) { + fp = of_get_property(node, clockname, NULL); + if (fp) + val = of_read_ulong(fp, 1); + } + return val; +} + +static void ref_clk_calc(struct clk *clk) +{ + unsigned long rate; + + rate = devtree_getfreq("soc", "ref-frequency"); + if (rate == 0) { + /* + * no reference clock in device tree + * get ips clock freq and go backwards from there + */ + rate = devtree_getfreq("soc", "bus-frequency"); + if (rate == 0) { + printk(KERN_WARNING + "No bus-frequency in dev tree using 66MHz\n"); + clk->rate = 66000000; + return; + } + clk->rate = ips_to_ref(rate); + } +} + +static struct clk ref_clk = { + .name = "ref_clk", + .calc = ref_clk_calc, +}; + + +static void sys_clk_calc(struct clk *clk) +{ + clk->rate = ref_to_sys(ref_clk.rate); +} + +static struct clk sys_clk = { + .name = "sys_clk", + .calc = sys_clk_calc, +}; + +static void diu_clk_calc(struct clk *clk) +{ + int diudiv_x_2 = clockctl->scfr1 & 0xff; + unsigned long rate; + + rate = sys_clk.rate; + + rate *= 2; + rate /= diudiv_x_2; + + clk->rate = rate; +} + +static void half_clk_calc(struct clk *clk) +{ + clk->rate = clk->parent->rate / 2; +} + +static void generic_div_clk_calc(struct clk *clk) +{ + int div = (clockctl->scfr1 >> clk->div_shift) & 0x7; + + clk->rate = clk->parent->rate / div; +} + +static void unity_clk_calc(struct clk *clk) +{ + clk->rate = clk->parent->rate; +} + +static struct clk csb_clk = { + .name = "csb_clk", + .calc = half_clk_calc, + .parent = &sys_clk, +}; + +static void e300_clk_calc(struct clk *clk) +{ + int spmf = (clockctl->spmr >> 16) & 0xf; + int ratex2 = clk->parent->rate * spmf; + + clk->rate = ratex2 / 2; +} + +static struct clk e300_clk = { + .name = "e300_clk", + .calc = e300_clk_calc, + .parent = &csb_clk, +}; + +static struct clk ips_clk = { + .name = "ips_clk", + .calc = generic_div_clk_calc, + .parent = &csb_clk, + .div_shift = 23, +}; + +/* + * Clocks controlled by SCCR1 (.reg = 0) + */ +static struct clk lpc_clk = { + .name = "lpc_clk", + .flags = CLK_HAS_CTRL, + .reg = 0, + .bit = 30, + .calc = generic_div_clk_calc, + .parent = &ips_clk, + .div_shift = 11, +}; + +static struct clk nfc_clk = { + .name = "nfc_clk", + .flags = CLK_HAS_CTRL, + .reg = 0, + .bit = 29, + .calc = generic_div_clk_calc, + .parent = &ips_clk, + .div_shift = 8, +}; + +static struct clk pata_clk = { + .name = "pata_clk", + .flags = CLK_HAS_CTRL, + .reg = 0, + .bit = 28, + .calc = unity_clk_calc, + .parent = &ips_clk, +}; + +/* + * PSC clocks (bits 27 - 16) + * are setup elsewhere + */ + +static struct clk sata_clk = { + .name = "sata_clk", + .flags = CLK_HAS_CTRL, + .reg = 0, + .bit = 14, + .calc = unity_clk_calc, + .parent = &ips_clk, +}; + +static struct clk fec_clk = { + .name = "fec_clk", + .flags = CLK_HAS_CTRL, + .reg = 0, + .bit = 13, + .calc = unity_clk_calc, + .parent = &ips_clk, +}; + +static struct clk pci_clk = { + .name = "pci_clk", + .flags = CLK_HAS_CTRL, + .reg = 0, + .bit = 11, + .calc = generic_div_clk_calc, + .parent = &csb_clk, + .div_shift = 20, +}; + +/* + * Clocks controlled by SCCR2 (.reg = 1) + */ +static struct clk diu_clk = { + .name = "diu_clk", + .flags = CLK_HAS_CTRL, + .reg = 1, + .bit = 31, + .calc = diu_clk_calc, +}; + +static struct clk axe_clk = { + .name = "axe_clk", + .flags = CLK_HAS_CTRL, + .reg = 1, + .bit = 30, + .calc = unity_clk_calc, + .parent = &csb_clk, +}; + +static struct clk usb1_clk = { + .name = "usb1_clk", + .flags = CLK_HAS_CTRL, + .reg = 1, + .bit = 28, + .calc = unity_clk_calc, + .parent = &csb_clk, +}; + +static struct clk usb2_clk = { + .name = "usb2_clk", + .flags = CLK_HAS_CTRL, + .reg = 1, + .bit = 27, + .calc = unity_clk_calc, + .parent = &csb_clk, +}; + +static struct clk i2c_clk = { + .name = "i2c_clk", + .flags = CLK_HAS_CTRL, + .reg = 1, + .bit = 26, + .calc = unity_clk_calc, + .parent = &ips_clk, +}; + +static struct clk mscan_clk = { + .name = "mscan_clk", + .flags = CLK_HAS_CTRL, + .reg = 1, + .bit = 25, + .calc = unity_clk_calc, + .parent = &ips_clk, +}; + +static struct clk sdhc_clk = { + .name = "sdhc_clk", + .flags = CLK_HAS_CTRL, + .reg = 1, + .bit = 24, + .calc = unity_clk_calc, + .parent = &ips_clk, +}; + +static struct clk mbx_bus_clk = { + .name = "mbx_bus_clk", + .flags = CLK_HAS_CTRL, + .reg = 1, + .bit = 22, + .calc = half_clk_calc, + .parent = &csb_clk, +}; + +static struct clk mbx_clk = { + .name = "mbx_clk", + .flags = CLK_HAS_CTRL, + .reg = 1, + .bit = 21, + .calc = unity_clk_calc, + .parent = &csb_clk, +}; + +static struct clk mbx_3d_clk = { + .name = "mbx_3d_clk", + .flags = CLK_HAS_CTRL, + .reg = 1, + .bit = 20, + .calc = generic_div_clk_calc, + .parent = &mbx_bus_clk, + .div_shift = 14, +}; + +static void psc_mclk_in_calc(struct clk *clk) +{ + clk->rate = devtree_getfreq("soc", "psc_mclk_in"); + if (!clk->rate) + clk->rate = 25000000; +} + +static struct clk psc_mclk_in = { + .name = "psc_mclk_in", + .calc = psc_mclk_in_calc, +}; + +static struct clk spdif_txclk = { + .name = "spdif_txclk", + .flags = CLK_HAS_CTRL, + .reg = 1, + .bit = 23, +}; + +static struct clk spdif_rxclk = { + .name = "spdif_rxclk", + .flags = CLK_HAS_CTRL, + .reg = 1, + .bit = 23, +}; + +static void ac97_clk_calc(struct clk *clk) +{ + /* ac97 bit clock is always 24.567 MHz */ + clk->rate = 24567000; +} + +static struct clk ac97_clk = { + .name = "ac97_clk_in", + .calc = ac97_clk_calc, +}; + +struct clk *rate_clks[] = { + &ref_clk, + &sys_clk, + &diu_clk, + &csb_clk, + &e300_clk, + &ips_clk, + &fec_clk, + &sata_clk, + &pata_clk, + &nfc_clk, + &lpc_clk, + &mbx_bus_clk, + &mbx_clk, + &mbx_3d_clk, + &axe_clk, + &usb1_clk, + &usb2_clk, + &i2c_clk, + &mscan_clk, + &sdhc_clk, + &pci_clk, + &psc_mclk_in, + &spdif_txclk, + &spdif_rxclk, + &ac97_clk, + NULL +}; + +static void rate_clk_init(struct clk *clk) +{ + if (clk->calc) { + clk->calc(clk); + clk->flags |= CLK_HAS_RATE; + clk_register(clk); + } else { + printk(KERN_WARNING + "Could not initialize clk %s without a calc routine\n", + clk->name); + } +} + +static void rate_clks_init(void) +{ + struct clk **cpp, *clk; + + cpp = rate_clks; + while ((clk = *cpp++)) + rate_clk_init(clk); +} + +/* + * There are two clk enable registers with 32 enable bits each + * psc clocks and device clocks are all stored in dev_clks + */ +struct clk dev_clks[2][32]; + +/* + * Given a psc number return the dev_clk + * associated with it + */ +static struct clk *psc_dev_clk(int pscnum) +{ + int reg, bit; + struct clk *clk; + + reg = 0; + bit = 27 - pscnum; + + clk = &dev_clks[reg][bit]; + clk->reg = 0; + clk->bit = bit; + return clk; +} + +/* + * PSC clock rate calculation + */ +static void psc_calc_rate(struct clk *clk, int pscnum, struct device_node *np) +{ + unsigned long mclk_src = sys_clk.rate; + unsigned long mclk_div; + + /* + * Can only change value of mclk divider + * when the divider is disabled. + * + * Zero is not a valid divider so minimum + * divider is 1 + * + * disable/set divider/enable + */ + out_be32(&clockctl->pccr[pscnum], 0); + out_be32(&clockctl->pccr[pscnum], 0x00020000); + out_be32(&clockctl->pccr[pscnum], 0x00030000); + + if (clockctl->pccr[pscnum] & 0x80) { + clk->rate = spdif_rxclk.rate; + return; + } + + switch ((clockctl->pccr[pscnum] >> 14) & 0x3) { + case 0: + mclk_src = sys_clk.rate; + break; + case 1: + mclk_src = ref_clk.rate; + break; + case 2: + mclk_src = psc_mclk_in.rate; + break; + case 3: + mclk_src = spdif_txclk.rate; + break; + } + + mclk_div = ((clockctl->pccr[pscnum] >> 17) & 0x7fff) + 1; + clk->rate = mclk_src / mclk_div; +} + +/* + * Find all psc nodes in device tree and assign a clock + * with name "psc%d_mclk" and dev pointing at the device + * returned from of_find_device_by_node + */ +static void psc_clks_init(void) +{ + struct device_node *np; + const u32 *cell_index; + struct of_device *ofdev; + + for_each_compatible_node(np, NULL, "fsl,mpc5121-psc") { + cell_index = of_get_property(np, "cell-index", NULL); + if (cell_index) { + int pscnum = *cell_index; + struct clk *clk = psc_dev_clk(pscnum); + + clk->flags = CLK_HAS_RATE | CLK_HAS_CTRL; + ofdev = of_find_device_by_node(np); + clk->dev = &ofdev->dev; + /* + * AC97 is special rate clock does + * not go through normal path + */ + if (strcmp("ac97", np->name) == 0) + clk->rate = ac97_clk.rate; + else + psc_calc_rate(clk, pscnum, np); + sprintf(clk->name, "psc%d_mclk", pscnum); + clk_register(clk); + clk_enable(clk); + } + } +} + +static int +mpc5121_clk_init(void) +{ + struct device_node *np; + + np = of_find_compatible_node(NULL, NULL, "fsl,mpc5121-clock"); + clockctl = of_iomap(np, 0); + of_node_put(np); + + if (!clockctl) { + printk(KERN_ERR "Could not map clock control registers\n"); + return 0; + } + + rate_clks_init(); + psc_clks_init(); + + /* leave clockctl mapped forever */ + /*iounmap(clockctl); */ + DEBUG_CLK_DUMP(); + clocks_initialized++; + return 0; +} + + +arch_initcall(mpc5121_clk_init); -- 1.5.6.rc0.46.gd2b3 ^ permalink raw reply related [flat|nested] 16+ messages in thread
* [PATCH 3/6] MPC5121 Add generic board support 2008-06-20 16:58 ` [PATCH 2/6] MPC5121 clock driver John Rigby @ 2008-06-20 16:58 ` John Rigby 2008-06-20 16:58 ` [PATCH 4/6] MPC5121 Add MPC5121ADS cpld support John Rigby 2008-06-29 5:30 ` [PATCH 3/6] MPC5121 Add generic board support Grant Likely 2008-06-21 4:39 ` [PATCH 2/6] MPC5121 clock driver Stephen Rothwell 2008-06-29 5:21 ` Grant Likely 2 siblings, 2 replies; 16+ messages in thread From: John Rigby @ 2008-06-20 16:58 UTC (permalink / raw) To: linuxppc-dev; +Cc: John Rigby Move shared code from mpc5121_ads.c to mpc512x_shared.c. Add new generic board setup mpc5121_generic.c Signed-off-by: John Rigby <jrigby@freescale.com> --- arch/powerpc/platforms/512x/Kconfig | 15 ++++- arch/powerpc/platforms/512x/Makefile | 3 +- arch/powerpc/platforms/512x/mpc5121_ads.c | 45 +--------------- arch/powerpc/platforms/512x/mpc5121_generic.c | 72 +++++++++++++++++++++++++ arch/powerpc/platforms/512x/mpc512x.h | 14 +++++ arch/powerpc/platforms/512x/mpc512x_shared.c | 66 ++++++++++++++++++++++ 6 files changed, 168 insertions(+), 47 deletions(-) create mode 100644 arch/powerpc/platforms/512x/mpc5121_generic.c create mode 100644 arch/powerpc/platforms/512x/mpc512x.h create mode 100644 arch/powerpc/platforms/512x/mpc512x_shared.c diff --git a/arch/powerpc/platforms/512x/Kconfig b/arch/powerpc/platforms/512x/Kconfig index 4c0da0c..f9a04da 100644 --- a/arch/powerpc/platforms/512x/Kconfig +++ b/arch/powerpc/platforms/512x/Kconfig @@ -2,12 +2,10 @@ config PPC_MPC512x bool select FSL_SOC select IPIC - default n config PPC_MPC5121 bool select PPC_MPC512x - default n config MPC5121_ADS bool "Freescale MPC5121E ADS" @@ -16,4 +14,15 @@ config MPC5121_ADS select PPC_MPC5121 help This option enables support for the MPC5121E ADS board. - default n + +config MPC5121_GENERIC + bool "Generic support for simple MPC5121 based boards" + depends on PPC_MULTIPLATFORM && PPC32 + select DEFAULT_UIMAGE + select PPC_MPC5121 + help + This option enables support for simple MPC5121 based boards + which do not need custome platform specific setup. + + Compatible boards include: Protonic LVT base boards (ZANMCU + and VICVT2). diff --git a/arch/powerpc/platforms/512x/Makefile b/arch/powerpc/platforms/512x/Makefile index ef6c925..e6674c8 100644 --- a/arch/powerpc/platforms/512x/Makefile +++ b/arch/powerpc/platforms/512x/Makefile @@ -1,5 +1,6 @@ # # Makefile for the Freescale PowerPC 512x linux kernel. # -obj-y := clock.o +obj-y := clock.o mpc512x_shared.o obj-$(CONFIG_MPC5121_ADS) += mpc5121_ads.o +obj-$(CONFIG_MPC5121_GENERIC) += mpc5121_generic.o diff --git a/arch/powerpc/platforms/512x/mpc5121_ads.c b/arch/powerpc/platforms/512x/mpc5121_ads.c index 50bd3a3..45bb2ef 100644 --- a/arch/powerpc/platforms/512x/mpc5121_ads.c +++ b/arch/powerpc/platforms/512x/mpc5121_ads.c @@ -15,7 +15,6 @@ #include <linux/kernel.h> #include <linux/io.h> -#include <linux/irq.h> #include <linux/of_platform.h> #include <asm/machdep.h> @@ -23,34 +22,7 @@ #include <asm/prom.h> #include <asm/time.h> -/** - * mpc512x_find_ips_freq - Find the IPS bus frequency for a device - * @node: device node - * - * Returns IPS bus frequency, or 0 if the bus frequency cannot be found. - */ -unsigned long -mpc512x_find_ips_freq(struct device_node *node) -{ - struct device_node *np; - const unsigned int *p_ips_freq = NULL; - - of_node_get(node); - while (node) { - p_ips_freq = of_get_property(node, "bus-frequency", NULL); - if (p_ips_freq) - break; - - np = of_get_parent(node); - of_node_put(node); - node = np; - } - if (node) - of_node_put(node); - - return p_ips_freq ? *p_ips_freq : 0; -} -EXPORT_SYMBOL(mpc512x_find_ips_freq); +#include "mpc512x.h" static struct of_device_id __initdata of_bus_ids[] = { { .name = "soc", }, @@ -68,20 +40,7 @@ static void __init mpc5121_ads_declare_of_platform_devices(void) static void __init mpc5121_ads_init_IRQ(void) { - struct device_node *np; - - np = of_find_compatible_node(NULL, NULL, "fsl,ipic"); - if (!np) - return; - - ipic_init(np, 0); - of_node_put(np); - - /* - * Initialize the default interrupt mapping priorities, - * in case the boot rom changed something on us. - */ - ipic_set_default_priority(); + mpc512x_init_IRQ(); } /* diff --git a/arch/powerpc/platforms/512x/mpc5121_generic.c b/arch/powerpc/platforms/512x/mpc5121_generic.c new file mode 100644 index 0000000..0111a98 --- /dev/null +++ b/arch/powerpc/platforms/512x/mpc5121_generic.c @@ -0,0 +1,72 @@ +/* + * Copyright (C) 2007,2008 Freescale Semiconductor, Inc. All rights reserved. + * + * Author: John Rigby, <jrigby@freescale.com> + * + * Description: + * MPC5121 SoC setup + * + * This 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/kernel.h> +#include <linux/of_platform.h> + +#include <asm/machdep.h> +#include <asm/ipic.h> +#include <asm/prom.h> +#include <asm/time.h> + +#include "mpc512x.h" + +static struct of_device_id __initdata of_bus_ids[] = { + { .name = "soc", }, + { .name = "localbus", }, + {}, +}; + +static void __init mpc5121_generic_declare_of_platform_devices(void) +{ + /* Find every child of the SOC node and add it to of_platform */ + if (of_platform_bus_probe(NULL, of_bus_ids, NULL)) + printk(KERN_ERR __FILE__ ": " + "Error while probing of_platform bus\n"); +} + +/* + * list of supported boards + */ +static char *board[] __initdata = { + "prt,prtlvt", + NULL +}; + +/* + * Called very early, MMU is off, device-tree isn't unflattened + */ +static int __init mpc5121_generic_probe(void) +{ + unsigned long node = of_get_flat_dt_root(); + int i = 0; + + while (board[i]) { + if (of_flat_dt_is_compatible(node, board[i])) + break; + i++; + } + + return board[i] != NULL; +} + +define_machine(mpc5121_generic) { + .name = "MPC5121 generic", + .probe = mpc5121_generic_probe, + .init = mpc5121_generic_declare_of_platform_devices, + .init_IRQ = mpc512x_init_IRQ, + .get_irq = ipic_get_irq, + .calibrate_decr = generic_calibrate_decr, +}; diff --git a/arch/powerpc/platforms/512x/mpc512x.h b/arch/powerpc/platforms/512x/mpc512x.h new file mode 100644 index 0000000..789b817 --- /dev/null +++ b/arch/powerpc/platforms/512x/mpc512x.h @@ -0,0 +1,14 @@ +/* + * Copyright (C) 2007 Freescale Semiconductor, Inc. All rights reserved. + * + * 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. + */ + +#ifndef __MPC512X_H__ +#define __MPC512X_H__ +extern unsigned long mpc512x_find_ips_freq(struct device_node *node); +extern void __init mpc512x_init_IRQ(void); +#endif /* __MPC512X_H__ */ diff --git a/arch/powerpc/platforms/512x/mpc512x_shared.c b/arch/powerpc/platforms/512x/mpc512x_shared.c new file mode 100644 index 0000000..4b8fe6a --- /dev/null +++ b/arch/powerpc/platforms/512x/mpc512x_shared.c @@ -0,0 +1,66 @@ +/* + * Copyright (C) 2007,2008 Freescale Semiconductor, Inc. All rights reserved. + * + * Author: John Rigby <jrigby@freescale.com> + * + * Description: + * MPC512x Shared code + * + * This 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/kernel.h> +#include <linux/io.h> +#include <linux/irq.h> +#include <linux/of_platform.h> + +#include <asm/machdep.h> +#include <asm/ipic.h> +#include <asm/prom.h> +#include <asm/time.h> + +#include "mpc512x.h" + +unsigned long +mpc512x_find_ips_freq(struct device_node *node) +{ + struct device_node *np; + const unsigned int *p_ips_freq = NULL; + + of_node_get(node); + while (node) { + p_ips_freq = of_get_property(node, "bus-frequency", NULL); + if (p_ips_freq) + break; + + np = of_get_parent(node); + of_node_put(node); + node = np; + } + if (node) + of_node_put(node); + + return p_ips_freq ? *p_ips_freq : 0; +} +EXPORT_SYMBOL(mpc512x_find_ips_freq); + +void __init mpc512x_init_IRQ(void) +{ + struct device_node *np; + + np = of_find_compatible_node(NULL, NULL, "fsl,ipic"); + if (!np) + return; + + ipic_init(np, 0); + of_node_put(np); + + /* + * Initialize the default interrupt mapping priorities, + * in case the boot rom changed something on us. + */ + ipic_set_default_priority(); +} -- 1.5.6.rc0.46.gd2b3 ^ permalink raw reply related [flat|nested] 16+ messages in thread
* [PATCH 4/6] MPC5121 Add MPC5121ADS cpld support 2008-06-20 16:58 ` [PATCH 3/6] MPC5121 Add generic board support John Rigby @ 2008-06-20 16:58 ` John Rigby 2008-06-20 16:58 ` [PATCH 5/6] MPC5121 Add PCI support John Rigby 2008-06-29 5:36 ` [PATCH 4/6] MPC5121 Add MPC5121ADS cpld support Grant Likely 2008-06-29 5:30 ` [PATCH 3/6] MPC5121 Add generic board support Grant Likely 1 sibling, 2 replies; 16+ messages in thread From: John Rigby @ 2008-06-20 16:58 UTC (permalink / raw) To: linuxppc-dev; +Cc: John Rigby Add a interrupt host for the interrupt controller in the mpc5121ads cpld. PCI interrupts are 0-7 the rest are 8-15 Touchscreen pendown irq is hardwired to irq1 All other irqs are chainged to irq0 Signed-off-by: John Rigby <jrigby@freescale.com> --- arch/powerpc/platforms/512x/Kconfig | 1 + arch/powerpc/platforms/512x/Makefile | 2 +- arch/powerpc/platforms/512x/mpc5121_ads.c | 14 ++- arch/powerpc/platforms/512x/mpc5121_ads.h | 14 ++ arch/powerpc/platforms/512x/mpc5121_ads_cpld.c | 204 ++++++++++++++++++++++++ 5 files changed, 233 insertions(+), 2 deletions(-) create mode 100644 arch/powerpc/platforms/512x/mpc5121_ads.h create mode 100644 arch/powerpc/platforms/512x/mpc5121_ads_cpld.c diff --git a/arch/powerpc/platforms/512x/Kconfig b/arch/powerpc/platforms/512x/Kconfig index f9a04da..0fd3b00 100644 --- a/arch/powerpc/platforms/512x/Kconfig +++ b/arch/powerpc/platforms/512x/Kconfig @@ -12,6 +12,7 @@ config MPC5121_ADS depends on PPC_MULTIPLATFORM && PPC32 select DEFAULT_UIMAGE select PPC_MPC5121 + select MPC5121_ADS_CPLD help This option enables support for the MPC5121E ADS board. diff --git a/arch/powerpc/platforms/512x/Makefile b/arch/powerpc/platforms/512x/Makefile index e6674c8..aaa934b 100644 --- a/arch/powerpc/platforms/512x/Makefile +++ b/arch/powerpc/platforms/512x/Makefile @@ -2,5 +2,5 @@ # Makefile for the Freescale PowerPC 512x linux kernel. # obj-y := clock.o mpc512x_shared.o -obj-$(CONFIG_MPC5121_ADS) += mpc5121_ads.o +obj-$(CONFIG_MPC5121_ADS) += mpc5121_ads.o mpc5121_ads_cpld.o obj-$(CONFIG_MPC5121_GENERIC) += mpc5121_generic.o diff --git a/arch/powerpc/platforms/512x/mpc5121_ads.c b/arch/powerpc/platforms/512x/mpc5121_ads.c index 45bb2ef..36805fd 100644 --- a/arch/powerpc/platforms/512x/mpc5121_ads.c +++ b/arch/powerpc/platforms/512x/mpc5121_ads.c @@ -1,5 +1,5 @@ /* - * Copyright (C) 2007 Freescale Semiconductor, Inc. All rights reserved. + * Copyright (C) 2007, 2008 Freescale Semiconductor, Inc. All rights reserved. * * Author: John Rigby, <jrigby@freescale.com>, Thur Mar 29 2007 * @@ -23,6 +23,16 @@ #include <asm/time.h> #include "mpc512x.h" +#include "mpc5121_ads.h" + +static void __init mpc5121_ads_setup_arch(void) +{ + printk(KERN_INFO "MPC5121 ADS board from Freescale Semiconductor\n"); + /* + * cpld regs are needed early + */ + mpc5121_ads_cpld_map(); +} static struct of_device_id __initdata of_bus_ids[] = { { .name = "soc", }, @@ -41,6 +51,7 @@ static void __init mpc5121_ads_declare_of_platform_devices(void) static void __init mpc5121_ads_init_IRQ(void) { mpc512x_init_IRQ(); + mpc5121_ads_cpld_pic_init(); } /* @@ -56,6 +67,7 @@ static int __init mpc5121_ads_probe(void) define_machine(mpc5121_ads) { .name = "MPC5121 ADS", .probe = mpc5121_ads_probe, + .setup_arch = mpc5121_ads_setup_arch, .init = mpc5121_ads_declare_of_platform_devices, .init_IRQ = mpc5121_ads_init_IRQ, .get_irq = ipic_get_irq, diff --git a/arch/powerpc/platforms/512x/mpc5121_ads.h b/arch/powerpc/platforms/512x/mpc5121_ads.h new file mode 100644 index 0000000..885992e --- /dev/null +++ b/arch/powerpc/platforms/512x/mpc5121_ads.h @@ -0,0 +1,14 @@ +/* + * Copyright (C) 2008 Freescale Semiconductor, Inc. All rights reserved. + * + * 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. + */ + +#ifndef __MPC512ADS_H__ +#define __MPC512ADS_H__ +extern void __init mpc5121_ads_cpld_map(void); +extern void __init mpc5121_ads_cpld_pic_init(void); +#endif /* __MPC512ADS_H__ */ diff --git a/arch/powerpc/platforms/512x/mpc5121_ads_cpld.c b/arch/powerpc/platforms/512x/mpc5121_ads_cpld.c new file mode 100644 index 0000000..a6ce805 --- /dev/null +++ b/arch/powerpc/platforms/512x/mpc5121_ads_cpld.c @@ -0,0 +1,204 @@ +/* + * Copyright (C) 2008 Freescale Semiconductor, Inc. All rights reserved. + * + * Author: John Rigby, <jrigby@freescale.com> + * + * Description: + * MPC5121ADS CPLD irq handling + * + * This 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. + */ + +#undef DEBUG + +#include <linux/kernel.h> +#include <linux/interrupt.h> +#include <linux/irq.h> +#include <linux/io.h> +#include <asm/prom.h> + +static struct device_node *cpld_pic_node; +static struct irq_host *cpld_pic_host; + +/* + * Bits to ignore in the misc_status register + * 0x10 touch screen pendown is hard routed to irq1 + * 0x02 pci status is read from pci status register + */ +#define MISC_IGNORE 0x12 + +/* + * Nothing to ignore in pci status register + */ +#define PCI_IGNORE 0x00 + +struct cpld_pic { + u8 pci_mask; + u8 pci_status; + u8 route; + u8 misc_mask; + u8 misc_status; + u8 misc_control; +}; + +static struct cpld_pic __iomem *cpld_regs; + +static void __iomem * +irq_to_pic_mask(unsigned int irq) +{ + return irq <= 7 ? &cpld_regs->pci_mask : &cpld_regs->misc_mask; +} + +static unsigned int +irq_to_pic_bit(unsigned int irq) +{ + return 1 << (irq & 0x7); +} + +static void +cpld_mask_irq(unsigned int irq) +{ + unsigned int cpld_irq = (unsigned int)irq_map[irq].hwirq; + void __iomem *pic_mask = irq_to_pic_mask(cpld_irq); + + out_8(pic_mask, + in_8(pic_mask) | irq_to_pic_bit(cpld_irq)); +} + +static void +cpld_unmask_irq(unsigned int irq) +{ + unsigned int cpld_irq = (unsigned int)irq_map[irq].hwirq; + void __iomem *pic_mask = irq_to_pic_mask(cpld_irq); + + out_8(pic_mask, + in_8(pic_mask) & ~irq_to_pic_bit(cpld_irq)); +} + +static struct irq_chip cpld_pic = { + .typename = " CPLD PIC ", + .mask = cpld_mask_irq, + .ack = cpld_mask_irq, + .unmask = cpld_unmask_irq, +}; + +static int +cpld_pic_get_irq(int offset, u8 ignore, u8 __iomem *statusp, + u8 __iomem *maskp) +{ + int cpld_irq; + u8 status = in_8(statusp); + u8 mask = in_8(maskp); + + /* ignore don't cares and masked irqs */ + status |= (ignore | mask); + + if (status == 0xff) + return NO_IRQ_IGNORE; + + cpld_irq = ffz(status) + offset; + + return irq_linear_revmap(cpld_pic_host, cpld_irq); +} + +static void +cpld_pic_cascade(unsigned int irq, struct irq_desc *desc) +{ + irq = cpld_pic_get_irq(0, PCI_IGNORE, &cpld_regs->pci_status, + &cpld_regs->pci_mask); + if (irq != NO_IRQ && irq != NO_IRQ_IGNORE) { + generic_handle_irq(irq); + return; + } + + irq = cpld_pic_get_irq(8, MISC_IGNORE, &cpld_regs->misc_status, + &cpld_regs->misc_mask); + if (irq != NO_IRQ && irq != NO_IRQ_IGNORE) { + generic_handle_irq(irq); + return; + } +} + +static int +cpld_pic_host_match(struct irq_host *h, struct device_node *node) +{ + return cpld_pic_node == node; +} + +static int +cpld_pic_host_map(struct irq_host *h, unsigned int virq, + irq_hw_number_t hw) +{ + get_irq_desc(virq)->status |= IRQ_LEVEL; + set_irq_chip_and_handler(virq, &cpld_pic, handle_level_irq); + return 0; +} + +static struct +irq_host_ops cpld_pic_host_ops = { + .match = cpld_pic_host_match, + .map = cpld_pic_host_map, +}; + +void __init +mpc5121_ads_cpld_map(void) +{ + struct device_node *np = NULL; + + np = of_find_compatible_node(NULL, NULL, "fsl,mpc5121ads-cpld-pic"); + if (!np) { + printk(KERN_ERR "CPLD PIC init: can not find cpld-pic node\n"); + return; + } + + cpld_regs = of_iomap(np, 0); + of_node_put(np); +} + +void __init +mpc5121_ads_cpld_pic_init(void) +{ + unsigned int cascade_irq; + struct device_node *np = NULL; + + pr_debug("cpld_ic_init\n"); + + np = of_find_compatible_node(NULL, NULL, "fsl,mpc5121ads-cpld-pic"); + if (!np) { + printk(KERN_ERR "CPLD PIC init: can not find cpld-pic node\n"); + return; + } + + if (!cpld_regs) + goto end; + + cascade_irq = irq_of_parse_and_map(np, 0); + if (cascade_irq == NO_IRQ) + goto end; + + /* + * statically route touch screen pendown through 1 + * and ignore it here + * route all others through our cascade irq + */ + out_8(&cpld_regs->route, 0xfd); + out_8(&cpld_regs->pci_mask, 0xff); + /* unmask pci ints in misc mask */ + out_8(&cpld_regs->misc_mask, ~(MISC_IGNORE)); + + cpld_pic_node = of_node_get(np); + + cpld_pic_host = + irq_alloc_host(np, IRQ_HOST_MAP_LINEAR, 16, &cpld_pic_host_ops, 16); + if (!cpld_pic_host) { + printk(KERN_ERR "CPLD PIC: failed to allocate irq host!\n"); + goto end; + } + + set_irq_chained_handler(cascade_irq, cpld_pic_cascade); +end: + of_node_put(np); +} -- 1.5.6.rc0.46.gd2b3 ^ permalink raw reply related [flat|nested] 16+ messages in thread
* [PATCH 5/6] MPC5121 Add PCI support 2008-06-20 16:58 ` [PATCH 4/6] MPC5121 Add MPC5121ADS cpld support John Rigby @ 2008-06-20 16:58 ` John Rigby 2008-06-20 16:58 ` [PATCH 6/6] MPC5121 Hide pci bridge John Rigby ` (2 more replies) 2008-06-29 5:36 ` [PATCH 4/6] MPC5121 Add MPC5121ADS cpld support Grant Likely 1 sibling, 3 replies; 16+ messages in thread From: John Rigby @ 2008-06-20 16:58 UTC (permalink / raw) To: linuxppc-dev; +Cc: John Rigby Copied from 83xx minus support for two busses. Signed-off-by: John Rigby <jrigby@freescale.com> --- arch/powerpc/Kconfig | 2 +- arch/powerpc/platforms/512x/Kconfig | 1 + arch/powerpc/platforms/512x/Makefile | 1 + arch/powerpc/platforms/512x/mpc5121_ads.c | 10 ++++ arch/powerpc/platforms/512x/mpc512x.h | 1 + arch/powerpc/platforms/512x/pci.c | 84 +++++++++++++++++++++++++++++ 6 files changed, 98 insertions(+), 1 deletions(-) create mode 100644 arch/powerpc/platforms/512x/pci.c diff --git a/arch/powerpc/Kconfig b/arch/powerpc/Kconfig index 3934e26..5a467a1 100644 --- a/arch/powerpc/Kconfig +++ b/arch/powerpc/Kconfig @@ -545,7 +545,7 @@ config MCA config PCI bool "PCI support" if 40x || CPM2 || PPC_83xx || PPC_85xx || PPC_86xx \ || PPC_MPC52xx || (EMBEDDED && (PPC_PSERIES || PPC_ISERIES)) \ - || PPC_PS3 || 44x + || PPC_PS3 || 44x || PPC_MPC512x default y if !40x && !CPM2 && !8xx && !PPC_MPC512x && !PPC_83xx \ && !PPC_85xx && !PPC_86xx default PCI_PERMEDIA if !4xx && !CPM2 && !8xx diff --git a/arch/powerpc/platforms/512x/Kconfig b/arch/powerpc/platforms/512x/Kconfig index 0fd3b00..a0eae56 100644 --- a/arch/powerpc/platforms/512x/Kconfig +++ b/arch/powerpc/platforms/512x/Kconfig @@ -2,6 +2,7 @@ config PPC_MPC512x bool select FSL_SOC select IPIC + select PPC_INDIRECT_PCI config PPC_MPC5121 bool diff --git a/arch/powerpc/platforms/512x/Makefile b/arch/powerpc/platforms/512x/Makefile index aaa934b..3292b44 100644 --- a/arch/powerpc/platforms/512x/Makefile +++ b/arch/powerpc/platforms/512x/Makefile @@ -4,3 +4,4 @@ obj-y := clock.o mpc512x_shared.o obj-$(CONFIG_MPC5121_ADS) += mpc5121_ads.o mpc5121_ads_cpld.o obj-$(CONFIG_MPC5121_GENERIC) += mpc5121_generic.o +obj-$(CONFIG_PCI) += pci.o diff --git a/arch/powerpc/platforms/512x/mpc5121_ads.c b/arch/powerpc/platforms/512x/mpc5121_ads.c index 36805fd..dd533ff 100644 --- a/arch/powerpc/platforms/512x/mpc5121_ads.c +++ b/arch/powerpc/platforms/512x/mpc5121_ads.c @@ -22,16 +22,26 @@ #include <asm/prom.h> #include <asm/time.h> +#include <sysdev/fsl_soc.h> + #include "mpc512x.h" #include "mpc5121_ads.h" static void __init mpc5121_ads_setup_arch(void) { +#ifdef CONFIG_PCI + struct device_node *np; +#endif printk(KERN_INFO "MPC5121 ADS board from Freescale Semiconductor\n"); /* * cpld regs are needed early */ mpc5121_ads_cpld_map(); + +#ifdef CONFIG_PCI + for_each_compatible_node(np, "pci", "fsl,mpc5121-pci") + mpc512x_add_bridge(np); +#endif } static struct of_device_id __initdata of_bus_ids[] = { diff --git a/arch/powerpc/platforms/512x/mpc512x.h b/arch/powerpc/platforms/512x/mpc512x.h index 789b817..be30915 100644 --- a/arch/powerpc/platforms/512x/mpc512x.h +++ b/arch/powerpc/platforms/512x/mpc512x.h @@ -11,4 +11,5 @@ #define __MPC512X_H__ extern unsigned long mpc512x_find_ips_freq(struct device_node *node); extern void __init mpc512x_init_IRQ(void); +extern int mpc512x_add_bridge(struct device_node *dev); #endif /* __MPC512X_H__ */ diff --git a/arch/powerpc/platforms/512x/pci.c b/arch/powerpc/platforms/512x/pci.c new file mode 100644 index 0000000..7ed9b34 --- /dev/null +++ b/arch/powerpc/platforms/512x/pci.c @@ -0,0 +1,84 @@ +/* + * Copyright (C) 2008 Freescale Semiconductor, Inc. All rights reserved. + * + * Original copied from 83xx/pci.c: + * + * FSL SoC setup code + * + * Maintained by Kumar Gala (see MAINTAINERS for contact information) + * + * 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/stddef.h> +#include <linux/kernel.h> +#include <linux/init.h> +#include <linux/errno.h> +#include <linux/pci.h> +#include <linux/delay.h> +#include <linux/irq.h> +#include <linux/module.h> +#include <linux/io.h> + +#include <asm/system.h> +#include <asm/atomic.h> +#include <asm/pci-bridge.h> +#include <asm/prom.h> +#include <sysdev/fsl_soc.h> + +#undef DEBUG + +#ifdef DEBUG +#define DBG(x...) printk(x) +#else +#define DBG(x...) +#endif + +int __init mpc512x_add_bridge(struct device_node *dev) +{ + int len; + struct pci_controller *hose; + struct resource rsrc; + const int *bus_range; + int has_address = 0; + phys_addr_t immr = get_immrbase(); + + DBG("Adding PCI host bridge %s\n", dev->full_name); + + /* Fetch host bridge registers address */ + has_address = (of_address_to_resource(dev, 0, &rsrc) == 0); + + /* Get bus range if any */ + bus_range = of_get_property(dev, "bus-range", &len); + if (bus_range == NULL || len < 2 * sizeof(int)) { + printk(KERN_WARNING "Can't get bus-range for %s, assume" + " bus 0\n", dev->full_name); + } + + ppc_pci_flags |= PPC_PCI_REASSIGN_ALL_BUS; + hose = pcibios_alloc_controller(dev); + if (!hose) + return -ENOMEM; + + hose->first_busno = bus_range ? bus_range[0] : 0; + hose->last_busno = bus_range ? bus_range[1] : 0xff; + + setup_indirect_pci(hose, immr + 0x8300, immr + 0x8304, 0); + + printk(KERN_INFO "Found MPC512x PCI host bridge at 0x%016llx. " + "Firmware bus number: %d->%d\n", + (unsigned long long)rsrc.start, hose->first_busno, + hose->last_busno); + + DBG(" ->Hose at 0x%p, cfg_addr=0x%p,cfg_data=0x%p\n", + hose, hose->cfg_addr, hose->cfg_data); + + /* Interpret the "ranges" property */ + /* This also maps the I/O region and sets isa_io/mem_base */ + pci_process_bridge_OF_ranges(hose, dev, 1); + + return 0; +} -- 1.5.6.rc0.46.gd2b3 ^ permalink raw reply related [flat|nested] 16+ messages in thread
* [PATCH 6/6] MPC5121 Hide pci bridge 2008-06-20 16:58 ` [PATCH 5/6] MPC5121 Add PCI support John Rigby @ 2008-06-20 16:58 ` John Rigby 2008-06-29 5:42 ` Grant Likely 2008-06-20 22:03 ` [PATCH 5/6] MPC5121 Add PCI support Kumar Gala 2008-06-29 5:38 ` Grant Likely 2 siblings, 1 reply; 16+ messages in thread From: John Rigby @ 2008-06-20 16:58 UTC (permalink / raw) To: linuxppc-dev; +Cc: John Rigby The class of the MPC5121 pci host bridge is PCI_CLASS_BRIDGE_OTHER while other freescale host bridges have class set to PCI_CLASS_PROCESSOR_POWERPC. This patch makes fixup_hide_host_resource_fsl match PCI_CLASS_BRIDGE_OTHER in addition to PCI_CLASS_PROCESSOR_POWERPC. Signed-off-by: John Rigby <jrigby@freescale.com> --- arch/powerpc/kernel/pci_32.c | 5 +++-- 1 files changed, 3 insertions(+), 2 deletions(-) diff --git a/arch/powerpc/kernel/pci_32.c b/arch/powerpc/kernel/pci_32.c index 88db4ff..3d33935 100644 --- a/arch/powerpc/kernel/pci_32.c +++ b/arch/powerpc/kernel/pci_32.c @@ -54,11 +54,12 @@ LIST_HEAD(hose_list); static int pci_bus_count; static void -fixup_hide_host_resource_fsl(struct pci_dev* dev) +fixup_hide_host_resource_fsl(struct pci_dev *dev) { int i, class = dev->class >> 8; - if ((class == PCI_CLASS_PROCESSOR_POWERPC) && + if ((class == PCI_CLASS_PROCESSOR_POWERPC + || class == PCI_CLASS_BRIDGE_OTHER) && (dev->hdr_type == PCI_HEADER_TYPE_NORMAL) && (dev->bus->parent == NULL)) { for (i = 0; i < DEVICE_COUNT_RESOURCE; i++) { -- 1.5.6.rc0.46.gd2b3 ^ permalink raw reply related [flat|nested] 16+ messages in thread
* Re: [PATCH 6/6] MPC5121 Hide pci bridge 2008-06-20 16:58 ` [PATCH 6/6] MPC5121 Hide pci bridge John Rigby @ 2008-06-29 5:42 ` Grant Likely 0 siblings, 0 replies; 16+ messages in thread From: Grant Likely @ 2008-06-29 5:42 UTC (permalink / raw) To: John Rigby, galak; +Cc: linuxppc-dev On Fri, Jun 20, 2008 at 10:58:39AM -0600, John Rigby wrote: > The class of the MPC5121 pci host bridge is PCI_CLASS_BRIDGE_OTHER > while other freescale host bridges have class set to > PCI_CLASS_PROCESSOR_POWERPC. > > This patch makes fixup_hide_host_resource_fsl match > PCI_CLASS_BRIDGE_OTHER in addition to PCI_CLASS_PROCESSOR_POWERPC. > > Signed-off-by: John Rigby <jrigby@freescale.com> This looks right to me, but I'm not really qualified to say if it is correct or not (limited PCI experience). I don't know who needs to look at it. Kumar perhaps? Cheers, g. > --- > arch/powerpc/kernel/pci_32.c | 5 +++-- > 1 files changed, 3 insertions(+), 2 deletions(-) > > diff --git a/arch/powerpc/kernel/pci_32.c b/arch/powerpc/kernel/pci_32.c > index 88db4ff..3d33935 100644 > --- a/arch/powerpc/kernel/pci_32.c > +++ b/arch/powerpc/kernel/pci_32.c > @@ -54,11 +54,12 @@ LIST_HEAD(hose_list); > static int pci_bus_count; > > static void > -fixup_hide_host_resource_fsl(struct pci_dev* dev) > +fixup_hide_host_resource_fsl(struct pci_dev *dev) > { > int i, class = dev->class >> 8; > > - if ((class == PCI_CLASS_PROCESSOR_POWERPC) && > + if ((class == PCI_CLASS_PROCESSOR_POWERPC > + || class == PCI_CLASS_BRIDGE_OTHER) && > (dev->hdr_type == PCI_HEADER_TYPE_NORMAL) && > (dev->bus->parent == NULL)) { > for (i = 0; i < DEVICE_COUNT_RESOURCE; i++) { > -- > 1.5.6.rc0.46.gd2b3 > > _______________________________________________ > Linuxppc-dev mailing list > Linuxppc-dev@ozlabs.org > https://ozlabs.org/mailman/listinfo/linuxppc-dev ^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH 5/6] MPC5121 Add PCI support 2008-06-20 16:58 ` [PATCH 5/6] MPC5121 Add PCI support John Rigby 2008-06-20 16:58 ` [PATCH 6/6] MPC5121 Hide pci bridge John Rigby @ 2008-06-20 22:03 ` Kumar Gala 2008-06-20 22:17 ` Scott Wood 2008-06-29 5:38 ` Grant Likely 2 siblings, 1 reply; 16+ messages in thread From: Kumar Gala @ 2008-06-20 22:03 UTC (permalink / raw) To: John Rigby; +Cc: linuxppc-dev On Jun 20, 2008, at 11:58 AM, John Rigby wrote: > Copied from 83xx minus support for two busses. > > Signed-off-by: John Rigby <jrigby@freescale.com> > --- > arch/powerpc/Kconfig | 2 +- > arch/powerpc/platforms/512x/Kconfig | 1 + > arch/powerpc/platforms/512x/Makefile | 1 + > arch/powerpc/platforms/512x/mpc5121_ads.c | 10 ++++ > arch/powerpc/platforms/512x/mpc512x.h | 1 + > arch/powerpc/platforms/512x/pci.c | 84 ++++++++++++++++++++ > +++++++++ > 6 files changed, 98 insertions(+), 1 deletions(-) > create mode 100644 arch/powerpc/platforms/512x/pci.c > > diff --git a/arch/powerpc/Kconfig b/arch/powerpc/Kconfig > index 3934e26..5a467a1 100644 > --- a/arch/powerpc/Kconfig > +++ b/arch/powerpc/Kconfig > @@ -545,7 +545,7 @@ config MCA > config PCI > bool "PCI support" if 40x || CPM2 || PPC_83xx || PPC_85xx || > PPC_86xx \ > || PPC_MPC52xx || (EMBEDDED && (PPC_PSERIES || PPC_ISERIES)) \ > - || PPC_PS3 || 44x > + || PPC_PS3 || 44x || PPC_MPC512x is it possible to select PCI rather than adding to the madness here? > > default y if !40x && !CPM2 && !8xx && !PPC_MPC512x && !PPC_83xx \ > && !PPC_85xx && !PPC_86xx > default PCI_PERMEDIA if !4xx && !CPM2 && !8xx > diff --git a/arch/powerpc/platforms/512x/pci.c b/arch/powerpc/ > platforms/512x/pci.c > new file mode 100644 > index 0000000..7ed9b34 > --- /dev/null > +++ b/arch/powerpc/platforms/512x/pci.c > @@ -0,0 +1,84 @@ > +/* > + * Copyright (C) 2008 Freescale Semiconductor, Inc. All rights > reserved. > + * > + * Original copied from 83xx/pci.c: Can we not reuse the same code for 83xx/pci.c and 5121/pci? and move it into sysdev/fsl_pci.c? (we'd add some ifdefs for 83xx & 5121) - k ^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH 5/6] MPC5121 Add PCI support 2008-06-20 22:03 ` [PATCH 5/6] MPC5121 Add PCI support Kumar Gala @ 2008-06-20 22:17 ` Scott Wood 0 siblings, 0 replies; 16+ messages in thread From: Scott Wood @ 2008-06-20 22:17 UTC (permalink / raw) To: Kumar Gala; +Cc: linuxppc-dev, John Rigby Kumar Gala wrote: >> diff --git a/arch/powerpc/platforms/512x/pci.c >> b/arch/powerpc/platforms/512x/pci.c >> new file mode 100644 >> index 0000000..7ed9b34 >> --- /dev/null >> +++ b/arch/powerpc/platforms/512x/pci.c >> @@ -0,0 +1,84 @@ >> +/* >> + * Copyright (C) 2008 Freescale Semiconductor, Inc. All rights reserved. >> + * >> + * Original copied from 83xx/pci.c: > > Can we not reuse the same code for 83xx/pci.c and 5121/pci? and move it > into sysdev/fsl_pci.c? (we'd add some ifdefs for 83xx & 5121) I assume by "ifdefs" you mean "device tree checks", right? :-) -Scott ^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH 5/6] MPC5121 Add PCI support 2008-06-20 16:58 ` [PATCH 5/6] MPC5121 Add PCI support John Rigby 2008-06-20 16:58 ` [PATCH 6/6] MPC5121 Hide pci bridge John Rigby 2008-06-20 22:03 ` [PATCH 5/6] MPC5121 Add PCI support Kumar Gala @ 2008-06-29 5:38 ` Grant Likely 2008-06-30 3:59 ` John Rigby 2 siblings, 1 reply; 16+ messages in thread From: Grant Likely @ 2008-06-29 5:38 UTC (permalink / raw) To: John Rigby; +Cc: linuxppc-dev On Fri, Jun 20, 2008 at 10:58:38AM -0600, John Rigby wrote: > Copied from 83xx minus support for two busses. If this is a copy, then can it be shared? g. ^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH 5/6] MPC5121 Add PCI support 2008-06-29 5:38 ` Grant Likely @ 2008-06-30 3:59 ` John Rigby 0 siblings, 0 replies; 16+ messages in thread From: John Rigby @ 2008-06-30 3:59 UTC (permalink / raw) To: Grant Likely; +Cc: linuxppc-dev Yes, Kumar made the same comment. The newer patch that moves the 83xx add bridge routine to fsl_soc obsoletes this patch. On Sat, Jun 28, 2008 at 11:38 PM, Grant Likely <grant.likely@secretlab.ca> wrote: > On Fri, Jun 20, 2008 at 10:58:38AM -0600, John Rigby wrote: >> Copied from 83xx minus support for two busses. > > If this is a copy, then can it be shared? > > g. > > _______________________________________________ > Linuxppc-dev mailing list > Linuxppc-dev@ozlabs.org > https://ozlabs.org/mailman/listinfo/linuxppc-dev > ^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH 4/6] MPC5121 Add MPC5121ADS cpld support 2008-06-20 16:58 ` [PATCH 4/6] MPC5121 Add MPC5121ADS cpld support John Rigby 2008-06-20 16:58 ` [PATCH 5/6] MPC5121 Add PCI support John Rigby @ 2008-06-29 5:36 ` Grant Likely 2008-06-30 4:01 ` John Rigby 1 sibling, 1 reply; 16+ messages in thread From: Grant Likely @ 2008-06-29 5:36 UTC (permalink / raw) To: John Rigby; +Cc: linuxppc-dev Minor comments below. On Fri, Jun 20, 2008 at 10:58:37AM -0600, John Rigby wrote: > Add a interrupt host for the interrupt > controller in the mpc5121ads cpld. > PCI interrupts are 0-7 the rest are 8-15 > Touchscreen pendown irq is hardwired to irq1 > All other irqs are chainged to irq0 > > Signed-off-by: John Rigby <jrigby@freescale.com> > --- > arch/powerpc/platforms/512x/Kconfig | 1 + > arch/powerpc/platforms/512x/Makefile | 2 +- > arch/powerpc/platforms/512x/mpc5121_ads.c | 14 ++- > arch/powerpc/platforms/512x/mpc5121_ads.h | 14 ++ > arch/powerpc/platforms/512x/mpc5121_ads_cpld.c | 204 ++++++++++++++++++++++++ > 5 files changed, 233 insertions(+), 2 deletions(-) > create mode 100644 arch/powerpc/platforms/512x/mpc5121_ads.h > create mode 100644 arch/powerpc/platforms/512x/mpc5121_ads_cpld.c > > diff --git a/arch/powerpc/platforms/512x/Kconfig b/arch/powerpc/platforms/512x/Kconfig > index f9a04da..0fd3b00 100644 > --- a/arch/powerpc/platforms/512x/Kconfig > +++ b/arch/powerpc/platforms/512x/Kconfig > @@ -12,6 +12,7 @@ config MPC5121_ADS > depends on PPC_MULTIPLATFORM && PPC32 > select DEFAULT_UIMAGE > select PPC_MPC5121 > + select MPC5121_ADS_CPLD What is this for? I don't see it used anywhere. > help > This option enables support for the MPC5121E ADS board. > > diff --git a/arch/powerpc/platforms/512x/mpc5121_ads.c b/arch/powerpc/platforms/512x/mpc5121_ads.c > index 45bb2ef..36805fd 100644 > --- a/arch/powerpc/platforms/512x/mpc5121_ads.c > +++ b/arch/powerpc/platforms/512x/mpc5121_ads.c > @@ -1,5 +1,5 @@ > /* > - * Copyright (C) 2007 Freescale Semiconductor, Inc. All rights reserved. > + * Copyright (C) 2007, 2008 Freescale Semiconductor, Inc. All rights reserved. > * > * Author: John Rigby, <jrigby@freescale.com>, Thur Mar 29 2007 > * > @@ -23,6 +23,16 @@ > #include <asm/time.h> > > #include "mpc512x.h" > +#include "mpc5121_ads.h" > + > +static void __init mpc5121_ads_setup_arch(void) > +{ > + printk(KERN_INFO "MPC5121 ADS board from Freescale Semiconductor\n"); > + /* > + * cpld regs are needed early > + */ > + mpc5121_ads_cpld_map(); > +} > > static struct of_device_id __initdata of_bus_ids[] = { > { .name = "soc", }, > @@ -41,6 +51,7 @@ static void __init mpc5121_ads_declare_of_platform_devices(void) > static void __init mpc5121_ads_init_IRQ(void) > { > mpc512x_init_IRQ(); > + mpc5121_ads_cpld_pic_init(); Ah, I understand now. Ignore my related comment in the previous patch. > } > > /* ^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH 4/6] MPC5121 Add MPC5121ADS cpld support 2008-06-29 5:36 ` [PATCH 4/6] MPC5121 Add MPC5121ADS cpld support Grant Likely @ 2008-06-30 4:01 ` John Rigby 0 siblings, 0 replies; 16+ messages in thread From: John Rigby @ 2008-06-30 4:01 UTC (permalink / raw) To: Grant Likely; +Cc: linuxppc-dev On Sat, Jun 28, 2008 at 11:36 PM, Grant Likely <grant.likely@secretlab.ca> wrote: > Minor comments below. > > On Fri, Jun 20, 2008 at 10:58:37AM -0600, John Rigby wrote: >> Add a interrupt host for the interrupt >> controller in the mpc5121ads cpld. >> PCI interrupts are 0-7 the rest are 8-15 >> Touchscreen pendown irq is hardwired to irq1 >> All other irqs are chainged to irq0 >> >> Signed-off-by: John Rigby <jrigby@freescale.com> >> --- >> arch/powerpc/platforms/512x/Kconfig | 1 + >> arch/powerpc/platforms/512x/Makefile | 2 +- >> arch/powerpc/platforms/512x/mpc5121_ads.c | 14 ++- >> arch/powerpc/platforms/512x/mpc5121_ads.h | 14 ++ >> arch/powerpc/platforms/512x/mpc5121_ads_cpld.c | 204 ++++++++++++++++++++++++ >> 5 files changed, 233 insertions(+), 2 deletions(-) >> create mode 100644 arch/powerpc/platforms/512x/mpc5121_ads.h >> create mode 100644 arch/powerpc/platforms/512x/mpc5121_ads_cpld.c >> >> diff --git a/arch/powerpc/platforms/512x/Kconfig b/arch/powerpc/platforms/512x/Kconfig >> index f9a04da..0fd3b00 100644 >> --- a/arch/powerpc/platforms/512x/Kconfig >> +++ b/arch/powerpc/platforms/512x/Kconfig >> @@ -12,6 +12,7 @@ config MPC5121_ADS >> depends on PPC_MULTIPLATFORM && PPC32 >> select DEFAULT_UIMAGE >> select PPC_MPC5121 >> + select MPC5121_ADS_CPLD > > What is this for? I don't see it used anywhere. Yes you are right, the Makefile just uses MPC5121_ADS to include the cpld code. > >> help >> This option enables support for the MPC5121E ADS board. >> >> diff --git a/arch/powerpc/platforms/512x/mpc5121_ads.c b/arch/powerpc/platforms/512x/mpc5121_ads.c >> index 45bb2ef..36805fd 100644 >> --- a/arch/powerpc/platforms/512x/mpc5121_ads.c >> +++ b/arch/powerpc/platforms/512x/mpc5121_ads.c >> @@ -1,5 +1,5 @@ >> /* >> - * Copyright (C) 2007 Freescale Semiconductor, Inc. All rights reserved. >> + * Copyright (C) 2007, 2008 Freescale Semiconductor, Inc. All rights reserved. >> * >> * Author: John Rigby, <jrigby@freescale.com>, Thur Mar 29 2007 >> * >> @@ -23,6 +23,16 @@ >> #include <asm/time.h> >> >> #include "mpc512x.h" >> +#include "mpc5121_ads.h" >> + >> +static void __init mpc5121_ads_setup_arch(void) >> +{ >> + printk(KERN_INFO "MPC5121 ADS board from Freescale Semiconductor\n"); >> + /* >> + * cpld regs are needed early >> + */ >> + mpc5121_ads_cpld_map(); >> +} >> >> static struct of_device_id __initdata of_bus_ids[] = { >> { .name = "soc", }, >> @@ -41,6 +51,7 @@ static void __init mpc5121_ads_declare_of_platform_devices(void) >> static void __init mpc5121_ads_init_IRQ(void) >> { >> mpc512x_init_IRQ(); >> + mpc5121_ads_cpld_pic_init(); > > Ah, I understand now. Ignore my related comment in the previous patch. > >> } >> >> /* > _______________________________________________ > Linuxppc-dev mailing list > Linuxppc-dev@ozlabs.org > https://ozlabs.org/mailman/listinfo/linuxppc-dev > ^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH 3/6] MPC5121 Add generic board support 2008-06-20 16:58 ` [PATCH 3/6] MPC5121 Add generic board support John Rigby 2008-06-20 16:58 ` [PATCH 4/6] MPC5121 Add MPC5121ADS cpld support John Rigby @ 2008-06-29 5:30 ` Grant Likely 1 sibling, 0 replies; 16+ messages in thread From: Grant Likely @ 2008-06-29 5:30 UTC (permalink / raw) To: John Rigby; +Cc: linuxppc-dev Mostly looks good, but a few comments below. On Fri, Jun 20, 2008 at 10:58:36AM -0600, John Rigby wrote: > Move shared code from mpc5121_ads.c to mpc512x_shared.c. > Add new generic board setup mpc5121_generic.c > > Signed-off-by: John Rigby <jrigby@freescale.com> > --- > arch/powerpc/platforms/512x/Kconfig | 15 ++++- > arch/powerpc/platforms/512x/Makefile | 3 +- > arch/powerpc/platforms/512x/mpc5121_ads.c | 45 +--------------- > arch/powerpc/platforms/512x/mpc5121_generic.c | 72 +++++++++++++++++++++++++ > arch/powerpc/platforms/512x/mpc512x.h | 14 +++++ > arch/powerpc/platforms/512x/mpc512x_shared.c | 66 ++++++++++++++++++++++ > 6 files changed, 168 insertions(+), 47 deletions(-) > create mode 100644 arch/powerpc/platforms/512x/mpc5121_generic.c > create mode 100644 arch/powerpc/platforms/512x/mpc512x.h > create mode 100644 arch/powerpc/platforms/512x/mpc512x_shared.c > > diff --git a/arch/powerpc/platforms/512x/Kconfig b/arch/powerpc/platforms/512x/Kconfig > index 4c0da0c..f9a04da 100644 > --- a/arch/powerpc/platforms/512x/Kconfig > +++ b/arch/powerpc/platforms/512x/Kconfig > @@ -2,12 +2,10 @@ config PPC_MPC512x > bool > select FSL_SOC > select IPIC > - default n > > config PPC_MPC5121 > bool > select PPC_MPC512x > - default n > > config MPC5121_ADS > bool "Freescale MPC5121E ADS" > @@ -16,4 +14,15 @@ config MPC5121_ADS > select PPC_MPC5121 > help > This option enables support for the MPC5121E ADS board. > - default n > + > +config MPC5121_GENERIC > + bool "Generic support for simple MPC5121 based boards" > + depends on PPC_MULTIPLATFORM && PPC32 > + select DEFAULT_UIMAGE > + select PPC_MPC5121 > + help > + This option enables support for simple MPC5121 based boards > + which do not need custome platform specific setup. typo > + > + Compatible boards include: Protonic LVT base boards (ZANMCU > + and VICVT2). > diff --git a/arch/powerpc/platforms/512x/Makefile b/arch/powerpc/platforms/512x/Makefile > index ef6c925..e6674c8 100644 > --- a/arch/powerpc/platforms/512x/Makefile > +++ b/arch/powerpc/platforms/512x/Makefile > @@ -1,5 +1,6 @@ > # > # Makefile for the Freescale PowerPC 512x linux kernel. > # > -obj-y := clock.o > +obj-y := clock.o mpc512x_shared.o > obj-$(CONFIG_MPC5121_ADS) += mpc5121_ads.o > +obj-$(CONFIG_MPC5121_GENERIC) += mpc5121_generic.o > diff --git a/arch/powerpc/platforms/512x/mpc5121_ads.c b/arch/powerpc/platforms/512x/mpc5121_ads.c > index 50bd3a3..45bb2ef 100644 > --- a/arch/powerpc/platforms/512x/mpc5121_ads.c > +++ b/arch/powerpc/platforms/512x/mpc5121_ads.c > @@ -68,20 +40,7 @@ static void __init mpc5121_ads_declare_of_platform_devices(void) > > static void __init mpc5121_ads_init_IRQ(void) > { > - struct device_node *np; > - > - np = of_find_compatible_node(NULL, NULL, "fsl,ipic"); > - if (!np) > - return; > - > - ipic_init(np, 0); > - of_node_put(np); > - > - /* > - * Initialize the default interrupt mapping priorities, > - * in case the boot rom changed something on us. > - */ > - ipic_set_default_priority(); > + mpc512x_init_IRQ(); > } Why not just put mpc512x_init_IRQ directly into the machine structure? > > /* > diff --git a/arch/powerpc/platforms/512x/mpc5121_generic.c b/arch/powerpc/platforms/512x/mpc5121_generic.c > new file mode 100644 > index 0000000..0111a98 > --- /dev/null > +++ b/arch/powerpc/platforms/512x/mpc5121_generic.c > @@ -0,0 +1,72 @@ > +/* > + * Copyright (C) 2007,2008 Freescale Semiconductor, Inc. All rights reserved. > + * > + * Author: John Rigby, <jrigby@freescale.com> > + * > + * Description: > + * MPC5121 SoC setup > + * > + * This 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/kernel.h> > +#include <linux/of_platform.h> > + > +#include <asm/machdep.h> > +#include <asm/ipic.h> > +#include <asm/prom.h> > +#include <asm/time.h> > + > +#include "mpc512x.h" > + > +static struct of_device_id __initdata of_bus_ids[] = { > + { .name = "soc", }, > + { .name = "localbus", }, Ugh. Not good. Bind against compatible, not name or type. > + {}, > +}; > + > +static void __init mpc5121_generic_declare_of_platform_devices(void) > +{ > + /* Find every child of the SOC node and add it to of_platform */ > + if (of_platform_bus_probe(NULL, of_bus_ids, NULL)) > + printk(KERN_ERR __FILE__ ": " > + "Error while probing of_platform bus\n"); > +} > + > +/* > + * list of supported boards > + */ > +static char *board[] __initdata = { > + "prt,prtlvt", > + NULL > +}; > + > +/* > + * Called very early, MMU is off, device-tree isn't unflattened > + */ > +static int __init mpc5121_generic_probe(void) > +{ > + unsigned long node = of_get_flat_dt_root(); > + int i = 0; > + > + while (board[i]) { > + if (of_flat_dt_is_compatible(node, board[i])) > + break; > + i++; > + } > + > + return board[i] != NULL; > +} > + > +define_machine(mpc5121_generic) { > + .name = "MPC5121 generic", > + .probe = mpc5121_generic_probe, > + .init = mpc5121_generic_declare_of_platform_devices, > + .init_IRQ = mpc512x_init_IRQ, > + .get_irq = ipic_get_irq, > + .calibrate_decr = generic_calibrate_decr, > +}; > diff --git a/arch/powerpc/platforms/512x/mpc512x.h b/arch/powerpc/platforms/512x/mpc512x.h > new file mode 100644 > index 0000000..789b817 > --- /dev/null > +++ b/arch/powerpc/platforms/512x/mpc512x.h > @@ -0,0 +1,14 @@ > +/* > + * Copyright (C) 2007 Freescale Semiconductor, Inc. All rights reserved. > + * > + * 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. > + */ Should probably state what this file is for in the header block. > diff --git a/arch/powerpc/platforms/512x/mpc512x_shared.c b/arch/powerpc/platforms/512x/mpc512x_shared.c > new file mode 100644 > index 0000000..4b8fe6a > --- /dev/null > +++ b/arch/powerpc/platforms/512x/mpc512x_shared.c > @@ -0,0 +1,66 @@ > +/* > + * Copyright (C) 2007,2008 Freescale Semiconductor, Inc. All rights reserved. > + * > + * Author: John Rigby <jrigby@freescale.com> > + * > + * Description: > + * MPC512x Shared code > + * > + * This 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/kernel.h> > +#include <linux/io.h> > +#include <linux/irq.h> > +#include <linux/of_platform.h> > + > +#include <asm/machdep.h> > +#include <asm/ipic.h> > +#include <asm/prom.h> > +#include <asm/time.h> > + > +#include "mpc512x.h" > + > +unsigned long > +mpc512x_find_ips_freq(struct device_node *node) > +{ > + struct device_node *np; > + const unsigned int *p_ips_freq = NULL; > + > + of_node_get(node); > + while (node) { > + p_ips_freq = of_get_property(node, "bus-frequency", NULL); > + if (p_ips_freq) > + break; > + > + np = of_get_parent(node); > + of_node_put(node); > + node = np; > + } > + if (node) > + of_node_put(node); > + > + return p_ips_freq ? *p_ips_freq : 0; > +} > +EXPORT_SYMBOL(mpc512x_find_ips_freq); This looks identical to the 52xx version. Perhaps they should be merged... I wouldn't bother for getting this mainlined, but it is something to think about for the future. g. ^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH 2/6] MPC5121 clock driver 2008-06-20 16:58 ` [PATCH 2/6] MPC5121 clock driver John Rigby 2008-06-20 16:58 ` [PATCH 3/6] MPC5121 Add generic board support John Rigby @ 2008-06-21 4:39 ` Stephen Rothwell 2008-06-29 5:21 ` Grant Likely 2 siblings, 0 replies; 16+ messages in thread From: Stephen Rothwell @ 2008-06-21 4:39 UTC (permalink / raw) To: John Rigby; +Cc: linuxppc-dev [-- Attachment #1: Type: text/plain, Size: 760 bytes --] Hi John, On Fri, 20 Jun 2008 10:58:35 -0600 John Rigby <jrigby@freescale.com> wrote: > > +struct module; Since you include linux/module.h, you don't need this. > +static unsigned long devtree_getfreq(char *nodetype, char *clockname) > +{ > + struct device_node *node; > + const unsigned int *fp; > + unsigned int val = 0; > + > + node = of_find_node_by_type(NULL, "soc"); > + if (node) { > + fp = of_get_property(node, clockname, NULL); > + if (fp) > + val = of_read_ulong(fp, 1); > + } > + return val; You leak a reference to the node here. Also every call has nodetype set to "soc" and you don't use nodetype anyway. -- Cheers, Stephen Rothwell sfr@canb.auug.org.au http://www.canb.auug.org.au/~sfr/ [-- Attachment #2: Type: application/pgp-signature, Size: 197 bytes --] ^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH 2/6] MPC5121 clock driver 2008-06-20 16:58 ` [PATCH 2/6] MPC5121 clock driver John Rigby 2008-06-20 16:58 ` [PATCH 3/6] MPC5121 Add generic board support John Rigby 2008-06-21 4:39 ` [PATCH 2/6] MPC5121 clock driver Stephen Rothwell @ 2008-06-29 5:21 ` Grant Likely 2 siblings, 0 replies; 16+ messages in thread From: Grant Likely @ 2008-06-29 5:21 UTC (permalink / raw) To: John Rigby; +Cc: linuxppc-dev Mostly looks good, a few comments below. On Fri, Jun 20, 2008 at 10:58:35AM -0600, John Rigby wrote: > Implements the api defined in include/clk.h > > Current only getting frequencies is supported > not setting. Need a more detailed commit message. This doesn't tell me much. > > Signed-off-by: John Rigby <jrigby@freescale.com> > --- > arch/powerpc/platforms/512x/Makefile | 1 + > arch/powerpc/platforms/512x/clock.c | 729 ++++++++++++++++++++++++++++++++++ > 2 files changed, 730 insertions(+), 0 deletions(-) > create mode 100644 arch/powerpc/platforms/512x/clock.c > > diff --git a/arch/powerpc/platforms/512x/Makefile b/arch/powerpc/platforms/512x/Makefile > index 232c89f..ef6c925 100644 > --- a/arch/powerpc/platforms/512x/Makefile > +++ b/arch/powerpc/platforms/512x/Makefile > @@ -1,4 +1,5 @@ > # > # Makefile for the Freescale PowerPC 512x linux kernel. > # > +obj-y := clock.o should be += > obj-$(CONFIG_MPC5121_ADS) += mpc5121_ads.o > diff --git a/arch/powerpc/platforms/512x/clock.c b/arch/powerpc/platforms/512x/clock.c > new file mode 100644 > index 0000000..39db722 > --- /dev/null > +++ b/arch/powerpc/platforms/512x/clock.c > @@ -0,0 +1,729 @@ > +/* > + * Copyright (C) 2007,2008 Freescale Semiconductor, Inc. All rights reserved. > + * > + * Author: John Rigby <jrigby@freescale.com> > + * > + * Implements the clk api defined in include/linux/clk.h > + * > + * Original based on linux/arch/arm/mach-integrator/clock.c > + * > + * Copyright (C) 2004 ARM Limited. > + * Written by Deep Blue Solutions Limited. > + * > + * This program is free software; you can redistribute it and/or modify > + * it under the terms of the GNU General Public License version 2 as > + * published by the Free Software Foundation. > + */ > +#include <linux/module.h> > +#include <linux/kernel.h> > +#include <linux/list.h> > +#include <linux/errno.h> > +#include <linux/err.h> > +#include <linux/string.h> > +#include <linux/clk.h> > +#include <linux/mutex.h> > +#include <linux/io.h> > + > +#include <linux/of_platform.h> > +#include <asm/mpc512x.h> > + > +static int clocks_initialized; > + > +struct module; This is already defined in linux/module.h? > + > +#undef CLK_DEBUG I think this line should be at the top of the file to be easier to find when toggling it. > +#ifdef CLK_DEBUG > +void dump_clocks(void) > +{ > + struct clk *p; > + > + mutex_lock(&clocks_mutex); > + printk(KERN_INFO "CLOCKS:\n"); > + list_for_each_entry(p, &clocks, node) { > + printk(KERN_INFO " %s %ld", p->name, p->rate); > + if (p->parent) > + printk(KERN_INFO " %s %ld", p->parent->name, > + p->parent->rate); > + if (p->flags & CLK_HAS_CTRL) > + printk(KERN_INFO " reg/bit %d/%d", p->reg, p->bit); > + printk("\n"); > + } > + mutex_unlock(&clocks_mutex); > +} > +#define DEBUG_CLK_DUMP() dump_clocks() > +#else > +#define DEBUG_CLK_DUMP() > +#endif > + > +static long ips_to_ref(unsigned long rate) > +{ > + int ips_div = (clockctl->scfr1 >> 23) & 0x7; > + > + rate *= ips_div; /* csb_clk = ips_clk * ips_div */ > + rate *= 2; /* sys_clk = csb_clk * 2 */ > + return sys_to_ref(rate); > +} > + > +static unsigned long devtree_getfreq(char *nodetype, char *clockname) Why is nodetype even passed in here? It isn't used, and besides, you shouldn't test against device_type anyway. Test against compatible instead. > +{ > + struct device_node *node; > + const unsigned int *fp; > + unsigned int val = 0; > + > + node = of_find_node_by_type(NULL, "soc"); Once again; don't look for device_type == "soc". Use compatible. > + if (node) { > + fp = of_get_property(node, clockname, NULL); > + if (fp) > + val = of_read_ulong(fp, 1); > + } > + return val; > +} > + > +static void ref_clk_calc(struct clk *clk) > +{ > + unsigned long rate; > + > + rate = devtree_getfreq("soc", "ref-frequency"); > + if (rate == 0) { > + /* > + * no reference clock in device tree > + * get ips clock freq and go backwards from there > + */ > + rate = devtree_getfreq("soc", "bus-frequency"); > + if (rate == 0) { > + printk(KERN_WARNING > + "No bus-frequency in dev tree using 66MHz\n"); > + clk->rate = 66000000; Is it even worth trying to use a default here? I think it should fail loudly instead to reduce the risk of people shipping boards with badly formed device trees. I don't think there is any backwards compatibility need for doing this. ^ permalink raw reply [flat|nested] 16+ messages in thread
end of thread, other threads:[~2008-06-30 4:01 UTC | newest]
Thread overview: 16+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-06-20 16:58 [PATCH 0/6] MPC5121 Updates John Rigby
[not found] ` <1213981119-1979-2-git-send-email-jrigby@freescale.com>
2008-06-20 16:58 ` [PATCH 2/6] MPC5121 clock driver John Rigby
2008-06-20 16:58 ` [PATCH 3/6] MPC5121 Add generic board support John Rigby
2008-06-20 16:58 ` [PATCH 4/6] MPC5121 Add MPC5121ADS cpld support John Rigby
2008-06-20 16:58 ` [PATCH 5/6] MPC5121 Add PCI support John Rigby
2008-06-20 16:58 ` [PATCH 6/6] MPC5121 Hide pci bridge John Rigby
2008-06-29 5:42 ` Grant Likely
2008-06-20 22:03 ` [PATCH 5/6] MPC5121 Add PCI support Kumar Gala
2008-06-20 22:17 ` Scott Wood
2008-06-29 5:38 ` Grant Likely
2008-06-30 3:59 ` John Rigby
2008-06-29 5:36 ` [PATCH 4/6] MPC5121 Add MPC5121ADS cpld support Grant Likely
2008-06-30 4:01 ` John Rigby
2008-06-29 5:30 ` [PATCH 3/6] MPC5121 Add generic board support Grant Likely
2008-06-21 4:39 ` [PATCH 2/6] MPC5121 clock driver Stephen Rothwell
2008-06-29 5:21 ` Grant Likely
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).