diff mbox series

[edk2,edk2-platforms,v2,01/23] Silicon/SynQuacer: add package with platform headers

Message ID 20171025175947.22798-2-ard.biesheuvel@linaro.org
State Superseded
Headers show
Series add support for Socionext Synquacer | expand

Commit Message

Ard Biesheuvel Oct. 25, 2017, 5:59 p.m. UTC
Add a package .DEC description for SynQuacer with an [Includes]
section, and add header files containing descriptions of the
platform's memory map and PCIe configuration. No code yet.

Contributed-under: TianoCore Contribution Agreement 1.1
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>

---
 Silicon/Socionext/SynQuacer/Include/Platform/MemoryMap.h | 69 ++++++++++++++++++++
 Silicon/Socionext/SynQuacer/Include/Platform/Pcie.h      | 63 ++++++++++++++++++
 Silicon/Socionext/SynQuacer/SynQuacer.dec                | 20 ++++++
 3 files changed, 152 insertions(+)

-- 
2.11.0

_______________________________________________
edk2-devel mailing list
edk2-devel@lists.01.org
https://lists.01.org/mailman/listinfo/edk2-devel

Comments

Leif Lindholm Oct. 26, 2017, 2:39 p.m. UTC | #1
On Wed, Oct 25, 2017 at 06:59:25PM +0100, Ard Biesheuvel wrote:
> Add a package .DEC description for SynQuacer with an [Includes]

> section, and add header files containing descriptions of the

> platform's memory map and PCIe configuration. No code yet.

> 

> Contributed-under: TianoCore Contribution Agreement 1.1

> Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>


Reviewed-by: Leif Lindholm <leif.lindholm@linaro.org>

Special thanks for the tedious name case-change.

> ---

>  Silicon/Socionext/SynQuacer/Include/Platform/MemoryMap.h | 69 ++++++++++++++++++++

>  Silicon/Socionext/SynQuacer/Include/Platform/Pcie.h      | 63 ++++++++++++++++++

>  Silicon/Socionext/SynQuacer/SynQuacer.dec                | 20 ++++++

>  3 files changed, 152 insertions(+)

> 

> diff --git a/Silicon/Socionext/SynQuacer/Include/Platform/MemoryMap.h b/Silicon/Socionext/SynQuacer/Include/Platform/MemoryMap.h

> new file mode 100644

> index 000000000000..a53b9088c3af

> --- /dev/null

> +++ b/Silicon/Socionext/SynQuacer/Include/Platform/MemoryMap.h

> @@ -0,0 +1,69 @@

> +/** @file

> +  Physical memory map for SynQuacer

> +

> +  Copyright (c) 2017, Linaro Ltd. All rights reserved.<BR>

> +

> +  This program and the accompanying materials are licensed and made available

> +  under the terms and conditions of the BSD License which accompanies this

> +  distribution.  The full text of the license may be found at

> +  http://opensource.org/licenses/bsd-license.php.

> +

> +  THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, WITHOUT

> +  WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.

> +

> +**/

> +

> +#ifndef _SYNQUACER_PLATFORM_MEMORYMAP_H_

> +#define _SYNQUACER_PLATFORM_MEMORYMAP_H_

> +

> +// Memory mapped SPI NOR

> +#define SYNQUACER_SPI_NOR_BASE          0x08000000

> +#define SYNQUACER_SPI_NOR_SIZE          SIZE_128MB

> +

> +// On-Chip non-secure ROM

> +#define SYNQUACER_NON_SECURE_ROM_BASE   0x1F000000

> +#define SYNQUACER_NON_SECURE_ROM_SZ     SIZE_512KB

> +

> +// On-Chip Peripherals

> +#define SYNQUACER_PERIPHERALS_BASE      0x20000000

> +#define SYNQUACER_PERIPHERALS_SZ        0x0E000000

> +

> +// On-Chip non-secure SRAM

> +#define SYNQUACER_NON_SECURE_SRAM_BASE  0x2E000000

> +#define SYNQUACER_NON_SECURE_SRAM_SZ    SIZE_64KB

> +

> +// GIC-500

> +#define SYNQUACER_GIC500_DIST_BASE      FixedPcdGet64 (PcdGicDistributorBase)

