Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/arm/samsung EXYNOS Rewrite step 2 of N: New exynos_...



details:   https://anonhg.NetBSD.org/src/rev/4aec019fc7b6
branches:  trunk
changeset: 342176:4aec019fc7b6
user:      marty <marty%NetBSD.org@localhost>
date:      Fri Dec 11 04:03:44 2015 +0000

description:
EXYNOS Rewrite step 2 of N: New exynos_gpio.c

I can't bring  myself to fully nuke from orbit, so there are really two
things in this checkin:

1) A major rewrite of exynos_gpio.c, based mostly on the Nvidia
   tegra_gpio.c file.  This is missing a major function that will be
   added the first time a customer for it is integrated, which is meant to
   select pins based on aliases, rather than pin bank names.

2) A small number of changes to other files that keep the tree compiling
   and progressing as far as ever; except it is now 5422 specific and
   will not boot on the other exynos socs, which I don't have hardware to
   test.

The choice to remove functionality is always controversial, but since
we are doing a significant rewrite and I don't have either
documentation or hardware *and* none of the code really works now
anyway, I'm taking the stance that only tested functionality should be
added, and that we'll layer the other exynos socs on this once it
fully boots.

diffstat:

 sys/arch/arm/samsung/exynos5_reg.h |   15 +-
 sys/arch/arm/samsung/exynos_gpio.c |  930 +++++++++---------------------------
 sys/arch/arm/samsung/exynos_i2c.c  |   11 +-
 sys/arch/arm/samsung/exynos_soc.c  |   88 +---
 sys/arch/arm/samsung/exynos_var.h  |    4 +-
 sys/arch/arm/samsung/mct.c         |   26 +-
 6 files changed, 265 insertions(+), 809 deletions(-)

diffs (truncated from 1450 to 300 lines):

diff -r 3afe651fe3df -r 4aec019fc7b6 sys/arch/arm/samsung/exynos5_reg.h
--- a/sys/arch/arm/samsung/exynos5_reg.h        Fri Dec 11 03:55:18 2015 +0000
+++ b/sys/arch/arm/samsung/exynos5_reg.h        Fri Dec 11 04:03:44 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: exynos5_reg.h,v 1.20 2014/12/29 22:58:59 skrll Exp $   */
+/*     $NetBSD: exynos5_reg.h,v 1.21 2015/12/11 04:03:44 marty Exp $   */
 
 /*-
  * Copyright (c) 2014 The NetBSD Foundation, Inc.
@@ -51,6 +51,13 @@
  * 0x40000000  0xFFFFFFFF              DRAM
 */
 
+/* MJF: The GPIO offset names made no sense and the values wer wrong. */
+#define EXYNOS5_GPIO_MUXA_OFFSET               0x03400000
+#define EXYNOS5_GPIO_MUXB_OFFSET               0x03410000
+#define EXYNOS5_GPIO_MUXC_OFFSET               0x04000000
+#define EXYNOS5_GPIO_MUXD_OFFSET               0x04010000
+#define EXYNOS5_GPIO_MUXE_OFFSET               0x03860000
+
 /* CORE */
 #define EXYNOS5_CORE_SIZE                      0x0f000000
 #define EXYNOS5_SDRAM_PBASE                    0x40000000
@@ -103,7 +110,7 @@
 #define EXYNOS5_AS_A_LEFT_BUS_OFFSET           0x00CE0000
 #define EXYNOS5_AS_A_RIGHT0_BUS_OFFSET         0x00CF0000
 #define EXYNOS5_AS_A_DISP1_BUS_OFFSET          0x00D00000
-#define EXYNOS5_GPIO_C2C_OFFSET                        0x00D10000
+/*#define EXYNOS5_GPIO_C2C_OFFSET                      0x00D10000*/
 #define EXYNOS5_DREXII_OFFSET                  0x00DD0000
 #define EXYNOS5_AS_A_EFCON_OFFSET              0x00DE0000
 #define EXYNOS5_AP_C2C_OFFSET                  0x00E00000
@@ -117,7 +124,7 @@
 #define EXYNOS5_MFC_OFFSET                     0x01000000
 #define EXYNOS5_SYSMMU_MFC0_R                  0x01200000
 #define EXYNOS5_SYSMMU_MFC1_L                  0x01210000
-#define EXYNOS5_GPIO_LEFT_OFFSET               0x01400000
+/*#define EXYNOS5_GPIO_LEFT_OFFSET             0x04010000*/
 #define EXYNOS5_AS_A_MFC_OFFSET                        0x01680000
 #define EXYNOS5_AS_A_GENX_OFFSET               0x016A0000
 #define EXYNOS5_3D ENGINE_OFFSET               0x01800000
