Merge branch 'for-v3.19/gpmc-omap' of github.com:rogerq/linux into omap-for-v3.19...
authorTony Lindgren <tony@atomide.com>
Tue, 4 Nov 2014 01:45:36 +0000 (17:45 -0800)
committerTony Lindgren <tony@atomide.com>
Tue, 4 Nov 2014 01:45:36 +0000 (17:45 -0800)
Conflicts:
arch/arm/mach-omap2/gpmc.c

1  2 
arch/arm/mach-omap2/gpmc.c

index a7554ac3f37c61ea2a9a90b20b8ee00537782b24,104bc2c5098761228d93b7079c718c8ca36114bd..73189fa9e1fc8f5467fcf0d4445e973e26b80317
@@@ -291,136 -280,8 +288,131 @@@ static void gpmc_cs_bool_timings(int cs
                           p->cycle2cyclediffcsen);
  }
  
- #ifdef DEBUG
 +#ifdef DEBUG
 +static int get_gpmc_timing_reg(int cs, int reg, int st_bit, int end_bit,
 +                             bool raw, bool noval, int shift,
 +                             const char *name)
 +{
 +      u32 l;
 +      int nr_bits, max_value, mask;
 +
 +      l = gpmc_cs_read_reg(cs, reg);
 +      nr_bits = end_bit - st_bit + 1;
 +      max_value = (1 << nr_bits) - 1;
 +      mask = max_value << st_bit;
 +      l = (l & mask) >> st_bit;
 +      if (shift)
 +              l = (shift << l);
 +      if (noval && (l == 0))
 +              return 0;
 +      if (!raw) {
 +              unsigned int time_ns_min, time_ns, time_ns_max;
 +
 +              time_ns_min = gpmc_ticks_to_ns(l ? l - 1 : 0);
 +              time_ns = gpmc_ticks_to_ns(l);
 +              time_ns_max = gpmc_ticks_to_ns(l + 1 > max_value ?
 +                                             max_value : l + 1);
 +              pr_info("gpmc,%s = <%u> (%u - %u ns, %i ticks)\n",
 +                      name, time_ns, time_ns_min, time_ns_max, l);
 +      } else {
 +              pr_info("gpmc,%s = <%u>\n", name, l);
 +      }
 +
 +      return l;
 +}
 +
 +#define GPMC_PRINT_CONFIG(cs, config) \
 +      pr_info("cs%i %s: 0x%08x\n", cs, #config, \
 +              gpmc_cs_read_reg(cs, config))
 +#define GPMC_GET_RAW(reg, st, end, field) \
 +      get_gpmc_timing_reg(cs, (reg), (st), (end), 1, 0, 0, field)
 +#define GPMC_GET_RAW_BOOL(reg, st, end, field) \
 +      get_gpmc_timing_reg(cs, (reg), (st), (end), 1, 1, 0, field)
 +#define GPMC_GET_RAW_SHIFT(reg, st, end, shift, field) \
 +      get_gpmc_timing_reg(cs, (reg), (st), (end), 1, 1, (shift), field)
 +#define GPMC_GET_TICKS(reg, st, end, field) \
 +      get_gpmc_timing_reg(cs, (reg), (st), (end), 0, 0, 0, field)
 +
 +static void gpmc_show_regs(int cs, const char *desc)
 +{
 +      pr_info("gpmc cs%i %s:\n", cs, desc);
 +      GPMC_PRINT_CONFIG(cs, GPMC_CS_CONFIG1);
 +      GPMC_PRINT_CONFIG(cs, GPMC_CS_CONFIG2);
 +      GPMC_PRINT_CONFIG(cs, GPMC_CS_CONFIG3);
 +      GPMC_PRINT_CONFIG(cs, GPMC_CS_CONFIG4);
 +      GPMC_PRINT_CONFIG(cs, GPMC_CS_CONFIG5);
 +      GPMC_PRINT_CONFIG(cs, GPMC_CS_CONFIG6);
 +}
 +
 +/*
 + * Note that gpmc,wait-pin handing wrongly assumes bit 8 is available,
 + * see commit c9fb809.
 + */
 +static void gpmc_cs_show_timings(int cs, const char *desc)
 +{
 +      gpmc_show_regs(cs, desc);
 +
 +      pr_info("gpmc cs%i access configuration:\n", cs);
 +      GPMC_GET_RAW_BOOL(GPMC_CS_CONFIG1,  4,  4, "time-para-granularity");
 +      GPMC_GET_RAW(GPMC_CS_CONFIG1,  8,  9, "mux-add-data");
 +      GPMC_GET_RAW(GPMC_CS_CONFIG1, 12, 13, "device-width");
 +      GPMC_GET_RAW(GPMC_CS_CONFIG1, 16, 17, "wait-pin");
 +      GPMC_GET_RAW_BOOL(GPMC_CS_CONFIG1, 21, 21, "wait-on-write");
 +      GPMC_GET_RAW_BOOL(GPMC_CS_CONFIG1, 22, 22, "wait-on-read");
 +      GPMC_GET_RAW_SHIFT(GPMC_CS_CONFIG1, 23, 24, 4, "burst-length");
 +      GPMC_GET_RAW_BOOL(GPMC_CS_CONFIG1, 27, 27, "sync-write");
 +      GPMC_GET_RAW_BOOL(GPMC_CS_CONFIG1, 28, 28, "burst-write");
 +      GPMC_GET_RAW_BOOL(GPMC_CS_CONFIG1, 29, 29, "gpmc,sync-read");
 +      GPMC_GET_RAW_BOOL(GPMC_CS_CONFIG1, 30, 30, "burst-read");
 +      GPMC_GET_RAW_BOOL(GPMC_CS_CONFIG1, 31, 31, "burst-wrap");
 +
 +      GPMC_GET_RAW_BOOL(GPMC_CS_CONFIG2,  7,  7, "cs-extra-delay");
 +
 +      GPMC_GET_RAW_BOOL(GPMC_CS_CONFIG3,  7,  7, "adv-extra-delay");
 +
 +      GPMC_GET_RAW_BOOL(GPMC_CS_CONFIG4, 23, 23, "we-extra-delay");
 +      GPMC_GET_RAW_BOOL(GPMC_CS_CONFIG4,  7,  7, "oe-extra-delay");
 +
 +      GPMC_GET_RAW_BOOL(GPMC_CS_CONFIG6,  7,  7, "cycle2cycle-samecsen");
 +      GPMC_GET_RAW_BOOL(GPMC_CS_CONFIG6,  6,  6, "cycle2cycle-diffcsen");
 +
 +      pr_info("gpmc cs%i timings configuration:\n", cs);
 +      GPMC_GET_TICKS(GPMC_CS_CONFIG2,  0,  3, "cs-on-ns");
 +      GPMC_GET_TICKS(GPMC_CS_CONFIG2,  8, 12, "cs-rd-off-ns");
 +      GPMC_GET_TICKS(GPMC_CS_CONFIG2, 16, 20, "cs-wr-off-ns");
 +
 +      GPMC_GET_TICKS(GPMC_CS_CONFIG3,  0,  3, "adv-on-ns");
 +      GPMC_GET_TICKS(GPMC_CS_CONFIG3,  8, 12, "adv-rd-off-ns");
 +      GPMC_GET_TICKS(GPMC_CS_CONFIG3, 16, 20, "adv-wr-off-ns");
 +
 +      GPMC_GET_TICKS(GPMC_CS_CONFIG4,  0,  3, "oe-on-ns");
 +      GPMC_GET_TICKS(GPMC_CS_CONFIG4,  8, 12, "oe-off-ns");
 +      GPMC_GET_TICKS(GPMC_CS_CONFIG4, 16, 19, "we-on-ns");
 +      GPMC_GET_TICKS(GPMC_CS_CONFIG4, 24, 28, "we-off-ns");
 +
 +      GPMC_GET_TICKS(GPMC_CS_CONFIG5,  0,  4, "rd-cycle-ns");
 +      GPMC_GET_TICKS(GPMC_CS_CONFIG5,  8, 12, "wr-cycle-ns");
 +      GPMC_GET_TICKS(GPMC_CS_CONFIG5, 16, 20, "access-ns");
 +
 +      GPMC_GET_TICKS(GPMC_CS_CONFIG5, 24, 27, "page-burst-access-ns");
 +
 +      GPMC_GET_TICKS(GPMC_CS_CONFIG6, 0, 3, "bus-turnaround-ns");
 +      GPMC_GET_TICKS(GPMC_CS_CONFIG6, 8, 11, "cycle2cycle-delay-ns");
 +
 +      GPMC_GET_TICKS(GPMC_CS_CONFIG1, 18, 19, "wait-monitoring-ns");
 +      GPMC_GET_TICKS(GPMC_CS_CONFIG1, 25, 26, "clk-activation-ns");
 +
 +      GPMC_GET_TICKS(GPMC_CS_CONFIG6, 16, 19, "wr-data-mux-bus-ns");
 +      GPMC_GET_TICKS(GPMC_CS_CONFIG6, 24, 28, "wr-access-ns");
 +}
 +#else
 +static inline void gpmc_cs_show_timings(int cs, const char *desc)
 +{
 +}
 +#endif
 +
  static int set_gpmc_timing_reg(int cs, int reg, int st_bit, int end_bit,
                               int time, const char *name)