> +#define SYNQUACER_GIC500_DIST_SIZE      SIZE_256KB

> +#define SYNQUACER_GIC500_RDIST_BASE     FixedPcdGet64 (PcdGicRedistributorsBase)

> +#define SYNQUACER_GIC500_RDIST_SIZE     SIZE_8MB

> +

> +// GPIO block

> +#define SYNQUACER_GPIO_BASE             0x51000000

> +#define SYNQUACER_GPIO_SIZE             SIZE_4KB

> +

> +// eMMC(SDH30)

> +#define SYNQUACER_EMMC_BASE             0x52300000

> +#define SYNQUACER_EMMC_BASE_SZ          SIZE_4KB

> +

> +#define SYNQUACER_EEPROM_BASE           0x10000000

> +#define SYNQUACER_EEPROM_BASE_SZ        SIZE_64KB

> +

> +// NETSEC

> +#define SYNQUACER_NETSEC_BASE           0x522D0000

> +#define SYNQUACER_NETSEC_BASE_SZ        SIZE_64KB

> +

> +#define SYNQUACER_SYSTEM_MEMORY_1_BASE  0x80000000

> +#define SYNQUACER_SYSTEM_MEMORY_1_SZ    (SIZE_2GB - SIZE_16MB)

> +

> +#define SYNQUACER_SYSTEM_MEMORY_2_BASE  0x0880000000ULL

> +#define SYNQUACER_SYSTEM_MEMORY_2_SZ    (SIZE_32GB - SIZE_2GB)

> +

> +#define SYNQUACER_SYSTEM_MEMORY_3_BASE  0x8800000000ULL

> +#define SYNQUACER_SYSTEM_MEMORY_3_SZ    SIZE_32GB

> +

> +// PCI

> +#define SYNQUACER_PCIE_BASE             0x58200000

> +#define SYNQUACER_PCIE_SIZE             0x00200000

> +

> +#endif

> diff --git a/Silicon/Socionext/SynQuacer/Include/Platform/Pcie.h b/Silicon/Socionext/SynQuacer/Include/Platform/Pcie.h

> new file mode 100644

> index 000000000000..d2a3f9acbf49

> --- /dev/null

> +++ b/Silicon/Socionext/SynQuacer/Include/Platform/Pcie.h

> @@ -0,0 +1,63 @@

> +/** @file

> +  PCI memory configuration for SynQuacer

> +

> +  Copyright (c) 2017, Linaro Ltd. All rights reserved.<BR>

> +

> +  This program and the accompanying materials are licensed and made available

> +  under the terms and conditions of the BSD License which accompanies this

> +  distribution.  The full text of the license may be found at

> +  http://opensource.org/licenses/bsd-license.php.

> +

> +  THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, WITHOUT

> +  WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.

> +

> +**/

> +

> +#ifndef _SYNQUACER_PLATFORM_PCI_H_

> +#define _SYNQUACER_PLATFORM_PCI_H_

> +

> +#define SYNQUACER_PCI_SEG0_CONFIG_BASE      0x60000000

> +#define SYNQUACER_PCI_SEG0_CONFIG_SIZE      0x07f00000

> +#define SYNQUACER_PCI_SEG0_DBI_BASE         0x583d0000

> +#define SYNQUACER_PCI_SEG0_EXS_BASE         0x58390000

> +

> +#define SYNQUACER_PCI_SEG0_BUSNUM_MIN       0x0

> +#define SYNQUACER_PCI_SEG0_BUSNUM_MAX       0x7e

> +

> +#define SYNQUACER_PCI_SEG0_PORTIO_MIN       0x0

> +#define SYNQUACER_PCI_SEG0_PORTIO_MAX       0xffff

> +#define SYNQUACER_PCI_SEG0_PORTIO_SIZE      0x10000

> +#define SYNQUACER_PCI_SEG0_PORTIO_MEMBASE   0x67f00000

> +#define SYNQUACER_PCI_SEG0_PORTIO_MEMSIZE   SYNQUACER_PCI_SEG0_PORTIO_SIZE

> +

> +#define SYNQUACER_PCI_SEG0_MMIO32_MIN       0x68000000

> +#define SYNQUACER_PCI_SEG0_MMIO32_MAX       0x6fffffff

