Re: [PATCH V5 2/4] DRIVERS: IRQCHIP: CROSSBAR: Add support for Crossbar IP

2014-02-28 Thread Tony Lindgren
* Sricharan R r.sricha...@ti.com [140205 06:13]:
 Tony,
 
 On Wednesday 05 February 2014 06:41 PM, Sricharan R wrote:
  On Tuesday 04 February 2014 09:44 PM, Thomas Gleixner wrote:
  On Mon, 3 Feb 2014, Sricharan R wrote:
  I already have your reviewed-by tag for the first patch in this series.
 
  Kevin was pointing out that irqchip maintainer tag is needed for this 
  patch as well
  to be merged. We are planning to take this series through arm-soc tree.
 
  Can i please have your tag for this patch as well ?
 
  Acked-by-me
  --
  To unsubscribe from this list: send the line unsubscribe linux-omap in
  the body of a message to majord...@vger.kernel.org
  More majordomo info at  http://vger.kernel.org/majordomo-info.html
  
  Thanks Thomas.
  
  Kevin,
  I will re-send a branch based on rc1 for this.
  
 
 I have pushed a branch based on mainline,
git://github.com/Sricharanti/sricharan.git
branch: crossbar_3.14_rc1

OK pulling into omap-for-v3.15/crossbar thanks.

Tony
--
To unsubscribe from this list: send the line unsubscribe linux-omap in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH V5 2/4] DRIVERS: IRQCHIP: CROSSBAR: Add support for Crossbar IP

2014-02-25 Thread Sricharan R
Hi Tony,

On Wednesday 05 February 2014 07:41 PM, Sricharan R wrote:
 Tony,
 
 On Wednesday 05 February 2014 06:41 PM, Sricharan R wrote:
 On Tuesday 04 February 2014 09:44 PM, Thomas Gleixner wrote:
 On Mon, 3 Feb 2014, Sricharan R wrote:
 I already have your reviewed-by tag for the first patch in this series.

 Kevin was pointing out that irqchip maintainer tag is needed for this 
 patch as well
 to be merged. We are planning to take this series through arm-soc tree.

 Can i please have your tag for this patch as well ?

 Acked-by-me
 --
 To unsubscribe from this list: send the line unsubscribe linux-omap in
 the body of a message to majord...@vger.kernel.org
 More majordomo info at  http://vger.kernel.org/majordomo-info.html

 Thanks Thomas.

 Kevin,
 I will re-send a branch based on rc1 for this.

 
 I have pushed a branch based on mainline,
git://github.com/Sricharanti/sricharan.git
branch: crossbar_3.14_rc1
 
 Ping on this..

Regards,
 Sricharan
--
To unsubscribe from this list: send the line unsubscribe linux-omap in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH V5 2/4] DRIVERS: IRQCHIP: CROSSBAR: Add support for Crossbar IP

2014-02-05 Thread Sricharan R
On Tuesday 04 February 2014 09:44 PM, Thomas Gleixner wrote:
 On Mon, 3 Feb 2014, Sricharan R wrote:
 I already have your reviewed-by tag for the first patch in this series.

 Kevin was pointing out that irqchip maintainer tag is needed for this patch 
 as well
 to be merged. We are planning to take this series through arm-soc tree.

 Can i please have your tag for this patch as well ?
 
 Acked-by-me
 --
 To unsubscribe from this list: send the line unsubscribe linux-omap in
 the body of a message to majord...@vger.kernel.org
 More majordomo info at  http://vger.kernel.org/majordomo-info.html

Thanks Thomas.

Kevin,
I will re-send a branch based on rc1 for this.

Regards,
 Sricharan
--
To unsubscribe from this list: send the line unsubscribe linux-omap in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH V5 2/4] DRIVERS: IRQCHIP: CROSSBAR: Add support for Crossbar IP

2014-02-05 Thread Sricharan R
Tony,

