diff options
-rw-r--r-- | recipes/linux/linux-2.6.31/boc01/008-091005-spi.patch | 227 | ||||
-rw-r--r-- | recipes/linux/linux-2.6.31/boc01/boc01.dts | 18 | ||||
-rw-r--r-- | recipes/linux/linux-2.6.31/boc01/boc01.dts.v1 | 18 | ||||
-rw-r--r-- | recipes/linux/linux_2.6.31.bb | 1 |
4 files changed, 36 insertions, 228 deletions
diff --git a/recipes/linux/linux-2.6.31/boc01/008-091005-spi.patch b/recipes/linux/linux-2.6.31/boc01/008-091005-spi.patch deleted file mode 100644 index 2c5239d13a..0000000000 --- a/recipes/linux/linux-2.6.31/boc01/008-091005-spi.patch +++ /dev/null @@ -1,227 +0,0 @@ -Index: linux-2.6.31/arch/powerpc/platforms/83xx/mpc831x_rdb.c -=================================================================== ---- linux-2.6.31.orig/arch/powerpc/platforms/83xx/mpc831x_rdb.c 2009-09-10 00:13:59.000000000 +0200 -+++ linux-2.6.31/arch/powerpc/platforms/83xx/mpc831x_rdb.c 2009-10-20 15:32:51.000000000 +0200 -@@ -14,18 +14,176 @@ - */ - - #include <linux/pci.h> -+#include <linux/interrupt.h> - #include <linux/of_platform.h> -+#include <linux/spi/spi.h> -+#include <linux/fsl_devices.h> - - #include <asm/time.h> - #include <asm/ipic.h> - #include <asm/udbg.h> - #include <sysdev/fsl_pci.h> -+#include <sysdev/fsl_soc.h> - - #include "mpc83xx.h" - - /* - * Setup the architecture - */ -+struct gpio { -+ __be32 gpdir; -+ __be32 gpodr; -+ __be32 gpdat; -+ __be32 gpier; -+ __be32 gpimr; -+ __be32 gpicr; -+} __attribute__ ((packed)); -+static struct gpio *gpio_regs; -+ -+static int __init of_fsl_spi_probe(char *type, char *compatible, u32 sysclk, -+ struct spi_board_info *board_infos, -+ unsigned int num_board_infos, -+ void (*cs_control)(struct spi_device *dev, -+ bool on)) -+{ -+ struct device_node *np; -+ unsigned int i = 0; -+ -+ for_each_compatible_node(np, type, compatible) { -+ int ret; -+ unsigned int j; -+ const void *prop; -+ struct resource res[2]; -+ struct platform_device *pdev; -+ struct fsl_spi_platform_data pdata = { -+ .cs_control = cs_control, -+ }; -+ -+ memset(res, 0, sizeof(res)); -+ -+ pdata.sysclk = sysclk; -+ -+ prop = of_get_property(np, "reg", NULL); -+ if (!prop) -+ goto err; -+ pdata.bus_num = *(u32 *)prop; -+ -+ prop = of_get_property(np, "cell-index", NULL); -+ if (prop) -+ i = *(u32 *)prop; -+ -+ prop = of_get_property(np, "mode", NULL); -+ if (prop && !strcmp(prop, "cpu-qe")) -+ pdata.qe_mode = 1; -+ -+ for (j = 0; j < num_board_infos; j++) { -+ if (board_infos[j].bus_num == pdata.bus_num) -+ pdata.max_chipselect++; -+ } -+ -+ if (!pdata.max_chipselect) -+ continue; -+ -+ ret = of_address_to_resource(np, 0, &res[0]); -+ if (ret) -+ goto err; -+ -+ ret = of_irq_to_resource(np, 0, &res[1]); -+ if (ret == NO_IRQ) -+ goto err; -+ -+ pdev = platform_device_alloc("mpc83xx_spi", i); -+ if (!pdev) -+ goto err; -+ -+ ret = platform_device_add_data(pdev, &pdata, sizeof(pdata)); -+ if (ret) -+ goto unreg; -+ -+ ret = platform_device_add_resources(pdev, res, -+ ARRAY_SIZE(res)); -+ if (ret) -+ goto unreg; -+ -+ ret = platform_device_add(pdev); -+ if (ret) -+ goto unreg; -+ -+ goto next; -+unreg: -+ platform_device_del(pdev); -+err: -+ pr_err("%s: registration failed\n", np->full_name); -+next: -+ i++; -+ } -+ -+ return i; -+} -+ -+static int __init fsl_spi_init(struct spi_board_info *board_infos, -+ unsigned int num_board_infos, -+ void (*cs_control)(struct spi_device *spi, -+ bool on)) -+{ -+ u32 sysclk = -1; -+ int ret; -+ -+ /* SPI controller is either clocked from QE or SoC clock */ -+ sysclk = get_brgfreq(); -+ if (sysclk == -1) { -+ sysclk = fsl_get_sys_freq(); -+ if (sysclk == -1) -+ return -ENODEV; -+ } -+ -+ ret = of_fsl_spi_probe(NULL, "fsl,spi", sysclk, board_infos, -+ num_board_infos, cs_control); -+ if (!ret) -+ of_fsl_spi_probe("spi", "fsl_spi", sysclk, board_infos, -+ num_board_infos, cs_control); -+ -+ return spi_register_board_info(board_infos, num_board_infos); -+} -+ -+static void mpc83xx_spi_cs_control(struct spi_device *spi, bool on) -+{ -+ if (on) -+ setbits32(&gpio_regs->gpdat, 1 << (31 - 14)); -+ else -+ clrbits32(&gpio_regs->gpdat, 1 << (31 - 14)); -+} -+ -+static struct spi_board_info mpc8313_spi_boardinfo = { -+ .bus_num = 0x7000, -+ .chip_select = 0, -+ .max_speed_hz = 50000000, -+ .modalias = "spidev", -+}; -+ -+static int __init mpc8313_spi_init(void) -+{ -+ __be32 __iomem *psicrl; -+ -+ /* System I/O Configuration Register Low */ -+ psicrl = ioremap(get_immrbase() + MPC83XX_SICRL_OFFS, 0x4); -+ gpio_regs = ioremap(get_immrbase() + 0xc00, 0x20); -+ if (!psicrl || !gpio_regs) -+ return -ENOMEM; -+ -+ clrbits32(psicrl, 0x03F00000); -+ setbits32(psicrl, 0x30000000); -+ iounmap(psicrl); -+ -+ /* set GPIO13 as output */ -+ setbits32(&gpio_regs->gpdir, 1 << (31 - 14)); -+ clrbits32(&gpio_regs->gpodr, 1 << (31 - 14)); -+ setbits32(&gpio_regs->gpdat, 1 << (31 - 14)); -+ -+ return fsl_spi_init(&mpc8313_spi_boardinfo, 1, mpc83xx_spi_cs_control); -+} -+machine_device_initcall(mpc831x_rdb, mpc8313_spi_init); -+ - static void __init mpc831x_rdb_setup_arch(void) - { - #ifdef CONFIG_PCI -Index: linux-2.6.31/drivers/spi/spi_mpc8xxx.c -=================================================================== ---- linux-2.6.31.orig/drivers/spi/spi_mpc8xxx.c 2009-09-10 00:13:59.000000000 +0200 -+++ linux-2.6.31/drivers/spi/spi_mpc8xxx.c 2009-10-20 15:32:55.000000000 +0200 -@@ -285,7 +285,9 @@ - if (pm) - pm--; - -- cs->hw_mode |= SPMODE_PM(pm); -+ cs->hw_mode = 0x0F700000; -+ mpc8xxx_spi_write_reg(&mpc8xxx_spi->base->mode, cs->hw_mode); -+ - regval = mpc8xxx_spi_read_reg(&mpc8xxx_spi->base->mode); - if (cs->hw_mode != regval) { - unsigned long flags; -@@ -445,7 +447,7 @@ - cs->hw_mode = mpc8xxx_spi_read_reg(&mpc8xxx_spi->base->mode); - /* mask out bits we are going to set */ - cs->hw_mode &= ~(SPMODE_CP_BEGIN_EDGECLK | SPMODE_CI_INACTIVEHIGH -- | SPMODE_REV | SPMODE_LOOP); -+ | SPMODE_REV ); - - if (spi->mode & SPI_CPHA) - cs->hw_mode |= SPMODE_CP_BEGIN_EDGECLK; -@@ -453,8 +455,10 @@ - cs->hw_mode |= SPMODE_CI_INACTIVEHIGH; - if (!(spi->mode & SPI_LSB_FIRST)) - cs->hw_mode |= SPMODE_REV; -- if (spi->mode & SPI_LOOP) -- cs->hw_mode |= SPMODE_LOOP; -+ -+ cs->hw_mode = 0x0F700000; -+ mpc8xxx_spi_write_reg(&mpc8xxx_spi->base->mode, cs->hw_mode); -+ cs->hw_mode = mpc8xxx_spi_read_reg(&mpc8xxx_spi->base->mode); - - retval = mpc8xxx_spi_setup_transfer(spi, NULL); - if (retval < 0) { -@@ -602,7 +606,7 @@ - INIT_LIST_HEAD(&mpc8xxx_spi->queue); - - mpc8xxx_spi->workqueue = create_singlethread_workqueue( -- dev_name(master->dev.parent)); -+ dev_name(dev)); - if (mpc8xxx_spi->workqueue == NULL) { - ret = -EBUSY; - goto free_irq; diff --git a/recipes/linux/linux-2.6.31/boc01/boc01.dts b/recipes/linux/linux-2.6.31/boc01/boc01.dts index d18fd7fd71..73b6044a07 100644 --- a/recipes/linux/linux-2.6.31/boc01/boc01.dts +++ b/recipes/linux/linux-2.6.31/boc01/boc01.dts @@ -108,6 +108,15 @@ reg = <0x200 0x100>; }; + gpio0: gpio-controller@c00 { + #gpio-cells = <2>; + compatible = "fsl,mpc8313-gpio", "fsl,mpc8349-gpio"; + reg = <0xc00 0x100>; + interrupts = <74 0x8>; + interrupt-parent = <&ipic>; + gpio-controller; + }; + sleep-nexus { #address-cells = <1>; #size-cells = <1>; @@ -177,6 +186,15 @@ interrupts = <16 0x8>; interrupt-parent = <&ipic>; mode = "cpu"; + + /* gpio representing chip select */ + gpios = <&gpio0 14 0>; + + rfid@0 { + compatible = "nxp,spidev"; + spi-max-frequency = <50000000>; + reg = <0>; + }; }; /* phy type (ULPI, UTMI, UTMI_WIDE, SERIAL) */ diff --git a/recipes/linux/linux-2.6.31/boc01/boc01.dts.v1 b/recipes/linux/linux-2.6.31/boc01/boc01.dts.v1 index b2e2456438..bf499b1287 100644 --- a/recipes/linux/linux-2.6.31/boc01/boc01.dts.v1 +++ b/recipes/linux/linux-2.6.31/boc01/boc01.dts.v1 @@ -108,6 +108,15 @@ reg = <0x200 0x100>; }; + gpio0: gpio-controller@c00 { + #gpio-cells = <2>; + compatible = "fsl,mpc8313-gpio", "fsl,mpc8349-gpio"; + reg = <0xc00 0x100>; + interrupts = <74 0x8>; + interrupt-parent = <&ipic>; + gpio-controller; + }; + sleep-nexus { #address-cells = <1>; #size-cells = <1>; @@ -177,6 +186,15 @@ interrupts = <16 0x8>; interrupt-parent = <&ipic>; mode = "cpu"; + + /* gpio representing chip select */ + gpios = <&gpio0 14 0>; + + rfid@0 { + compatible = "nxp,spidev"; + spi-max-frequency = <50000000>; + reg = <0>; + }; }; /* phy type (ULPI, UTMI, UTMI_WIDE, SERIAL) */ diff --git a/recipes/linux/linux_2.6.31.bb b/recipes/linux/linux_2.6.31.bb index 47816cb094..6c5a1091dd 100644 --- a/recipes/linux/linux_2.6.31.bb +++ b/recipes/linux/linux_2.6.31.bb @@ -20,7 +20,6 @@ SRC_URI_append_boc01 = "\ file://004-081205-usb.patch;patch=1 \ file://005-091008-isl12024.patch;patch=1 \ file://007-091005-lm73.patch;patch=1 \ - file://008-091005-spi.patch;patch=1 \ file://011-090115-gpio.patch;patch=1 \ file://012-091019-capsense.patch;patch=1 \ file://013-091015-lcd.patch;patch=1 \ |