> +#define SYNQUACER_PCI_SEG0_MMIO32_SIZE      0x08000000

> +

> +#define SYNQUACER_PCI_SEG0_MMIO64_MIN       0x3e00000000

> +#define SYNQUACER_PCI_SEG0_MMIO64_MAX       0x3effffffff

> +#define SYNQUACER_PCI_SEG0_MMIO64_SIZE      0x100000000

> +

> +#define SYNQUACER_PCI_SEG1_CONFIG_BASE      0x70000000

> +#define SYNQUACER_PCI_SEG1_CONFIG_SIZE      0x07f00000

> +#define SYNQUACER_PCI_SEG1_DBI_BASE         0x583c0000

> +#define SYNQUACER_PCI_SEG1_EXS_BASE         0x58380000

> +

> +#define SYNQUACER_PCI_SEG1_BUSNUM_MIN       0x0

> +#define SYNQUACER_PCI_SEG1_BUSNUM_MAX       0x7e

> +

> +#define SYNQUACER_PCI_SEG1_PORTIO_MIN       0x10000

> +#define SYNQUACER_PCI_SEG1_PORTIO_MAX       0x1ffff

> +#define SYNQUACER_PCI_SEG1_PORTIO_SIZE      0x10000

> +#define SYNQUACER_PCI_SEG1_PORTIO_MEMBASE   0x77f00000

> +#define SYNQUACER_PCI_SEG1_PORTIO_MEMSIZE   SYNQUACER_PCI_SEG1_PORTIO_SIZE

> +

> +#define SYNQUACER_PCI_SEG1_MMIO32_MIN       0x78000000

> +#define SYNQUACER_PCI_SEG1_MMIO32_MAX       0x7fffffff

> +#define SYNQUACER_PCI_SEG1_MMIO32_SIZE      0x08000000

> +

> +#define SYNQUACER_PCI_SEG1_MMIO64_MIN       0x3f00000000

> +#define SYNQUACER_PCI_SEG1_MMIO64_MAX       0x3fffffffff

> +#define SYNQUACER_PCI_SEG1_MMIO64_SIZE      0x100000000

> +

> +#endif

> diff --git a/Silicon/Socionext/SynQuacer/SynQuacer.dec b/Silicon/Socionext/SynQuacer/SynQuacer.dec

> new file mode 100644

> index 000000000000..c3adf85d3562

> --- /dev/null

> +++ b/Silicon/Socionext/SynQuacer/SynQuacer.dec

> @@ -0,0 +1,20 @@

> +#

> +#  Copyright (c) 2017, Linaro, Ltd. All rights reserved.

> +#

> +#  This program and the accompanying materials

> +#  are licensed and made available under the terms and conditions of the BSD License

> +#  which accompanies this distribution.  The full text of the license may be found at

> +#  http://opensource.org/licenses/bsd-license.php

> +#

> +#  THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,

> +#  WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.

> +#

> +

> +[Defines]

> +  DEC_SPECIFICATION              = 0x0001001A

> +  PACKAGE_NAME                   = SynQuacer

> +  PACKAGE_GUID                   = 9c782fd2-7db1-438d-b51c-2155cee2c5cc

> +  PACKAGE_VERSION                = 0.1

> +

> +[Includes]

> +  Include

> -- 

> 2.11.0

> 

_______________________________________________
edk2-devel mailing list
edk2-devel@lists.01.org
https://lists.01.org/mailman/listinfo/edk2-devel
diff mbox series

Patch