- #else
- static int set_gpmc_timing_reg(int cs, int reg, int st_bit, int end_bit,
-                              int time)
- #endif
  {
        u32 l;
        int ticks, mask, nr_bits;
@@@ -1665,8 -1511,8 +1665,9 @@@ static int gpmc_probe_generic_child(str
        struct gpmc_timings gpmc_t;
        struct resource res;
        unsigned long base;
 +      const char *name;
        int ret, cs;
+       u32 val;
  
        if (of_property_read_u32(child, "reg", &cs) < 0) {
                dev_err(&pdev->dev, "%s has no 'reg' property\n",
        if (ret < 0)
                goto err;
  
-       gpmc_cs_set_timings(cs, &gpmc_t);
 -      gpmc_read_timings_dt(child, &gpmc_t);
+       ret = gpmc_cs_set_timings(cs, &gpmc_t);
+       if (ret) {
+               dev_err(&pdev->dev, "failed to set gpmc timings for: %s\n",
+                       child->name);
+               goto err;
+       }
+       /* Clear limited address i.e. enable A26-A11 */
+       val = gpmc_read_reg(GPMC_CONFIG);
+       val &= ~GPMC_CONFIG_LIMITEDADDRESS;
+       gpmc_write_reg(GPMC_CONFIG, val);
+       /* Enable CS region */
+       gpmc_cs_enable_mem(cs);
  
  no_timings:
        if (of_platform_device_create(child, NULL, &pdev->dev))