SAMD21: Add memory map header file

This commit is contained in:
Gregory Nutt 2015-06-20 15:02:25 -06:00
parent b4682bd839
commit 62973af6eb
4 changed files with 179 additions and 13 deletions

View File

@ -394,10 +394,15 @@
/* Internal memory */ /* Internal memory */
# define SAMDL_FLASH_SIZE (32*1024) /* 32KB */ # define SAMDL_FLASH_SIZE (32*1024) /* 32KB */
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */
# define SAMDL_SRAM0_SIZE (4*1024) /* 4KB */ # define SAMDL_SRAM0_SIZE (4*1024) /* 4KB */
# define SAMDL_LPRAM_SIZE (0*1024) /* None */ # define SAMDL_LPRAM_SIZE (0*1024) /* None */
# if defined(CONFIG_ARCH_CHIP_SAMD21E15A)
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
# else
# define SAMDL_FLASHRWW_SIZE (1*1024) /* 1KB */
# endif
#elif defined(CONFIG_ARCH_CHIP_SAMD21E16A) || defined(CONFIG_ARCH_CHIP_SAMD21E16B) #elif defined(CONFIG_ARCH_CHIP_SAMD21E16A) || defined(CONFIG_ARCH_CHIP_SAMD21E16B)
# define SAMD21 1 /* SAMD21 family */ # define SAMD21 1 /* SAMD21 family */
@ -408,10 +413,15 @@
/* Internal memory */ /* Internal memory */
# define SAMDL_FLASH_SIZE (64*1024) /* 64KB */ # define SAMDL_FLASH_SIZE (64*1024) /* 64KB */
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */
# define SAMDL_SRAM0_SIZE (8*1024) /* 8KB */ # define SAMDL_SRAM0_SIZE (8*1024) /* 8KB */
# define SAMDL_LPRAM_SIZE (0*1024) /* None */ # define SAMDL_LPRAM_SIZE (0*1024) /* None */
# if defined(CONFIG_ARCH_CHIP_SAMD21E16A)
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
# else
# define SAMDL_FLASHRWW_SIZE (2*1024) /* 2KB */
# endif
#elif defined(CONFIG_ARCH_CHIP_SAMD21E17A) #elif defined(CONFIG_ARCH_CHIP_SAMD21E17A)
# define SAMD21 1 /* SAMD21 family */ # define SAMD21 1 /* SAMD21 family */
@ -422,7 +432,7 @@
/* Internal memory */ /* Internal memory */
# define SAMDL_FLASH_SIZE (128*1024) /* 128KB */ # define SAMDL_FLASH_SIZE (128*1024) /* 128KB */
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */ # define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
# define SAMDL_SRAM0_SIZE (16*1024) /* 16KB */ # define SAMDL_SRAM0_SIZE (16*1024) /* 16KB */
# define SAMDL_LPRAM_SIZE (0*1024) /* None */ # define SAMDL_LPRAM_SIZE (0*1024) /* None */
@ -436,7 +446,7 @@
/* Internal memory */ /* Internal memory */
# define SAMDL_FLASH_SIZE (256*1024) /* 256KB */ # define SAMDL_FLASH_SIZE (256*1024) /* 256KB */
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */ # define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
# define SAMDL_SRAM0_SIZE (32*1024) /* 32KB */ # define SAMDL_SRAM0_SIZE (32*1024) /* 32KB */
# define SAMDL_LPRAM_SIZE (0*1024) /* None */ # define SAMDL_LPRAM_SIZE (0*1024) /* None */
@ -450,10 +460,15 @@
/* Internal memory */ /* Internal memory */
# define SAMDL_FLASH_SIZE (32*1024) /* 32KB */ # define SAMDL_FLASH_SIZE (32*1024) /* 32KB */
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */
# define SAMDL_SRAM0_SIZE (4*1024) /* 4KB */ # define SAMDL_SRAM0_SIZE (4*1024) /* 4KB */
# define SAMDL_LPRAM_SIZE (0*1024) /* None */ # define SAMDL_LPRAM_SIZE (0*1024) /* None */
# if defined(CONFIG_ARCH_CHIP_SAMD21G15A)
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
# else
# define SAMDL_FLASHRWW_SIZE (1*1024) /* 1KB */
# endif
#elif defined(CONFIG_ARCH_CHIP_SAMD21G16A) || defined(CONFIG_ARCH_CHIP_SAMD21G16B) #elif defined(CONFIG_ARCH_CHIP_SAMD21G16A) || defined(CONFIG_ARCH_CHIP_SAMD21G16B)
# define SAMD21 1 /* SAMD21 family */ # define SAMD21 1 /* SAMD21 family */
@ -464,10 +479,15 @@
/* Internal memory */ /* Internal memory */
# define SAMDL_FLASH_SIZE (64*1024) /* 64KB */ # define SAMDL_FLASH_SIZE (64*1024) /* 64KB */
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */
# define SAMDL_SRAM0_SIZE (8*1024) /* 8KB */ # define SAMDL_SRAM0_SIZE (8*1024) /* 8KB */
# define SAMDL_LPRAM_SIZE (0*1024) /* None */ # define SAMDL_LPRAM_SIZE (0*1024) /* None */
# if defined(CONFIG_ARCH_CHIP_SAMD21G16A)
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
# else
# define SAMDL_FLASHRWW_SIZE (2*1024) /* 2KB */
# endif
#elif defined(CONFIG_ARCH_CHIP_SAMD21G17A) #elif defined(CONFIG_ARCH_CHIP_SAMD21G17A)
# define SAMD21 1 /* SAMD21 family */ # define SAMD21 1 /* SAMD21 family */
@ -478,7 +498,7 @@
/* Internal memory */ /* Internal memory */
# define SAMDL_FLASH_SIZE (128*1024) /* 128KB */ # define SAMDL_FLASH_SIZE (128*1024) /* 128KB */
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */ # define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
# define SAMDL_SRAM0_SIZE (16*1024) /* 16KB */ # define SAMDL_SRAM0_SIZE (16*1024) /* 16KB */
# define SAMDL_LPRAM_SIZE (0*1024) /* None */ # define SAMDL_LPRAM_SIZE (0*1024) /* None */
@ -492,7 +512,7 @@
/* Internal memory */ /* Internal memory */
# define SAMDL_FLASH_SIZE (256*1024) /* 256KB */ # define SAMDL_FLASH_SIZE (256*1024) /* 256KB */
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */ # define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
# define SAMDL_SRAM0_SIZE (32*1024) /* 32KB */ # define SAMDL_SRAM0_SIZE (32*1024) /* 32KB */
# define SAMDL_LPRAM_SIZE (0*1024) /* None */ # define SAMDL_LPRAM_SIZE (0*1024) /* None */
@ -506,10 +526,15 @@
/* Internal memory */ /* Internal memory */
# define SAMDL_FLASH_SIZE (32*1024) /* 32KB */ # define SAMDL_FLASH_SIZE (32*1024) /* 32KB */
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */
# define SAMDL_SRAM0_SIZE (4*1024) /* 4KB */ # define SAMDL_SRAM0_SIZE (4*1024) /* 4KB */
# define SAMDL_LPRAM_SIZE (0*1024) /* None */ # define SAMDL_LPRAM_SIZE (0*1024) /* None */
# if defined(CONFIG_ARCH_CHIP_SAMD21J15A)
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
# else
# define SAMDL_FLASHRWW_SIZE (1*1024) /* 1KB */
# endif
#elif defined(CONFIG_ARCH_CHIP_SAMD21J16A) || defined(CONFIG_ARCH_CHIP_SAMD21J16B) #elif defined(CONFIG_ARCH_CHIP_SAMD21J16A) || defined(CONFIG_ARCH_CHIP_SAMD21J16B)
# define SAMD21 1 /* SAMD21 family */ # define SAMD21 1 /* SAMD21 family */
@ -520,10 +545,15 @@
/* Internal memory */ /* Internal memory */
# define SAMDL_FLASH_SIZE (64*1024) /* 64KB */ # define SAMDL_FLASH_SIZE (64*1024) /* 64KB */
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */
# define SAMDL_SRAM0_SIZE (8*1024) /* 8KB */ # define SAMDL_SRAM0_SIZE (8*1024) /* 8KB */
# define SAMDL_LPRAM_SIZE (0*1024) /* None */ # define SAMDL_LPRAM_SIZE (0*1024) /* None */
# if defined(CONFIG_ARCH_CHIP_SAMD21J16A)
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
# else
# define SAMDL_FLASHRWW_SIZE (2*1024) /* 2KB */
# endif
#elif defined(CONFIG_ARCH_CHIP_SAMD21J17A) #elif defined(CONFIG_ARCH_CHIP_SAMD21J17A)
# define SAMD21 1 /* SAMD21 family */ # define SAMD21 1 /* SAMD21 family */
@ -534,7 +564,7 @@
/* Internal memory */ /* Internal memory */
# define SAMDL_FLASH_SIZE (128*1024) /* 128KB */ # define SAMDL_FLASH_SIZE (128*1024) /* 128KB */
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */ # define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
# define SAMDL_SRAM0_SIZE (16*1024) /* 16KB */ # define SAMDL_SRAM0_SIZE (16*1024) /* 16KB */
# define SAMDL_LPRAM_SIZE (0*1024) /* None */ # define SAMDL_LPRAM_SIZE (0*1024) /* None */
@ -548,7 +578,7 @@
/* Internal memory */ /* Internal memory */
# define SAMDL_FLASH_SIZE (256*1024) /* 256KB */ # define SAMDL_FLASH_SIZE (256*1024) /* 256KB */
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */ # define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
# define SAMDL_SRAM0_SIZE (32*1024) /* 32KB */ # define SAMDL_SRAM0_SIZE (32*1024) /* 32KB */
# define SAMDL_LPRAM_SIZE (0*1024) /* None */ # define SAMDL_LPRAM_SIZE (0*1024) /* None */