@@ -236,7 +243,7 @@
 #define EXYNOS5_SYSMMU_FIMC_DIS0               0x032D0000
 #define EXYNOS5_SYSMMU_FIMC_DIS1               0x032E0000
 #define EXYNOS5_SYSMMU_FIMC_3DNR_OFFSET                0x032F0000
-#define EXYNOS5_GPIO_RIGHT_OFFSET              0x03400000
+/*#define EXYNOS5_GPIO_RIGHT_OFFSET            0x04000000*/
 #define EXYNOS5_AS_A_MFC0_OFFSET               0x03620000
 #define EXYNOS5_AS_A_ISP0_OFFSET               0x03640000
 #define EXYNOS5_AS_A_ISP1_OFFSET               0x03650000
diff -r 3afe651fe3df -r 4aec019fc7b6 sys/arch/arm/samsung/exynos_gpio.c
--- a/sys/arch/arm/samsung/exynos_gpio.c        Fri Dec 11 03:55:18 2015 +0000
+++ b/sys/arch/arm/samsung/exynos_gpio.c        Fri Dec 11 04:03:44 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: exynos_gpio.c,v 1.12 2014/12/29 22:34:08 skrll Exp $   */
+/*     $NetBSD: exynos_gpio.c,v 1.13 2015/12/11 04:03:44 marty Exp $ */
 
 /*-
 * Copyright (c) 2014 The NetBSD Foundation, Inc.
@@ -34,7 +34,7 @@
 #include "gpio.h"
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(1, "$NetBSD: exynos_gpio.c,v 1.12 2014/12/29 22:34:08 skrll Exp $");
+__KERNEL_RCSID(1, "$NetBSD: exynos_gpio.c,v 1.13 2015/12/11 04:03:44 marty Exp $");
 
 #include <sys/param.h>
 #include <sys/bus.h>
@@ -42,21 +42,14 @@
 #include <sys/intr.h>
 #include <sys/systm.h>
 #include <sys/kmem.h>
+#include <sys/gpio.h>
+
+#include <dev/gpio/gpiovar.h>
 
 #include <arm/samsung/exynos_reg.h>
 #include <arm/samsung/exynos_io.h>
 #include <arm/samsung/exynos_intr.h>
 
-#include <sys/gpio.h>
-#include <dev/gpio/gpiovar.h>
-
-static int exynos_gpio_match(device_t, cfdata_t, void *);
-static void exynos_gpio_attach(device_t, device_t, void *);
-
-static int exynos_gpio_pin_read(void *, int);
-static void exynos_gpio_pin_write(void *, int, int);
-static void exynos_gpio_pin_ctl(void *, int, int);
-
 struct exynos_gpio_pin_cfg {
        uint32_t cfg;
        uint32_t pud;
@@ -65,277 +58,108 @@
        uint32_t pudpwd;
 };
 
-struct exynos_gpio_pin_group {
-       const char              grp_name[6];
-       const bus_addr_t        grp_core_offset;
-       const uint8_t           grp_bits;
-
-       uint8_t                 grp_pin_mask;
-       uint8_t                 grp_pin_inuse_mask;
-       bus_space_handle_t      grp_bsh;
-       struct exynos_gpio_pin_cfg grp_cfg;
-       struct gpio_chipset_tag grp_gc_tag;
-};
-
-
-#define GPIO_REG(v,s,o) (EXYNOS##v##_GPIO_##s##_OFFSET + (o))
-#define GPIO_GRP(v, s, o, n, b) \
-       { \
-               .grp_name = #n, \
-               .grp_core_offset = GPIO_REG(v,s,o), \
-               .grp_bits = b,\
-       }
+struct exynos_gpio_softc;
 
-#ifdef EXYNOS4
-/*
- * Exynos 4412 contains 304 multi-functional input/output port pins and 164
- * memory port pins. There are 37 general port groups and two memory port
- * groups. They are:
- *
- *  GPA0, GPA1: 14 in/out ports-3xUART with flow control, UART without flow
- *  control, and/or 2xI2C
- *
- *  GPB: 8 in/out ports-2xSPI and/or 2xI2C and/ or IEM
- *
- *  GPC0, GPC1: 10 in/out ports-2xI2S, and/or 2xPCM, and/or AC97, SPDIF, I2C,
- *  and/or SPI
- *
- *  GPD0, GPD1: 8 in/out ports-PWM, 2xI2C, and/ or LCD I/F, MIPI
- *
- *  GPM0, GPM1, GPM2, GPM3, GPM4: 35 in/out ports-CAM I/F, and/ or TS I/F,
- *  HSI, and/ or Trace I/F
- *
- *  GPF0, GPF1, GPF2, GPF3: 30 in/out ports-LCD I/F
- *
- *  GPJ0, GPJ1: 13 in/out ports-CAM I/F
- *
- *  GPK0, GPK1, GPK2, GPK3: 28 in/out ports-4xMMC (4-bit MMC), and/or 2xMMC
- *  (8-bit MMC)), and/or GPS debugging I/F
- *
- *  GPL0, GPL1: 11 in/out ports-GPS I/F
- *
- *  GPL2: 8 in/out ports-GPS debugging I/F or Key pad I/F
- *
- *  GPX0, GPX1, GPX2, GPX3: 32 in/out ports-External wake-up, and/or Key pad
- *  I/F
- *
- *  GPZ: 7 in/out ports-low Power I2S and/or PCM
- *
- *  GPY0, GPY1, GPY2: 16 in/out ports-Control signals of EBI (SROM, NF, One
- *  NAND)
- *
- *  GPY3, GPY4, GPY5, GPY6: 32 in/out memory ports-EBI (For more information
- *  about EBI configuration, refer to Chapter 5, and 6)
- *
- *  MP1_0-MP1_9: 78 DRAM1 ports. NOTE: GPIO registers does not control these
- *  ports.
- *
- *  MP2_0-MP2_9: 78 DRAM2 ports. NOTE: GPIO registers does not control these
- *  ports.
- *
- *  ETC0, ETC1, ETC6: 18 in/out ETC ports-JTAG, SLIMBUS, RESET, CLOCK
- *
- *  ETC7, ETC8 : 4 clock port for C2C
- *
- */
-
-static struct exynos_gpio_pin_group exynos4_pin_groups[] = {
-       GPIO_GRP(4, LEFT,  0x0000, GPA0, 8),
-       GPIO_GRP(4, LEFT,  0x0020, GPA1, 6),
-       GPIO_GRP(4, LEFT,  0x0040, GPB,  8),
-       GPIO_GRP(4, LEFT,  0x0060, GPC0, 5),
-       GPIO_GRP(4, LEFT,  0x0080, GPC1, 5),
-       GPIO_GRP(4, LEFT,  0x00A0, GPD0, 4),
-       GPIO_GRP(4, LEFT,  0x00C0, GPD1, 4),
-       GPIO_GRP(4, LEFT,  0x0180, GPF0, 8),
-       GPIO_GRP(4, LEFT,  0x01A0, GPF1, 8),
-       GPIO_GRP(4, LEFT,  0x01C0, GPF2, 8),
-       GPIO_GRP(4, LEFT,  0x01E0, GPF3, 8),
-       GPIO_GRP(4, LEFT,  0x0240, GPJ0, 8),
-       GPIO_GRP(4, LEFT,  0x0260, GPJ1, 5),
-       /* EXTINT skipped */
-
-       GPIO_GRP(4, RIGHT, 0x0040, GPK0, 8),
-       GPIO_GRP(4, RIGHT, 0x0060, GPK1, 8),
-       GPIO_GRP(4, RIGHT, 0x0080, GPK2, 7),
-       GPIO_GRP(4, RIGHT, 0x00A0, GPK3, 7),
-       GPIO_GRP(4, RIGHT, 0x00C0, GPL0, 7),
-       GPIO_GRP(4, RIGHT, 0x00E0, GPL1, 2),
-       GPIO_GRP(4, RIGHT, 0x0100, GPL2, 8),
-       GPIO_GRP(4, RIGHT, 0x0120, GPY0, 6),
-       GPIO_GRP(4, RIGHT, 0x0140, GPY1, 4),
-       GPIO_GRP(4, RIGHT, 0x0160, GPY2, 6),
-       GPIO_GRP(4, RIGHT, 0x0180, GPY3, 8),
-       GPIO_GRP(4, RIGHT, 0x01A0, GPY4, 8),
-       GPIO_GRP(4, RIGHT, 0x01C0, GPY5, 8),
-       GPIO_GRP(4, RIGHT, 0x01E0, GPY6, 8),
-       GPIO_GRP(4, RIGHT, 0x0200, ETC0, 6),
-       GPIO_GRP(4, RIGHT, 0x0220, ETC6, 8),
-       GPIO_GRP(4, RIGHT, 0x0260, GPM0, 8),
-       GPIO_GRP(4, RIGHT, 0x0280, GPM1, 7),
-       GPIO_GRP(4, RIGHT, 0x02A0, GPM2, 5),
-       GPIO_GRP(4, RIGHT, 0x02C0, GPM3, 8),
-       GPIO_GRP(4, RIGHT, 0x02E0, GPM4, 8),
-       /* EXTINT skipped */
-       GPIO_GRP(4, RIGHT, 0x0C00, GPX0, 8),
-       GPIO_GRP(4, RIGHT, 0x0C20, GPX1, 8),
-       GPIO_GRP(4, RIGHT, 0x0C40, GPX2, 8),
-       GPIO_GRP(4, RIGHT, 0x0C60, GPX3, 8),
-       /* EXTINT skipped */
-
-       GPIO_GRP(4, I2S0,  0x0000, GPZ,  8),
-       /* EXTINT skipped */
+struct exynos_gpio_bank {
+       const char              bank_name[6];
+       struct exynos_gpio_softc *bank_sc;
+       device_t                bank_dev;
+       struct gpio_chipset_tag bank_gc;
+       gpio_pin_t              bank_pins[8];
 
-       GPIO_GRP(4, C2C,   0x0000, GPV0, 8),
-       GPIO_GRP(4, C2C,   0x0020, GPV1, 8),
-       GPIO_GRP(4, C2C,   0x0040, ETC7, 2),
-       GPIO_GRP(4, C2C,   0x0060, GPV2, 8),
-       GPIO_GRP(4, C2C,   0x0080, GPV3, 8),
-       GPIO_GRP(4, C2C,   0x00A0, ETC8, 2),
-       GPIO_GRP(4, C2C,   0x00C0, GPV4, 2),
-       /* EXTINT skipped */
-};
-#endif
-
-
-#ifdef EXYNOS5
-
-/*
- * Exynos 5250 contains 253 multi-functional input/output port pins and 160
- * memory port pins. There are 39 general port groups and 2 memory port
- * groups. They are:
- *
- * GPA0, GPA1: 14 in/out ports-2xUART with flow control, UART without flow
- * control, and/or 2xI2C , and/or2xHS-I2C
- *
- * GPA2: 8 in/out ports-2xSPI, and/or I2C
- *
- * GPB0, GPB1: 10 in/out ports-2xI2S, and/or 2xPCM, and/or AC97, SPDIF, I2C,
- * and/or SPI
- *
- * GPB2, GPB3: 8 in/out ports-PWM, I2C, and/or I2C ,and/or HS-I2C
- *
- * GPC0, GPC1: 11 in/out ports-1xMMC (8-bit MMC) I/F
- *
- * GPC2: 7 in/out ports-1xMMC (4-bit MMC) I/F
- *
- * GPC3, GPC4: 14 in/out ports-2xMMC (4-bit MMC) and/or 1xMMC (8-bit MMC) I/F
- *
- * GPD0: 4 pin/out ports-1xUART with flow control I/F
- *
- * GPD1: 8 pin/out ports-HSI I/F
- *
- * GPE0, GPE1, GPF0, GPF1, GPG0, GPG1, GPG2, GPH0, GPH1: 48 in/out ports-CAM
- * I/F, and/or Trace I/F
- *
- * GPV0, GPV1, GPV2, GPV3, GPV4: 34 in/out ports-C2C I/F
- *
- * GPX0, 1, 2, 3: 32 in/out port-external wake-up interrupts (up-to 32-bit),
- * and/or AUD I/F, and/or MFC I/F (GPX groups are in alive region)
- *
- * GPY0, GPY1, GPY2: 16 in/out ports-control signals of EBI (SROM)
- *
- * GPY3, GPY4, GPY5, GPY6: 32 in/out memory ports-EBI
- *
- * GPZ: 7 in/out ports-low power I2S and/or PCM
- *
- * MP1_0-MP1_10: 80 DRAM1 ports NOTE: GPIO registers do not control these
- * ports.
- *
- * MP2_0-MP2_10: 80 DRAM2 ports NOTE: GPIO registers do not control these
- * ports.
- *
- * ETC0, ETC5, ETC6, ETC7, ETC8: 22 in/out ETC ports-JTAG, C2C_CLK (Rx),
- * RESET, CLOCK, USBOTG and USB3, C2C_CLK (Tx)
- */
+       const bus_addr_t        bank_core_offset;
+       const uint8_t           bank_bits;
 
-static struct exynos_gpio_pin_group exynos5_pin_groups[] = {
-       GPIO_GRP(5, LEFT,  0x0000, GPA0, 8),
-       GPIO_GRP(5, LEFT,  0x0020, GPA1, 6),
-       GPIO_GRP(5, LEFT,  0x0040, GPA2, 8),
-       GPIO_GRP(5, LEFT,  0x0060, GPB0, 5),
-       GPIO_GRP(5, LEFT,  0x0080, GPB1, 5),
-       GPIO_GRP(5, LEFT,  0x00A0, GPB2, 4),
-       GPIO_GRP(5, LEFT,  0x00C0, GPB3, 4),
-       GPIO_GRP(5, LEFT,  0x00E0, GPC0, 7),
-       GPIO_GRP(5, LEFT,  0x0100, GPC1, 4),



Home | Main Index | Thread Index | Old Index