]> pilppa.com Git - linux-2.6-omap-h63xx.git/commitdiff
Merge omap-drivers
authorTony Lindgren <tony@atomide.com>
Tue, 8 May 2007 00:08:50 +0000 (17:08 -0700)
committerTony Lindgren <tony@atomide.com>
Tue, 8 May 2007 00:08:50 +0000 (17:08 -0700)
Conflicts:

arch/arm/configs/omap_h2_1610_defconfig
arch/arm/configs/omap_osk_5912_defconfig
arch/arm/mach-omap1/board-h2.c
arch/arm/mach-omap1/board-palmte.c
arch/arm/mach-omap1/time.c
arch/arm/mach-omap2/Kconfig
arch/arm/mach-omap2/Makefile
arch/arm/mach-omap2/board-2430sdp.c
arch/arm/mach-omap2/board-h4.c
arch/arm/mach-omap2/board-n800-audio.c
arch/arm/mach-omap2/board-n800-dsp.c
arch/arm/mach-omap2/board-n800-usb.c
arch/arm/mach-omap2/devices.c
arch/arm/mach-omap2/pm.c
arch/arm/plat-omap/Kconfig
arch/arm/plat-omap/Makefile
arch/arm/plat-omap/common.c
arch/arm/plat-omap/devices.c
arch/arm/plat-omap/gpio.c
arch/arm/plat-omap/timer32k.c
drivers/Makefile
drivers/i2c/chips/gpio_expander_omap.c
drivers/i2c/chips/menelaus.c
drivers/i2c/chips/tlv320aic23.c
drivers/input/keyboard/Kconfig
drivers/input/keyboard/Makefile
drivers/mtd/onenand/omap2.c
drivers/video/omap/lcdc.c
drivers/video/omap/omapfb_main.c
include/asm-arm/arch-omap/dsp.h
include/asm-arm/arch-omap/eac.h
include/asm-arm/arch-omap/gpio.h
include/asm-arm/arch-omap/omap24xx.h
include/asm-arm/arch-omap/onenand.h
include/asm-arm/hardware/tsc2101.h
net/ipv4/netfilter/Kconfig
net/ipv4/netfilter/Makefile
net/ipv4/netfilter/ipt_IDLETIMER.c

17 files changed:
1  2 
Makefile
arch/arm/mach-omap2/io.c
arch/arm/plat-omap/timer32k.c
drivers/Makefile
drivers/char/Kconfig
drivers/char/Makefile
drivers/input/keyboard/Kconfig
drivers/input/keyboard/Makefile
drivers/input/keyboard/omap-keypad.c
drivers/media/video/Kconfig
drivers/media/video/Makefile
drivers/mmc/host/omap.c
drivers/mtd/nand/Kconfig
drivers/mtd/nand/Makefile
drivers/usb/gadget/Kconfig
include/linux/input.h
net/ipv4/netfilter/Kconfig

diff --cc Makefile
Simple merge
index 871fde3f02b7197edbfa7087d91a65f92bba7bb6,2769171147bcfbe1edb51ad51d60742ba2548fb0..5fa7fc2be030b2ef50c2c78d0dcf391f66a926bd
@@@ -42,12 -42,6 +42,50 @@@ static struct map_desc omap2_io_desc[] 
                .length         = L3_24XX_SIZE,
                .type           = MT_DEVICE
        },