On Wednesday 05 February 2014 06:41 PM, Sricharan R wrote:
 On Tuesday 04 February 2014 09:44 PM, Thomas Gleixner wrote:
 On Mon, 3 Feb 2014, Sricharan R wrote:
 I already have your reviewed-by tag for the first patch in this series.

 Kevin was pointing out that irqchip maintainer tag is needed for this 
 patch as well
 to be merged. We are planning to take this series through arm-soc tree.

 Can i please have your tag for this patch as well ?

 Acked-by-me
 --
 To unsubscribe from this list: send the line unsubscribe linux-omap in
 the body of a message to majord...@vger.kernel.org
 More majordomo info at  http://vger.kernel.org/majordomo-info.html
 
 Thanks Thomas.
 
 Kevin,
 I will re-send a branch based on rc1 for this.
 

I have pushed a branch based on mainline,
   git://github.com/Sricharanti/sricharan.git
   branch: crossbar_3.14_rc1

Regards,
 Sricharan

--
To unsubscribe from this list: send the line unsubscribe linux-omap in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH V5 2/4] DRIVERS: IRQCHIP: CROSSBAR: Add support for Crossbar IP

2014-02-04 Thread Thomas Gleixner
On Mon, 3 Feb 2014, Sricharan R wrote:
  I already have your reviewed-by tag for the first patch in this series.
  
  Kevin was pointing out that irqchip maintainer tag is needed for this patch 
  as well
  to be merged. We are planning to take this series through arm-soc tree.
  
  Can i please have your tag for this patch as well ?

Acked-by-me
--
To unsubscribe from this list: send the line unsubscribe linux-omap in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH V5 2/4] DRIVERS: IRQCHIP: CROSSBAR: Add support for Crossbar IP

2014-02-03 Thread Sricharan R
Hi Thomas,

