All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH 00/12] ARM: vf610m4: Add Vybrid Cortex-M4 support
@ 2014-12-03  0:11 ` Stefan Agner
  0 siblings, 0 replies; 108+ messages in thread
From: Stefan Agner @ 2014-12-03  0:11 UTC (permalink / raw)
  To: shawn.guo, kernel, linux, u.kleine-koenig, jason, olof, arnd,
	daniel.lezcano, tglx, mark.rutland, pawel.moll, robh+dt,
	ijc+devicetree, galak
  Cc: devicetree, linux-arm-kernel, linux-kernel, Stefan Agner

This is the second version (first was RFC) of this patchset. It
contains feedback from RFC and mainly grew by the support for the
interrupt router which is part of the MSCM IP contained in Vybrid.
MSCM provides a simple router for the pheriperal interrupts which
allows to select which CPU should receive a certain interrupt.
Hence it is crucrial for Linux. Right now, the boot loader enables
all interrupts for the Cortex-A5. To make Linux on Cortex-M4
working, the interrupts of the peripherals have been manually
remapped. A proper driver would automate this, along with a "poor
mans resource controller" (WARN_ON when the interrupt is routed).
This IP appears only to be part of Vybrid, the somewhat similar
SoC i.MX6SoloX does not contain this IP, hence I made it rather
Vybrid specific.

I think some patches are already merge ready (unified addruart),
while some need likely more discussion (NVIC irq router support,
MSCM stuff).

Especially I did not solved the multiplatform problem. Arnd, I
read your patches and started to think about it, but I'm not sure
I'm the right person doing that since my view of the ARM world
is still rather limited... But for Vybrid, it would be very useful
and simplify Kconfig (would avoid the additional arch ARCH_MXCM4).

With the m4boot utility (https://github.com/falstaff84/m4boot), a
XIP kernel image with its dtb and a initramfs, the Cortex-M4 can
be booted on a mainline kernel using:

./m4boot xipImage initramfs.cpio.lzo vf610m4-colibri.dtb

(some U-Boot fiddling needed, ask for details if you really want
to test that)

Changes since RFC:
- Unified addruart calls for MMU/!MMU
- Add MSCM support along with routable IRQ support in NVIC
- Rebased on Shawns for-next tree which made some changes
  obsolete (mainly the Vybrid SoC device tree files in for-next
  are already prepared for Cortex-M4 support)
- Removed SRC_GPR3 hack, this is now part of a mini boot-loader:
  https://github.com/falstaff84/vf610m4bootldr

Stefan Agner (12):
  ARM: dts: vf610: add routable-irqs property for gic node
  ARM: dts: vf610: add Miscellaneous System Control Module (MSCM)
  irqchip: gic: define register_routable_domain_ops conditional
  irqchip: nvic: support routable irq domain ops
  irqchip: nvic: increase number of external interrupts to 112
  ARM: imx: add support for MSCM interrupt router
  Documentation: dt: imx: add MSCM documentation
  clocksource: add dependencies for Vybrid pit clocksource
  ARM: unify MMU/!MMU addruart calls
  ARM: vf610m4: add new machine and SoC for Vybrid on Cortex-M4
  ARM: dts: add support for Vybrid running on Cortex-M4
  ARM: vf610m4: add defconfig for Linux on Vybrids Cortex-M4

 .../bindings/arm/freescale/fsl,vf610-mscm.txt      |  14 ++
 arch/arm/Kconfig                                   |  12 ++
 arch/arm/Kconfig.debug                             |   4 +-
 arch/arm/Makefile                                  |   1 +
 arch/arm/boot/dts/Makefile                         |   1 +
 arch/arm/boot/dts/vf500.dtsi                       |   1 +
 arch/arm/boot/dts/vf610m4-colibri.dts              |  52 ++++++++
 arch/arm/boot/dts/vf610m4.dtsi                     |  33 +++++
 arch/arm/boot/dts/vfxxx.dtsi                       |   5 +
 arch/arm/configs/vf610m4_defconfig                 |  49 +++++++
 arch/arm/include/debug/efm32.S                     |   2 +-
 arch/arm/kernel/debug.S                            |   2 +-
 arch/arm/kernel/entry-v7m.S                        |   6 +-
 arch/arm/mach-imx/Kconfig                          |  27 ++++
 arch/arm/mach-imx/Makefile                         |   2 +
 arch/arm/mach-imx/Makefile.boot                    |   0
 arch/arm/mach-imx/common.h                         |   1 +
 arch/arm/mach-imx/mach-vf610.c                     |   7 +
 arch/arm/mach-imx/mach-vf610m4.c                   |  31 +++++
 arch/arm/mach-imx/mscm-vf610.c                     | 141 +++++++++++++++++++++
 drivers/clocksource/Kconfig                        |   2 +
 drivers/irqchip/irq-nvic.c                         |  72 ++++++++++-
 drivers/mmc/host/Kconfig                           |   2 +-
 drivers/pinctrl/freescale/Kconfig                  |   2 +-
 include/linux/irqchip/arm-gic.h                    |   3 +
 include/linux/irqchip/arm-nvic.h                   |  25 ++++
 26 files changed, 487 insertions(+), 10 deletions(-)
 create mode 100644 Documentation/devicetree/bindings/arm/freescale/fsl,vf610-mscm.txt
 create mode 100644 arch/arm/boot/dts/vf610m4-colibri.dts
 create mode 100644 arch/arm/boot/dts/vf610m4.dtsi
 create mode 100644 arch/arm/configs/vf610m4_defconfig
 create mode 100644 arch/arm/mach-imx/Makefile.boot
 create mode 100644 arch/arm/mach-imx/mach-vf610m4.c
 create mode 100644 arch/arm/mach-imx/mscm-vf610.c
 create mode 100644 include/linux/irqchip/arm-nvic.h

-- 
2.1.3


^ permalink raw reply	[flat|nested] 108+ messages in thread

end of thread, other threads:[~2014-12-20 18:49 UTC | newest]

Thread overview: 108+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2014-12-03  0:11 [PATCH 00/12] ARM: vf610m4: Add Vybrid Cortex-M4 support Stefan Agner
2014-12-03  0:11 ` Stefan Agner
2014-12-03  0:12 ` [PATCH 01/12] ARM: dts: vf610: add routable-irqs property for gic node Stefan Agner
2014-12-03  0:12   ` Stefan Agner
2014-12-03  0:12 ` [PATCH 02/12] ARM: dts: vf610: add Miscellaneous System Control Module (MSCM) Stefan Agner
2014-12-03  0:12   ` Stefan Agner
2014-12-03  0:12   ` Stefan Agner
2014-12-03  0:12 ` [PATCH 03/12] irqchip: gic: define register_routable_domain_ops conditional Stefan Agner
2014-12-03  0:12   ` Stefan Agner
2014-12-03 10:46   ` Arnd Bergmann
2014-12-03 10:46     ` Arnd Bergmann
2014-12-03 10:46     ` Arnd Bergmann
2014-12-03 13:04     ` Thomas Gleixner
2014-12-03 13:04       ` Thomas Gleixner
2014-12-03 13:04       ` Thomas Gleixner
2014-12-03 17:28       ` Stefan Agner
2014-12-03 17:28         ` Stefan Agner
2014-12-03 19:04         ` Marc Zyngier
2014-12-03 19:04           ` Marc Zyngier
2014-12-03 19:04           ` Marc Zyngier
2014-12-04  0:03           ` Thomas Gleixner
2014-12-04  0:03             ` Thomas Gleixner
2014-12-04  0:03             ` Thomas Gleixner
2014-12-04 13:35           ` Stefan Agner
2014-12-04 13:35             ` Stefan Agner
2014-12-04 13:35             ` Stefan Agner
2014-12-04 13:42             ` Marc Zyngier
2014-12-04 13:42               ` Marc Zyngier
2014-12-04 13:42               ` Marc Zyngier
2014-12-04 13:50               ` Stefan Agner
2014-12-04 13:50                 ` Stefan Agner
2014-12-04 13:50                 ` Stefan Agner
2014-12-03  0:12 ` [PATCH 04/12] irqchip: nvic: support routable irq domain ops Stefan Agner
2014-12-03  0:12   ` Stefan Agner
2014-12-03  9:39   ` Uwe Kleine-König
2014-12-03  9:39     ` Uwe Kleine-König
2014-12-03  9:39     ` Uwe Kleine-König
2014-12-03 10:49   ` Arnd Bergmann
2014-12-03 10:49     ` Arnd Bergmann
2014-12-03 10:49     ` Arnd Bergmann
2014-12-03 17:32     ` Stefan Agner
2014-12-03 17:32       ` Stefan Agner
2014-12-03 17:32       ` Stefan Agner
2014-12-03  0:12 ` [PATCH 05/12] irqchip: nvic: increase number of external interrupts to 112 Stefan Agner
2014-12-03  0:12   ` Stefan Agner
2014-12-03  0:12   ` Stefan Agner
2014-12-03  8:12   ` Uwe Kleine-König
2014-12-03  8:12     ` Uwe Kleine-König
2014-12-03  8:12     ` Uwe Kleine-König
2014-12-03 17:40     ` Stefan Agner
2014-12-03 17:40       ` Stefan Agner
2014-12-03 17:40       ` Stefan Agner
2014-12-03  0:12 ` [PATCH 06/12] ARM: imx: add support for MSCM interrupt router Stefan Agner
2014-12-03  0:12   ` Stefan Agner
2014-12-03  0:12   ` Stefan Agner
2014-12-03 10:51   ` Arnd Bergmann
2014-12-03 10:51     ` Arnd Bergmann
2014-12-03  0:12 ` [PATCH 07/12] Documentation: dt: imx: add MSCM documentation Stefan Agner
2014-12-03  0:12   ` Stefan Agner
2014-12-03  0:12   ` Stefan Agner
2014-12-03 10:52   ` Arnd Bergmann
2014-12-03 10:52     ` Arnd Bergmann
2014-12-03 10:52     ` Arnd Bergmann
2014-12-03 17:49     ` Stefan Agner
2014-12-03 17:49       ` Stefan Agner
2014-12-03 17:49       ` Stefan Agner
2014-12-03  0:12 ` [PATCH 08/12] clocksource: add dependencies for Vybrid pit clocksource Stefan Agner
2014-12-03  0:12   ` Stefan Agner
2014-12-03  0:12   ` Stefan Agner
2014-12-03  0:12 ` [PATCH 09/12] ARM: unify MMU/!MMU addruart calls Stefan Agner
2014-12-03  0:12   ` Stefan Agner
2014-12-03  0:12   ` Stefan Agner
2014-12-03 10:53   ` Arnd Bergmann
2014-12-03 10:53     ` Arnd Bergmann
2014-12-03 10:53     ` Arnd Bergmann
2014-12-03  0:12 ` [PATCH 10/12] ARM: vf610m4: add new machine and SoC for Vybrid on Cortex-M4 Stefan Agner
2014-12-03  0:12   ` Stefan Agner
2014-12-03 10:56   ` Arnd Bergmann
2014-12-03 10:56     ` Arnd Bergmann
2014-12-03 10:56     ` Arnd Bergmann
2014-12-03 18:00     ` Stefan Agner
2014-12-03 18:00       ` Stefan Agner
2014-12-03 18:00       ` Stefan Agner
2014-12-03  0:12 ` [PATCH 11/12] ARM: dts: add support for Vybrid running " Stefan Agner
2014-12-03  0:12   ` Stefan Agner
2014-12-03 11:03   ` Arnd Bergmann
2014-12-03 11:03     ` Arnd Bergmann
2014-12-16 22:19     ` Stefan Agner
2014-12-16 22:19       ` Stefan Agner
2014-12-16 22:19       ` Stefan Agner
2014-12-17 10:57       ` Arnd Bergmann
2014-12-17 10:57         ` Arnd Bergmann
2014-12-17 10:57         ` Arnd Bergmann
2014-12-16 23:41     ` Stefan Agner
2014-12-16 23:41       ` Stefan Agner
2014-12-17 12:31       ` Arnd Bergmann
2014-12-17 12:31         ` Arnd Bergmann
2014-12-18 20:36         ` Stefan Agner
2014-12-18 20:36           ` Stefan Agner
2014-12-18 20:36           ` Stefan Agner
2014-12-18 22:44           ` Arnd Bergmann
2014-12-18 22:44             ` Arnd Bergmann
2014-12-18 22:44             ` Arnd Bergmann
2014-12-20 18:49             ` Stefan Agner
2014-12-20 18:49               ` Stefan Agner
2014-12-03  0:12 ` [PATCH 12/12] ARM: vf610m4: add defconfig for Linux on Vybrids Cortex-M4 Stefan Agner
2014-12-03  0:12   ` Stefan Agner
2014-12-03  0:12   ` Stefan Agner

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.