diff --git a/Silicon/Socionext/SynQuacer/Include/Platform/MemoryMap.h b/Silicon/Socionext/SynQuacer/Include/Platform/MemoryMap.h
new file mode 100644
index 000000000000..a53b9088c3af
--- /dev/null
+++ b/Silicon/Socionext/SynQuacer/Include/Platform/MemoryMap.h
@@ -0,0 +1,69 @@ 
+/** @file
+  Physical memory map for SynQuacer
+
+  Copyright (c) 2017, Linaro Ltd. All rights reserved.<BR>
+
+  This program and the accompanying materials are licensed and made available
+  under the terms and conditions of the BSD License which accompanies this
+  distribution.  The full text of the license may be found at
+  http://opensource.org/licenses/bsd-license.php.
+
+  THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, WITHOUT
+  WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
+
+**/
+
+#ifndef _SYNQUACER_PLATFORM_MEMORYMAP_H_
+#define _SYNQUACER_PLATFORM_MEMORYMAP_H_
+
+// Memory mapped SPI NOR
+#define SYNQUACER_SPI_NOR_BASE          0x08000000
+#define SYNQUACER_SPI_NOR_SIZE          SIZE_128MB
+
+// On-Chip non-secure ROM
+#define SYNQUACER_NON_SECURE_ROM_BASE   0x1F000000
+#define SYNQUACER_NON_SECURE_ROM_SZ     SIZE_512KB
+
+// On-Chip Peripherals
+#define SYNQUACER_PERIPHERALS_BASE      0x20000000
+#define SYNQUACER_PERIPHERALS_SZ        0x0E000000
+
+// On-Chip non-secure SRAM
+#define SYNQUACER_NON_SECURE_SRAM_BASE  0x2E000000
+#define SYNQUACER_NON_SECURE_SRAM_SZ    SIZE_64KB
+
+// GIC-500
+#define SYNQUACER_GIC500_DIST_BASE      FixedPcdGet64 (PcdGicDistributorBase)
+#define SYNQUACER_GIC500_DIST_SIZE      SIZE_256KB
+#define SYNQUACER_GIC500_RDIST_BASE     FixedPcdGet64 (PcdGicRedistributorsBase)
+#define SYNQUACER_GIC500_RDIST_SIZE     SIZE_8MB
+
+// GPIO block
+#define SYNQUACER_GPIO_BASE             0x51000000
+#define SYNQUACER_GPIO_SIZE             SIZE_4KB
+
+// eMMC(SDH30)
+#define SYNQUACER_EMMC_BASE             0x52300000
+#define SYNQUACER_EMMC_BASE_SZ          SIZE_4KB
+
+#define SYNQUACER_EEPROM_BASE           0x10000000
+#define SYNQUACER_EEPROM_BASE_SZ        SIZE_64KB
+
+// NETSEC
+#define SYNQUACER_NETSEC_BASE           0x522D0000
+#define SYNQUACER_NETSEC_BASE_SZ        SIZE_64KB
+
+#define SYNQUACER_SYSTEM_MEMORY_1_BASE  0x80000000
+#define SYNQUACER_SYSTEM_MEMORY_1_SZ    (SIZE_2GB - SIZE_16MB)
+
+#define SYNQUACER_SYSTEM_MEMORY_2_BASE  0x0880000000ULL
+#define SYNQUACER_SYSTEM_MEMORY_2_SZ    (SIZE_32GB - SIZE_2GB)
+
+#define SYNQUACER_SYSTEM_MEMORY_3_BASE  0x8800000000ULL
+#define SYNQUACER_SYSTEM_MEMORY_3_SZ    SIZE_32GB
+
+// PCI
+#define SYNQUACER_PCIE_BASE             0x58200000
+#define SYNQUACER_PCIE_SIZE             0x00200000
+
+#endif
diff --git a/Silicon/Socionext/SynQuacer/Include/Platform/Pcie.h b/Silicon/Socionext/SynQuacer/Include/Platform/Pcie.h
new file mode 100644
index 000000000000..d2a3f9acbf49
--- /dev/null
+++ b/Silicon/Socionext/SynQuacer/Include/Platform/Pcie.h
@@ -0,0 +1,63 @@ 
+/** @file
+  PCI memory configuration for SynQuacer
+
+  Copyright (c) 2017, Linaro Ltd. All rights reserved.<BR>
+
+  This program and the accompanying materials are licensed and made available
+  under the terms and conditions of the BSD License which accompanies this
+  distribution.  The full text of the license may be found at
+  http://opensource.org/licenses/bsd-license.php.
+
+  THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, WITHOUT
+  WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
+
+**/
+
+#ifndef _SYNQUACER_PLATFORM_PCI_H_
+#define _SYNQUACER_PLATFORM_PCI_H_
+
+#define SYNQUACER_PCI_SEG0_CONFIG_BASE      0x60000000
+#define SYNQUACER_PCI_SEG0_CONFIG_SIZE      0x07f00000
+#define SYNQUACER_PCI_SEG0_DBI_BASE         0x583d0000
+#define SYNQUACER_PCI_SEG0_EXS_BASE         0x58390000
+
+#define SYNQUACER_PCI_SEG0_BUSNUM_MIN       0x0
+#define SYNQUACER_PCI_SEG0_BUSNUM_MAX       0x7e
+
+#define SYNQUACER_PCI_SEG0_PORTIO_MIN       0x0
+#define SYNQUACER_PCI_SEG0_PORTIO_MAX       0xffff
+#define SYNQUACER_PCI_SEG0_PORTIO_SIZE      0x10000
+#define SYNQUACER_PCI_SEG0_PORTIO_MEMBASE   0x67f00000
+#define SYNQUACER_PCI_SEG0_PORTIO_MEMSIZE   SYNQUACER_PCI_SEG0_PORTIO_SIZE
+
+#define SYNQUACER_PCI_SEG0_MMIO32_MIN       0x68000000
+#define SYNQUACER_PCI_SEG0_MMIO32_MAX       0x6fffffff
+#define SYNQUACER_PCI_SEG0_MMIO32_SIZE      0x08000000
+
+#define SYNQUACER_PCI_SEG0_MMIO64_MIN       0x3e00000000
+#define SYNQUACER_PCI_SEG0_MMIO64_MAX       0x3effffffff
+#define SYNQUACER_PCI_SEG0_MMIO64_SIZE      0x100000000
+
+#define SYNQUACER_PCI_SEG1_CONFIG_BASE      0x70000000
+#define SYNQUACER_PCI_SEG1_CONFIG_SIZE      0x07f00000
+#define SYNQUACER_PCI_SEG1_DBI_BASE         0x583c0000
+#define SYNQUACER_PCI_SEG1_EXS_BASE         0x58380000
+
+#define SYNQUACER_PCI_SEG1_BUSNUM_MIN       0x0
+#define SYNQUACER_PCI_SEG1_BUSNUM_MAX       0x7e
+
+#define SYNQUACER_PCI_SEG1_PORTIO_MIN       0x10000
+#define SYNQUACER_PCI_SEG1_PORTIO_MAX       0x1ffff
+#define SYNQUACER_PCI_SEG1_PORTIO_SIZE      0x10000
+#define SYNQUACER_PCI_SEG1_PORTIO_MEMBASE   0x77f00000
+#define SYNQUACER_PCI_SEG1_PORTIO_MEMSIZE   SYNQUACER_PCI_SEG1_PORTIO_SIZE
+
+#define SYNQUACER_PCI_SEG1_MMIO32_MIN       0x78000000
+#define SYNQUACER_PCI_SEG1_MMIO32_MAX       0x7fffffff
+#define SYNQUACER_PCI_SEG1_MMIO32_SIZE      0x08000000
+
+#define SYNQUACER_PCI_SEG1_MMIO64_MIN       0x3f00000000
+#define SYNQUACER_PCI_SEG1_MMIO64_MAX       0x3fffffffff
+#define SYNQUACER_PCI_SEG1_MMIO64_SIZE      0x100000000
+
+#endif
diff --git a/Silicon/Socionext/SynQuacer/SynQuacer.dec b/Silicon/Socionext/SynQuacer/SynQuacer.dec
new file mode 100644
index 000000000000..c3adf85d3562
--- /dev/null
+++ b/Silicon/Socionext/SynQuacer/SynQuacer.dec
@@ -0,0 +1,20 @@ 
+#
+#  Copyright (c) 2017, Linaro, Ltd. All rights reserved.
+#
+#  This program and the accompanying materials
+#  are licensed and made available under the terms and conditions of the BSD License
+#  which accompanies this distribution.  The full text of the license may be found at
+#  http://opensource.org/licenses/bsd-license.php
+#
+#  THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
+#  WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
+#
+
+[Defines]
+  DEC_SPECIFICATION              = 0x0001001A
+  PACKAGE_NAME                   = SynQuacer
+  PACKAGE_GUID                   = 9c782fd2-7db1-438d-b51c-2155cee2c5cc
+  PACKAGE_VERSION                = 0.1
+
+[Includes]
+  Include