On Thursday 16 January 2014 03:52 PM, Sricharan R wrote:
 Hi Thomas,
 
 On Tuesday 03 December 2013 03:57 PM, Sricharan R wrote:
 Some socs have a large number of interrupts requests to service
 the needs of its many peripherals and subsystems. All of the
 interrupt lines from the subsystems are not needed at the same
 time, so they have to be muxed to the irq-controller appropriately.
 In such places a interrupt controllers are preceded by an CROSSBAR
 that provides flexibility in muxing the device requests to the controller
 inputs.

 This driver takes care a allocating a free irq and then configuring the
 crossbar IP as a part of the mpu's irqchip callbacks. crossbar_init should
 be called right before the irqchip_init, so that it is setup to handle the
 irqchip callbacks.

 Cc: Thomas Gleixner t...@linutronix.de
 Cc: Linus Walleij linus.wall...@linaro.org
 Cc: Santosh Shilimkar santosh.shilim...@ti.com
 Cc: Russell King li...@arm.linux.org.uk
 Cc: Tony Lindgren t...@atomide.com
 Cc: Rajendra Nayak rna...@ti.com
 Cc: Marc Zyngier marc.zyng...@arm.com
 Cc: Grant Likely grant.lik...@linaro.org
 Cc: Rob Herring rob.herr...@calxeda.com
 Signed-off-by: Sricharan R r.sricha...@ti.com
 Acked-by: Kumar Gala ga...@codeaurora.org (for DT binding portion)
 Acked-by: Santosh Shilimkar santosh.shilim...@ti.com
 Acked-by: Linus Walleij linus.wall...@linaro.org
 ---
  [v5] Used the function of_property_read_u32_index instead of raw reading
   from DT as per comments from Mark Rutland mark.rutl...@arm.com

  .../devicetree/bindings/arm/omap/crossbar.txt  |   27 +++
  drivers/irqchip/Kconfig|8 +
  drivers/irqchip/Makefile   |1 +
  drivers/irqchip/irq-crossbar.c |  208 
 
  include/linux/irqchip/irq-crossbar.h   |   11 ++
  5 files changed, 255 insertions(+)
  create mode 100644 Documentation/devicetree/bindings/arm/omap/crossbar.txt
  create mode 100644 drivers/irqchip/irq-crossbar.c
  create mode 100644 include/linux/irqchip/irq-crossbar.h

 diff --git a/Documentation/devicetree/bindings/arm/omap/crossbar.txt 
 b/Documentation/devicetree/bindings/arm/omap/crossbar.txt
 new file mode 100644
 index 000..fb88585
 --- /dev/null
 +++ b/Documentation/devicetree/bindings/arm/omap/crossbar.txt
 @@ -0,0 +1,27 @@
 +Some socs have a large number of interrupts requests to service
 +the needs of its many peripherals and subsystems. All of the
 +interrupt lines from the subsystems are not needed at the same
 +time, so they have to be muxed to the irq-controller appropriately.
 +In such places a interrupt controllers are preceded by an CROSSBAR
 +that provides flexibility in muxing the device requests to the controller
 +inputs.
 +
 +Required properties:
 +- compatible : Should be ti,irq-crossbar
 +- reg: Base address and the size of the crossbar registers.
 +- ti,max-irqs: Total number of irqs available at the interrupt controller.
 +- ti,reg-size: Size of a individual register in bytes. Every individual
 +register is assumed to be of same size. Valid sizes are 1, 2, 4.
 +- ti,irqs-reserved: List of the reserved irq lines that are not muxed using
 + crossbar. These interrupt lines are reserved in the soc,
 + so crossbar bar driver should not consider them as free
 + lines.
 +
 +Examples:
 +crossbar_mpu: @4a02 {
 +compatible = ti,irq-crossbar;
 +reg = 0x4a002a48 0x130;
 +ti,max-irqs = 160;
 +ti,reg-size = 2;
 +ti,irqs-reserved = 0 1 2 3 5 6 131 132 139 140;
 +};
 diff --git a/drivers/irqchip/Kconfig b/drivers/irqchip/Kconfig
 index 3792a1a..2efcde6 100644
 --- a/drivers/irqchip/Kconfig
 +++ b/drivers/irqchip/Kconfig
 @@ -61,3 +61,11 @@ config VERSATILE_FPGA_IRQ_NR
 int
 default 4
 depends on VERSATILE_FPGA_IRQ
 +
 +config IRQ_CROSSBAR
 +bool
 +help
 +  Support for a CROSSBAR ip that preceeds the main interrupt controller.
 +  The primary irqchip invokes the crossbar's callback which inturn 
 allocates
 +  a free irq and configures the IP. Thus the peripheral interrupts are
 +  routed to one of the free irqchip interrupt lines.
 diff --git a/drivers/irqchip/Makefile b/drivers/irqchip/Makefile
 index c60b901..2edead9 100644
 --- a/drivers/irqchip/Makefile
 +++ b/drivers/irqchip/Makefile
 @@ -22,3 +22,4 @@ obj-$(CONFIG_RENESAS_IRQC) += irq-renesas-irqc.o
  obj-$(CONFIG_VERSATILE_FPGA_IRQ)+= irq-versatile-fpga.o
  obj-$(CONFIG_ARCH_VT8500)   += irq-vt8500.o
  obj-$(CONFIG_TB10X_IRQC)+= irq-tb10x.o
 +obj-$(CONFIG_IRQ_CROSSBAR)  += irq-crossbar.o
 diff --git a/drivers/irqchip/irq-crossbar.c b/drivers/irqchip/irq-crossbar.c
 new file mode 100644
 index 000..ae605a3
 --- /dev/null
 +++ b/drivers/irqchip/irq-crossbar.c
 @@ -0,0 +1,208 @@
 +/*
 + *  

Re: [PATCH V5 2/4] DRIVERS: IRQCHIP: CROSSBAR: Add support for Crossbar IP

2014-01-16 Thread Sricharan R
Hi Thomas,

On Tuesday 03 December 2013 03:57 PM, Sricharan R wrote:
 Some socs have a large number of interrupts requests to service
 the needs of its many peripherals and subsystems. All of the
 interrupt lines from the subsystems are not needed at the same
 time, so they have to be muxed to the irq-controller appropriately.
 In such places a interrupt controllers are preceded by an CROSSBAR
 that provides flexibility in muxing the device requests to the controller
 inputs.
 
 This driver takes care a allocating a free irq and then configuring the
 crossbar IP as a part of the mpu's irqchip callbacks. crossbar_init should
 be called right before the irqchip_init, so that it is setup to handle the
 irqchip callbacks.
 
 Cc: Thomas Gleixner t...@linutronix.de
 Cc: Linus Walleij linus.wall...@linaro.org
 Cc: Santosh Shilimkar santosh.shilim...@ti.com
 Cc: Russell King li...@arm.linux.org.uk
 Cc: Tony Lindgren t...@atomide.com
 Cc: Rajendra Nayak rna...@ti.com
 Cc: Marc Zyngier marc.zyng...@arm.com
 Cc: Grant Likely grant.lik...@linaro.org
 Cc: Rob Herring rob.herr...@calxeda.com
 Signed-off-by: Sricharan R r.sricha...@ti.com
 Acked-by: Kumar Gala ga...@codeaurora.org (for DT binding portion)
 Acked-by: Santosh Shilimkar santosh.shilim...@ti.com
 Acked-by: Linus Walleij linus.wall...@linaro.org
 ---
  [v5] Used the function of_property_read_u32_index instead of raw reading
   from DT as per comments from Mark Rutland mark.rutl...@arm.com
 
  .../devicetree/bindings/arm/omap/crossbar.txt  |   27 +++
  drivers/irqchip/Kconfig|8 +
  drivers/irqchip/Makefile   |1 +
  drivers/irqchip/irq-crossbar.c |  208 
 
  include/linux/irqchip/irq-crossbar.h   |   11 ++
  5 files changed, 255 insertions(+)
  create mode 100644 Documentation/devicetree/bindings/arm/omap/crossbar.txt
  create mode 100644 drivers/irqchip/irq-crossbar.c
  create mode 100644 include/linux/irqchip/irq-crossbar.h
 
 diff --git a/Documentation/devicetree/bindings/arm/omap/crossbar.txt 
 b/Documentation/devicetree/bindings/arm/omap/crossbar.txt
 new file mode 100644
 index 000..fb88585
 --- /dev/null
 +++ b/Documentation/devicetree/bindings/arm/omap/crossbar.txt
 @@ -0,0 +1,27 @@
 +Some socs have a large number of interrupts requests to service
 +the needs of its many peripherals and subsystems. All of the
 +interrupt lines from the subsystems are not needed at the same
 +time, so they have to be muxed to the irq-controller appropriately.
 +In such places a interrupt controllers are preceded by an CROSSBAR
 +that provides flexibility in muxing the device requests to the controller
 +inputs.
 +
 +Required properties:
 +- compatible : Should be ti,irq-crossbar
 +- reg: Base address and the size of the crossbar registers.
 +- ti,max-irqs: Total number of irqs available at the interrupt controller.
 +- ti,reg-size: Size of a individual register in bytes. Every individual
 + register is assumed to be of same size. Valid sizes are 1, 2, 4.
 +- ti,irqs-reserved: List of the reserved irq lines that are not muxed using
 +  crossbar. These interrupt lines are reserved in the soc,
 +  so crossbar bar driver should not consider them as free
 +  lines.
 +
 +Examples:
 + crossbar_mpu: @4a02 {
 + compatible = ti,irq-crossbar;
 + reg = 0x4a002a48 0x130;
 + ti,max-irqs = 160;
 + ti,reg-size = 2;
 + ti,irqs-reserved = 0 1 2 3 5 6 131 132 139 140;
 + };
 diff --git a/drivers/irqchip/Kconfig b/drivers/irqchip/Kconfig
 index 3792a1a..2efcde6 100644
 --- a/drivers/irqchip/Kconfig
 +++ b/drivers/irqchip/Kconfig
 @@ -61,3 +61,11 @@ config VERSATILE_FPGA_IRQ_NR
 int
 default 4
 depends on VERSATILE_FPGA_IRQ
 +
 +config IRQ_CROSSBAR
 + bool
 + help
 +   Support for a CROSSBAR ip that preceeds the main interrupt controller.
 +   The primary irqchip invokes the crossbar's callback which inturn 
 allocates
 +   a free irq and configures the IP. Thus the peripheral interrupts are
 +   routed to one of the free irqchip interrupt lines.
 diff --git a/drivers/irqchip/Makefile b/drivers/irqchip/Makefile
 index c60b901..2edead9 100644
 --- a/drivers/irqchip/Makefile
 +++ b/drivers/irqchip/Makefile
 @@ -22,3 +22,4 @@ obj-$(CONFIG_RENESAS_IRQC)  += irq-renesas-irqc.o
  obj-$(CONFIG_VERSATILE_FPGA_IRQ) += irq-versatile-fpga.o
  obj-$(CONFIG_ARCH_VT8500)+= irq-vt8500.o
  obj-$(CONFIG_TB10X_IRQC) += irq-tb10x.o
 +obj-$(CONFIG_IRQ_CROSSBAR)   += irq-crossbar.o
 diff --git a/drivers/irqchip/irq-crossbar.c b/drivers/irqchip/irq-crossbar.c
 new file mode 100644
 index 000..ae605a3
 --- /dev/null
 +++ b/drivers/irqchip/irq-crossbar.c
 @@ -0,0 +1,208 @@
 +/*
 + *  drivers/irqchip/irq-crossbar.c
 + *
 + *  

Re: [PATCH V5 2/4] DRIVERS: IRQCHIP: CROSSBAR: Add support for Crossbar IP

2013-12-27 Thread Sricharan R
Hi Felipe,

On Friday 27 December 2013 01:31 AM, Felipe Balbi wrote:
 Hi,
 
 On Tue, Dec 03, 2013 at 03:57:23PM +0530, Sricharan R wrote:
 +static const struct of_device_id crossbar_match[] __initconst = {
 +{ .compatible = ti,irq-crossbar },
 +{}
 +};
 +
 +int irqcrossbar_init(void)
 +{
 +struct device_node *np;
 +np = of_find_matching_node(NULL, crossbar_match);
 +if (!np)
 +return -ENODEV;
 +
 +crossbar_of_init(np);
 +return 0;
 +}
 
 instead, please use IRQCHIP_DECLARE() then you won't need to expose this
 symbol to be used by arch/arm/ code.
 

Crossbar node does not have a interrupt-controller property and
not a regular Interrupt controller. This was added in here
after all below discussions

 https://lkml.org/lkml/2013/9/18/540

So IRQCHIP_DECLARE() macro cannot be used here.

Regards,
 Sricharan
--
To unsubscribe from this list: send the line unsubscribe linux-omap in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH V5 2/4] DRIVERS: IRQCHIP: CROSSBAR: Add support for Crossbar IP

2013-12-26 Thread Felipe Balbi
Hi,

On Tue, Dec 03, 2013 at 03:57:23PM +0530, Sricharan R wrote:
 +static const struct of_device_id crossbar_match[] __initconst = {
 + { .compatible = ti,irq-crossbar },
 + {}
 +};
 +
 +int irqcrossbar_init(void)
 +{
 + struct device_node *np;
 + np = of_find_matching_node(NULL, crossbar_match);
 + if (!np)
 + return -ENODEV;
 +
 + crossbar_of_init(np);
 + return 0;
 +}

instead, please use IRQCHIP_DECLARE() then you won't need to expose this
symbol to be used by arch/arm/ code.

-- 
balbi


signature.asc
Description: Digital signature


[PATCH V5 2/4] DRIVERS: IRQCHIP: CROSSBAR: Add support for Crossbar IP

2013-12-03 Thread Sricharan R
Some socs have a large number of interrupts requests to service
the needs of its many peripherals and subsystems. All of the
interrupt lines from the subsystems are not needed at the same
time, so they have to be muxed to the irq-controller appropriately.
In such places a interrupt controllers are preceded by an CROSSBAR
that provides flexibility in muxing the device requests to the controller
inputs.

This driver takes care a allocating a free irq and then configuring the
crossbar IP as a part of the mpu's irqchip callbacks. crossbar_init should
be called right before the irqchip_init, so that it is setup to handle the
irqchip callbacks.

Cc: Thomas Gleixner t...@linutronix.de
Cc: Linus Walleij linus.wall...@linaro.org
Cc: Santosh Shilimkar santosh.shilim...@ti.com
Cc: Russell King li...@arm.linux.org.uk
Cc: Tony Lindgren t...@atomide.com
Cc: Rajendra Nayak rna...@ti.com
Cc: Marc Zyngier marc.zyng...@arm.com
Cc: Grant Likely grant.lik...@linaro.org
Cc: Rob Herring rob.herr...@calxeda.com
Signed-off-by: Sricharan R r.sricha...@ti.com
Acked-by: Kumar Gala ga...@codeaurora.org (for DT binding portion)
Acked-by: Santosh Shilimkar santosh.shilim...@ti.com
Acked-by: Linus Walleij linus.wall...@linaro.org
---
 [v5] Used the function of_property_read_u32_index instead of raw reading
  from DT as per comments from Mark Rutland mark.rutl...@arm.com

 .../devicetree/bindings/arm/omap/crossbar.txt  |   27 +++
 drivers/irqchip/Kconfig|8 +
 drivers/irqchip/Makefile   |1 +
 drivers/irqchip/irq-crossbar.c |  208 
 include/linux/irqchip/irq-crossbar.h   |   11 ++
 5 files changed, 255 insertions(+)
 create mode 100644 Documentation/devicetree/bindings/arm/omap/crossbar.txt
 create mode 100644 drivers/irqchip/irq-crossbar.c
 create mode 100644 include/linux/irqchip/irq-crossbar.h

diff --git a/Documentation/devicetree/bindings/arm/omap/crossbar.txt 
b/Documentation/devicetree/bindings/arm/omap/crossbar.txt
new file mode 100644
index 000..fb88585
--- /dev/null
+++ b/Documentation/devicetree/bindings/arm/omap/crossbar.txt
@@ -0,0 +1,27 @@
+Some socs have a large number of interrupts requests to service
+the needs of its many peripherals and subsystems. All of the
+interrupt lines from the subsystems are not needed at the same
+time, so they have to be muxed to the irq-controller appropriately.
+In such places a interrupt controllers are preceded by an CROSSBAR
+that provides flexibility in muxing the device requests to the controller
+inputs.
+
+Required properties:
+- compatible : Should be ti,irq-crossbar
+- reg: Base address and the size of the crossbar registers.
+- ti,max-irqs: Total number of irqs available at the interrupt controller.
+- ti,reg-size: Size of a individual register in bytes. Every individual
+   register is assumed to be of same size. Valid sizes are 1, 2, 4.
+- ti,irqs-reserved: List of the reserved irq lines that are not muxed using
+crossbar. These interrupt lines are reserved in the soc,
+so crossbar bar driver should not consider them as free
+lines.
+
+Examples:
+   crossbar_mpu: @4a02 {
+   compatible = ti,irq-crossbar;
+   reg = 0x4a002a48 0x130;
+   ti,max-irqs = 160;
+   ti,reg-size = 2;
+   ti,irqs-reserved = 0 1 2 3 5 6 131 132 139 140;
+   };
diff --git a/drivers/irqchip/Kconfig b/drivers/irqchip/Kconfig
index 3792a1a..2efcde6 100644
--- a/drivers/irqchip/Kconfig
+++ b/drivers/irqchip/Kconfig
@@ -61,3 +61,11 @@ config VERSATILE_FPGA_IRQ_NR
int
default 4
depends on VERSATILE_FPGA_IRQ
+
+config IRQ_CROSSBAR
+   bool
+   help
+ Support for a CROSSBAR ip that preceeds the main interrupt controller.
+ The primary irqchip invokes the crossbar's callback which inturn 
allocates
+ a free irq and configures the IP. Thus the peripheral interrupts are
+ routed to one of the free irqchip interrupt lines.
diff --git a/drivers/irqchip/Makefile b/drivers/irqchip/Makefile
index c60b901..2edead9 100644
--- a/drivers/irqchip/Makefile
+++ b/drivers/irqchip/Makefile
@@ -22,3 +22,4 @@ obj-$(CONFIG_RENESAS_IRQC)+= irq-renesas-irqc.o
 obj-$(CONFIG_VERSATILE_FPGA_IRQ)   += irq-versatile-fpga.o
 obj-$(CONFIG_ARCH_VT8500)  += irq-vt8500.o
 obj-$(CONFIG_TB10X_IRQC)   += irq-tb10x.o
+obj-$(CONFIG_IRQ_CROSSBAR) += irq-crossbar.o
diff --git a/drivers/irqchip/irq-crossbar.c b/drivers/irqchip/irq-crossbar.c
new file mode 100644
index 000..ae605a3
--- /dev/null
+++ b/drivers/irqchip/irq-crossbar.c
@@ -0,0 +1,208 @@
+/*
+ *  drivers/irqchip/irq-crossbar.c
+ *
+ *  Copyright (C) 2013 Texas Instruments Incorporated - http://www.ti.com
+ *  Author: Sricharan R r.sricha...@ti.com
+ *
+ * This program is