View File

@ -1,9 +1,13 @@
/**************************************************************************************** /****************************************************************************************
* arch/arm/include/samd/samd21_irq.h * arch/arm/include/samd/samd21_irq.h
* *
* Copyright (C) 2014 Gregory Nutt. All rights reserved. * Copyright (C) 2015 Gregory Nutt. All rights reserved.
* Author: Gregory Nutt <gnutt@nuttx.org> * Author: Gregory Nutt <gnutt@nuttx.org>
* *
* References:
* "Atmel SAM D21E / SAM D21G / SAM D21J SMART ARM-Based Microcontroller
* Datasheet", Atmel-42181ESAM-D21_Datasheet02/2015
*
* Redistribution and use in source and binary forms, with or without * Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions * modification, are permitted provided that the following conditions
* are met: * are met:

View File

@ -56,6 +56,8 @@
#if defined(CONFIG_ARCH_FAMILY_SAMD20) #if defined(CONFIG_ARCH_FAMILY_SAMD20)
# include "chip/samd20_memorymap.h" # include "chip/samd20_memorymap.h"
#elif defined(CONFIG_ARCH_FAMILY_SAMD21)
# include "chip/samd21_memorymap.h"
#elif defined(CONFIG_ARCH_FAMILY_SAML21) #elif defined(CONFIG_ARCH_FAMILY_SAML21)
# include "chip/saml21_memorymap.h" # include "chip/saml21_memorymap.h"
#else #else

View File

@ -0,0 +1,130 @@
/********************************************************************************************
* arch/arm/src/samdl/chip/samd21_memorymap.h
*
* Copyright (C) 2015 Gregory Nutt. All rights reserved.
* Author: Gregory Nutt <gnutt@nuttx.org>
*
* References:
* "Atmel SAM D21E / SAM D21G / SAM D21J SMART ARM-Based Microcontroller
* Datasheet", Atmel-42181ESAM-D21_Datasheet02/2015
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
* 3. Neither the name NuttX nor the names of its contributors may be
* used to endorse or promote products derived from this software
* without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*
********************************************************************************************/
#ifndef __ARCH_ARM_SRC_SAMDL_CHIP_SAMD21_MEMORYMAP_H
#define __ARCH_ARM_SRC_SAMDL_CHIP_SAMD21_MEMORYMAP_H
/********************************************************************************************
* Included Files
********************************************************************************************/
#include <nuttx/config.h>
#include "chip.h"
/********************************************************************************************
* Pre-processor Definitions
********************************************************************************************/
/* System Memory Map */
#define SAM_FLASH_BASE 0x00000000 /* Embedded FLASH memory space (<= 256KB) */
#define SAM_FLASHRWW_BASE 0x00100000 /* Embedded FLASH RWW memory space (<= 2KB) */
#define SAM_CALIB_BASE 0x00800000 /* Calibration and auxiliary space */
#define SAM_SRAM_BASE 0x20000000 /* Embedded SRAM memory space (<= 64KB) */
#define SAM_AHBA_BASE 0x40000000 /* AHB-APB Bridge A (64KB) */
#define SAM_AHBB_BASE 0x41000000 /* AHB-APB Bridge B (64KB) */
#define SAM_AHBC_BASE 0x42000000 /* AHB-APB Bridge C (64KB) */
/* Calibration and Auxiliary Space */
#define SAM_AUTOCAL_BASE 0x00800000 /* Automatic Calibration row */
#define SAM_AUX0_BASE 0x00804000 /* AUX0 offset address */
#define SAM_AUX1_BASE 0x00806000 /* AUX1 offset address */
# define SAM_AUX1_AREA1 0x00806000 /* Area 1 offset address (reserved, 64 bits) */
# define SAM_AUX1_AREA2 0x00806008 /* Area 2 Device configuration area (64 bits) */
# define SAM_AUX1_AREA3 0x00806010 /* Area 3 offset address (reserved, 128 bits) */
# define SAM_AUX1_AREA4 0x00806020 /* Area 4 Software calibration area (256 bits) */
/* AHB-APB Bridge A */
#define SAM_PAC0_BASE 0x40000000 /* Peripheral Access Controller 0 */
#define SAM_PM_BASE 0x40000400 /* Power Manager */
#define SAM_SYSCTRL_BASE 0x40000800 /* System Controller */
#define SAM_GCLK_BASE 0x40000c00 /* Generic Clock Controller */
#define SAM_WDT_BASE 0x40001000 /* Watchdog Timer */
#define SAM_RTC_BASE 0x40001400 /* Real-Time Counter */
#define SAM_EIC_BASE 0x40001800 /* External Interrupt Controller */
/* AHB-APB Bridge B */
#define SAM_PAC1_BASE 0x41000000 /* Peripheral Access Controller 1 */
#define SAM_DSU_BASE 0x41002000 /* Device Service Unit */
#define SAM_NVMCTRL_BASE 0x41004000 /* Non-Volatile Memory Controller */
#define SAM_PORT_BASE 0x41004400 /* Ports */
#define SAM_DMAC_BASE 0x41004800 /* DMA Controller */
#define SAM_USB_BASE 0x41005000 /* USB */
#define SAM_MTB_BASE 0x41006000 /* Micro Trace Buffer (MTB) */
/* AHB-APB Bridge C */
#define SAM_PAC2_BASE 0x42000000 /* Peripheral Access Controller 2 */
#define SAM_EVSYS_BASE 0x42000400 /* Event System */
#define SAM_SERCOM0_BASE 0x42000800 /* Serial Communication Interface 0 */
#define SAM_SERCOM1_BASE 0x42000c00 /* Serial Communication Interface 1 */
#define SAM_SERCOM2_BASE 0x42001000 /* Serial Communication Interface 2 */
#define SAM_SERCOM3_BASE 0x42001400 /* Serial Communication Interface 3 */
#define SAM_SERCOM4_BASE 0x42001800 /* Serial Communication Interface 4 */
#define SAM_SERCOM5_BASE 0x42001c00 /* Serial Communication Interface 5 */
#define SAM_TCC0_BASE 0x42002000 /* Timer/Counter Control 0 */
#define SAM_TCC1_BASE 0x42002400 /* Timer/Counter Control 1 */
#define SAM_TCC2_BASE 0x42002800 /* Timer/Counter Control 2 */
#define SAM_TC3_BASE 0x42002c00 /* Timer/Counter 3 */
#define SAM_TC4_BASE 0x42003000 /* Timer/Counter 4 */
#define SAM_TC5_BASE 0x42003400 /* Timer/Counter 5 */
#define SAM_TC6_BASE 0x42003800 /* Timer/Counter 6 */
#define SAM_TC7_BASE 0x42003c00 /* Timer/Counter 7 */
#define SAM_ADC_BASE 0x42004000 /* Analog-to-Digital Converter */
#define SAM_AC_BASE 0x42004400 /* Analog Comparator*/
#define SAM_DAC_BASE 0x42004800 /* Digital-to-Analog Converter */
#define SAM_PTC_BASE 0x42004c00 /* Peripheral Touch Controller */
#define SAM_I2S_BASE 0x42005000 /* Inter IC Sound */
/********************************************************************************************
* Public Types
********************************************************************************************/
/********************************************************************************************
* Public Data
********************************************************************************************/
/********************************************************************************************
* Public Functions
********************************************************************************************/
#endif /* __ARCH_ARM_SRC_SAMDL_CHIP_SAMD21_MEMORYMAP_H */