-               .virtual        = L4_24XX_VIRT,
-               .pfn            = __phys_to_pfn(L4_24XX_PHYS),
-               .length         = L4_24XX_SIZE,
++#ifdef CONFIG_ARCH_OMAP2430
++      {
++              .virtual        = L4_WK_243X_VIRT,
++              .pfn            = __phys_to_pfn(L4_WK_243X_PHYS),
++              .length         = L4_WK_243X_SIZE,
++              .type           = MT_DEVICE
++      },
++      {
++              .virtual        = OMAP243X_GPMC_VIRT,
++              .pfn            = __phys_to_pfn(OMAP243X_GPMC_PHYS),
++              .length         = OMAP243X_GPMC_SIZE,
++              .type           = MT_DEVICE
++      },
++      {
++              .virtual        = OMAP243X_SDRC_VIRT,
++              .pfn            = __phys_to_pfn(OMAP243X_SDRC_PHYS),
++              .length         = OMAP243X_SDRC_SIZE,
++              .type           = MT_DEVICE
++      },
++      {
++              .virtual        = OMAP243X_SMS_VIRT,
++              .pfn            = __phys_to_pfn(OMAP243X_SMS_PHYS),
++              .length         = OMAP243X_SMS_SIZE,
++              .type           = MT_DEVICE
++      },
++#endif
++      {
++              .virtual        = DSP_MEM_24XX_VIRT,
++              .pfn            = __phys_to_pfn(DSP_MEM_24XX_PHYS),
++              .length         = DSP_MEM_24XX_SIZE,
++              .type           = MT_DEVICE
++      },
++      {
++              .virtual        = DSP_IPI_24XX_VIRT,
++              .pfn            = __phys_to_pfn(DSP_IPI_24XX_PHYS),
++              .length         = DSP_IPI_24XX_SIZE,
++              .type           = MT_DEVICE
++      },
 +      {
++              .virtual        = DSP_MMU_24XX_VIRT,
++              .pfn            = __phys_to_pfn(DSP_MMU_24XX_PHYS),
++              .length         = DSP_MMU_24XX_SIZE,
 +              .type           = MT_DEVICE
 +      },
  #ifdef CONFIG_ARCH_OMAP2430
        {
                .virtual        = L4_WK_243X_VIRT,
index f28e12883e927eec01f98d7644e94772e01067c0,114f87151d601a303d9080dbff7d2617b86f87ff..2653106011618b2a2279eb894298b8390ff2c1ed
@@@ -42,7 -42,8 +42,6 @@@
  #include <linux/spinlock.h>
  #include <linux/err.h>
  #include <linux/clk.h>
--#include <linux/clocksource.h>
 -#include <linux/clockchips.h>
  
  #include <asm/system.h>
  #include <asm/hardware.h>
@@@ -171,6 -194,6 +170,15 @@@ omap_32k_ticks_to_nsecs(unsigned long t
  
  static unsigned long omap_32k_last_tick = 0;
  
++/*
++ * Returns elapsed usecs since last 32k timer interrupt
++ */
++static unsigned long omap_32k_timer_gettimeoffset(void)
++{
++      unsigned long now = omap_32k_sync_timer_read();
++      return omap_32k_ticks_to_usecs(now - omap_32k_last_tick);
++}
++
  /*
   * Returns current time from boot in nsecs. It's OK for this to wrap
   * around for now, as it's just a relative time stamp.
@@@ -180,106 -203,16 +188,95 @@@ unsigned long long sched_clock(void
        return omap_32k_ticks_to_nsecs(omap_32k_sync_timer_read());
  }
  
 -static irqreturn_t omap_32k_timer_interrupt(int irq, void *dev_id)
 +/*
 + * Timer interrupt for 32KHz timer. When dynamic tick is enabled, this
 + * function is also called from other interrupts to remove latency
 + * issues with dynamic tick. In the dynamic tick case, we need to lock
 + * with irqsave.
 + */
 +static inline irqreturn_t _omap_32k_timer_interrupt(int irq, void *dev_id)
  {
 -      struct clock_event_device *evt = &clockevent_32k_timer;
 +      unsigned long now;
 +
        omap_32k_timer_ack_irq();
 +      now = omap_32k_sync_timer_read();
 +
 +      while ((signed long)(now - omap_32k_last_tick)
 +                                              >= OMAP_32K_TICKS_PER_HZ) {
 +              omap_32k_last_tick += OMAP_32K_TICKS_PER_HZ;
 +              timer_tick();
 +      }
 +
 +      /* Restart timer so we don't drift off due to modulo or dynamic tick.
 +       * By default we program the next timer to be continuous to avoid
 +       * latencies during high system load. During dynamic tick operation the
 +       * continuous timer can be overridden from pm_idle to be longer.
 +       */
 +      omap_32k_timer_start(omap_32k_last_tick + OMAP_32K_TICKS_PER_HZ - now);
 +
 +      return IRQ_HANDLED;
 +}
 +
++static irqreturn_t omap_32k_timer_handler(int irq, void *dev_id)
++{
++      return _omap_32k_timer_interrupt(irq, dev_id);
++}
++
 +static irqreturn_t omap_32k_timer_interrupt(int irq, void *dev_id)
 +{
 +      unsigned long flags;
  
 -      evt->event_handler(evt);
 +      write_seqlock_irqsave(&xtime_lock, flags);
 +      _omap_32k_timer_interrupt(irq, dev_id);
 +      write_sequnlock_irqrestore(&xtime_lock, flags);
  
        return IRQ_HANDLED;
  }
  
- static irqreturn_t omap_32k_timer_handler(int irq, void *dev_id)
- {
-       unsigned long now;
-       now = omap_32k_sync_timer_read();
-       /* Don't bother reprogramming timer if last tick was before next
-        * jiffie. We will get another interrupt when previously programmed
-        * timer expires. This cuts down interrupt load quite a bit.
-        */
-       if (now - omap_32k_last_tick < OMAP_32K_TICKS_PER_HZ)
-               return IRQ_HANDLED;
-       return _omap_32k_timer_interrupt(irq, dev_id);
- }
 +#ifdef CONFIG_NO_IDLE_HZ
 +/*
 + * Programs the next timer interrupt needed. Called when dynamic tick is
 + * enabled, and to reprogram the ticks to skip from pm_idle. Note that
 + * we can keep the timer continuous, and don't need to set it to run in
 + * one-shot mode. This is because the timer will get reprogrammed again
 + * after next interrupt.
 + */
 +void omap_32k_timer_reprogram(unsigned long next_tick)
 +{
 +      unsigned long ticks = JIFFIES_TO_HW_TICKS(next_tick, 32768) + 1;
 +      unsigned long now = omap_32k_sync_timer_read();
 +      unsigned long idled = now - omap_32k_last_tick;
 +
 +      if (idled + 1 < ticks)
 +              ticks -= idled;
 +      else
 +              ticks = 1;
 +      omap_32k_timer_start(ticks);
 +}
 +
 +static struct irqaction omap_32k_timer_irq;
 +extern struct timer_update_handler timer_update;
 +
 +static int omap_32k_timer_enable_dyn_tick(void)
 +{
 +      /* No need to reprogram timer, just use the next interrupt */
 +      return 0;
 +}
 +
 +static int omap_32k_timer_disable_dyn_tick(void)
 +{
 +      omap_32k_timer_start(OMAP_32K_TIMER_TICK_PERIOD);
 +      return 0;
 +}
 +
 +static struct dyn_tick_timer omap_dyn_tick_timer = {
 +      .enable         = omap_32k_timer_enable_dyn_tick,
 +      .disable        = omap_32k_timer_disable_dyn_tick,
 +      .reprogram      = omap_32k_timer_reprogram,
 +      .handler        = omap_32k_timer_handler,
 +};
 +#endif        /* CONFIG_NO_IDLE_HZ */
 +
  static struct irqaction omap_32k_timer_irq = {
        .name           = "32KHz timer",
        .flags          = IRQF_DISABLED | IRQF_TIMER,
  
  static __init void omap_init_32k_timer(void)
  {
 +#ifdef CONFIG_NO_IDLE_HZ
 +      omap_timer.dyn_tick = &omap_dyn_tick_timer;
 +#endif
 +
        if (cpu_class_is_omap1())
                setup_irq(INT_OS_TIMER, &omap_32k_timer_irq);
++      omap_timer.offset  = omap_32k_timer_gettimeoffset;
        omap_32k_last_tick = omap_32k_sync_timer_read();
  
  #ifdef CONFIG_ARCH_OMAP2
@@@ -328,4 -266,4 +326,5 @@@ static void __init omap_timer_init(void
  
  struct sys_timer omap_timer = {
        .init           = omap_timer_init,
++      .offset         = NULL,         /* Initialized later */
  };
index a8b7fba015a7cb679ccfe3eff4cf934eea6c0418,7fe5da8f323770af6853b0fc54ff655e9e1228ef..55a613a2154796d607e4c3f29e1606bb58652024
@@@ -25,14 -25,9 +25,14 @@@ obj-$(CONFIG_CONNECTOR)             += connector
  obj-$(CONFIG_FB_I810)           += video/i810/
  obj-$(CONFIG_FB_INTEL)          += video/intelfb/
  
 +# we also need input/serio early so serio bus is initialized by the time
 +# serial drivers start registering their serio ports
 +obj-$(CONFIG_SERIO)           += input/serio/
  obj-y                         += serial/
  obj-$(CONFIG_PARPORT)         += parport/
- obj-y                         += base/ block/ misc/ mfd/ net/ media/
+ obj-y                         += base/ block/ misc/ mfd/ net/ media/ cbus/
 +obj-$(CONFIG_I2C)             += i2c/
 +obj-y                         += cbus/
  obj-$(CONFIG_NUBUS)           += nubus/
  obj-$(CONFIG_ATM)             += atm/
  obj-y                         += macintosh/
Simple merge
Simple merge
index 6fefc4dfa92af2ca9b4d2bb931267a1bfcdd8466,9f42e4d3649efe83178e2e89a2b9fd6c9debef72..6fa5416c8c5ee4f77c3b74b2b35fa5e70a943022
@@@ -203,16 -214,15 +214,25 @@@ config KEYBOARD_OMA
          To compile this driver as a module, choose M here: the
          module will be called omap-keypad.
  
 +config OMAP_PS2
 +      tristate "TI OMAP Innovator 1510 PS/2 keyboard & mouse support"
 +      depends on ARCH_OMAP15XX && MACH_OMAP_INNOVATOR
 +      help
 +        Say Y here if you want to use the OMAP Innovator 1510 PS/2
 +        keyboard and mouse.
 +
 +        To compile this driver as a module, choose M here: the
 +        module will be called innovator_ps2.
 +
+ config KEYBOARD_PXA27x
+       tristate "PXA27x keyboard support"
+       depends on PXA27x
+       help
+         Enable support for PXA27x matrix keyboard controller
+         To compile this driver as a module, choose M here: the
+         module will be called pxa27x_keyboard.
  config KEYBOARD_AAED2000
        tristate "AAED-2000 keyboard"
        depends on MACH_AAED2000
index f80aebe1c9df1995aa731098f224fb666cd369be,28d211b87b1486ea95ce661910c77e197f7d4a77..0e36829b24384628e2401fc78158f4e03059e869
@@@ -16,9 -17,8 +17,10 @@@ obj-$(CONFIG_KEYBOARD_CORGI)         += corgik
  obj-$(CONFIG_KEYBOARD_SPITZ)          += spitzkbd.o
  obj-$(CONFIG_KEYBOARD_HIL)            += hil_kbd.o
  obj-$(CONFIG_KEYBOARD_HIL_OLD)                += hilkbd.o
 -obj-$(CONFIG_KEYBOARD_OMAP)           += omap-keypad.o
 +obj-$(CONFIG_KEYBOARD_OMAP)             += omap-keypad.o
 +obj-$(CONFIG_OMAP_PS2)                        += innovator_ps2.o
+ obj-$(CONFIG_KEYBOARD_PXA27x)         += pxa27x_keyboard.o
 -obj-$(CONFIG_KEYBOARD_AAED2000)               += aaed2000_kbd.o
 +obj-$(CONFIG_KEYBOARD_AAED2000)         += aaed2000_kbd.o
  obj-$(CONFIG_KEYBOARD_GPIO)           += gpio_keys.o
 +obj-$(CONFIG_KEYBOARD_TSC2301)                += tsc2301_kp.o
  
Simple merge
index 0fcf22e2a09e8d2d84f37650fa8f9e991106432c,bc773781993a5b75113388a623f12f64fa697556..653842ccd47cb05b355fbf87f1648dfd68c40d45
@@@ -761,8 -763,18 +763,20 @@@ source "drivers/media/video/zc0301/Kcon
  
  source "drivers/media/video/pwc/Kconfig"
  
+ config USB_ZR364XX
+       tristate "USB ZR364XX Camera support"
+       depends on USB && VIDEO_V4L2
+       ---help---
+         Say Y here if you want to connect this type of camera to your
+         computer's USB port.
+         See <file:Documentation/video4linux/zr364xx.txt> for more info
+         and list of supported cameras.
+         To compile this driver as a module, choose M here: the
+         module will be called zr364xx.
  endmenu # V4L USB devices
  
 +source drivers/media/video/omap/Kconfig
 +
  endmenu
Simple merge
Simple merge
index d086b6105411ed0459f9921f12154003b2a2008b,d05873b8c155a8f8c478fc86cd522ca792441451..7d641f4056c7bfb743fc8d46b7cfeaed3d12f5e6
@@@ -63,22 -69,9 +69,22 @@@ config MTD_NAND_AMS_DELT
        help
          Support for NAND flash on Amstrad E3 (Delta).
  
 +config MTD_NAND_OMAP
 +      tristate "NAND Flash device on OMAP H3/H2/P2 boards"
 +      depends on ARM && ARCH_OMAP1 && MTD_NAND && (MACH_OMAP_H2 || MACH_OMAP_H3 || MACH_OMAP_PERSEUS2)
 +      help
 +        Support for NAND flash on Texas Instruments H3/H2/P2 platforms.
 +
 +config MTD_NAND_OMAP_HW
 +      bool "OMAP HW NAND Flash controller support"
 +        depends on ARM && ARCH_OMAP16XX && MTD_NAND
 +
 +      help
 +        Driver for TI OMAP16xx hardware NAND flash controller.
 +
  config MTD_NAND_TOTO
        tristate "NAND Flash device on TOTO board"
-       depends on ARCH_OMAP && MTD_NAND && BROKEN
+       depends on ARCH_OMAP && BROKEN
        help
          Support for NAND flash on Texas Instruments Toto platform.
  
index 1d5f12ffa6d6f02f1b753eeaa58a406ceba54660,6872031a3fb25ff45d4e263691133d4698d94c8f..5a0739ec4bda5fe994feab229379ba206acefdea
@@@ -23,9 -23,8 +23,10 @@@ obj-$(CONFIG_MTD_NAND_TS7250)                += ts725
  obj-$(CONFIG_MTD_NAND_NANDSIM)                += nandsim.o
  obj-$(CONFIG_MTD_NAND_CS553X)         += cs553x_nand.o
  obj-$(CONFIG_MTD_NAND_NDFC)           += ndfc.o
 +obj-$(CONFIG_MTD_NAND_OMAP)           += omap-nand-flash.o
 +obj-$(CONFIG_MTD_NAND_OMAP_HW)                += omap-hw.o
  obj-$(CONFIG_MTD_NAND_AT91)           += at91_nand.o
+ obj-$(CONFIG_MTD_NAND_CM_X270)                += cmx270_nand.o
  obj-$(CONFIG_MTD_NAND_BASLER_EXCITE)  += excite_nandflash.o
  
  nand-objs := nand_base.o nand_bbt.o
Simple merge
Simple merge
index c5100eea83b1fd3bb8666bd1eee8ec463b1c6b23,93b9fc76a18530fd1c860061f8eeb3e164368104..ede368afea1a6ace1de8e77c39645886ea8c1763
@@@ -446,21 -248,6 +248,9 @@@ config IP_NF_TARGET_IDLETIME
  
          To compile it as a module, choose M here.  If unsure, say N.
  
- config IP_NF_NAT_SNMP_BASIC
-       tristate "Basic SNMP-ALG support (EXPERIMENTAL)"
-       depends on EXPERIMENTAL && IP_NF_NAT
-       ---help---
-         This module implements an Application Layer Gateway (ALG) for
-         SNMP payloads.  In conjunction with NAT, it allows a network
-         management system to access multiple private networks with
-         conflicting addresses.  It works by modifying IP addresses
-         inside SNMP payloads to match IP-layer NAT mapping.
-         This is the "basic" form of SNMP-ALG, as described in RFC 2962
 +
 +        To compile it as a module, choose M here.  If unsure, say N.
 +
  config NF_NAT_SNMP_BASIC
        tristate "Basic SNMP-ALG support (EXPERIMENTAL)"
        depends on EXPERIMENTAL && NF_NAT