PIC32MZ: Add just enough PIC32MZ logic that we can run 'make menuconfig'
This commit is contained in:
parent
ea1640a0a8
commit
13926ce019
@ -180,6 +180,8 @@
|
|||||||
| | | `- <a href="http://sourceforge.net/p/nuttx/git/ci/master/tree/nuttx/configs/pic32mx-starterkit/README.txt"><b><i>README.txt</i></b></a>
|
| | | `- <a href="http://sourceforge.net/p/nuttx/git/ci/master/tree/nuttx/configs/pic32mx-starterkit/README.txt"><b><i>README.txt</i></b></a>
|
||||||
| | |- pic32mx7mmb/
|
| | |- pic32mx7mmb/
|
||||||
| | | `- <a href="http://sourceforge.net/p/nuttx/git/ci/master/tree/nuttx/configs/pic32mx7mmb/README.txt"><b><i>README.txt</i></b></a>
|
| | | `- <a href="http://sourceforge.net/p/nuttx/git/ci/master/tree/nuttx/configs/pic32mx7mmb/README.txt"><b><i>README.txt</i></b></a>
|
||||||
|
| | |- pic32mz-starterkit/
|
||||||
|
| | | `- <a href="http://sourceforge.net/p/nuttx/git/ci/master/tree/nuttx/configs/pic32mz-starterkit/README.txt"><b><i>README.txt</i></b></a>
|
||||||
| | |- pirelli_dpl10/
|
| | |- pirelli_dpl10/
|
||||||
| | | `- <a href="http://sourceforge.net/p/nuttx/git/ci/master/tree/nuttx/configs/pirelli_dpl10/README.txt"><b><i>README.txt</i></b></a>
|
| | | `- <a href="http://sourceforge.net/p/nuttx/git/ci/master/tree/nuttx/configs/pirelli_dpl10/README.txt"><b><i>README.txt</i></b></a>
|
||||||
| | |- qemu-i486/
|
| | |- qemu-i486/
|
||||||
|
@ -1237,6 +1237,8 @@ nuttx
|
|||||||
| | `- README.txt
|
| | `- README.txt
|
||||||
| |- pic32mx7mmb/
|
| |- pic32mx7mmb/
|
||||||
| | `- README.txt
|
| | `- README.txt
|
||||||
|
| |- pic32mz-starterkit/
|
||||||
|
| | `- README.txt
|
||||||
| |- pirelli_dpl10/
|
| |- pirelli_dpl10/
|
||||||
| | `- README.txt
|
| | `- README.txt
|
||||||
| |- qemu-i486/
|
| |- qemu-i486/
|
||||||
|
@ -16,7 +16,17 @@ config ARCH_CHIP_PIC32MX
|
|||||||
select ARCH_HAVE_RAMFUNCS
|
select ARCH_HAVE_RAMFUNCS
|
||||||
select ARCH_HAVE_SERIAL_TERMIOS
|
select ARCH_HAVE_SERIAL_TERMIOS
|
||||||
---help---
|
---help---
|
||||||
Microchip PIC32MX320F032H (MIPS32)
|
Microchip PIC32MX (MIPS32)
|
||||||
|
|
||||||
|
config ARCH_CHIP_PIC32MZ
|
||||||
|
bool "PIC32MZ"
|
||||||
|
select ARCH_MIPS32
|
||||||
|
select ARCH_HAVE_IRQPRIO
|
||||||
|
select ARCH_VECNOTIRQ
|
||||||
|
select ARCH_HAVE_RAMFUNCS
|
||||||
|
select ARCH_HAVE_SERIAL_TERMIOS
|
||||||
|
---help---
|
||||||
|
Microchip PIC32MZ (MIPS32)
|
||||||
|
|
||||||
endchoice
|
endchoice
|
||||||
|
|
||||||
@ -32,9 +42,11 @@ config ARCH_FAMILY
|
|||||||
config ARCH_CHIP
|
config ARCH_CHIP
|
||||||
string
|
string
|
||||||
default "pic32mx" if ARCH_CHIP_PIC32MX
|
default "pic32mx" if ARCH_CHIP_PIC32MX
|
||||||
|
default "pic32mz" if ARCH_CHIP_PIC32MZ
|
||||||
|
|
||||||
source arch/mips/src/common/Kconfig
|
source arch/mips/src/common/Kconfig
|
||||||
source arch/mips/src/mips32/Kconfig
|
source arch/mips/src/mips32/Kconfig
|
||||||
source arch/mips/src/pic32mx/Kconfig
|
source arch/mips/src/pic32mx/Kconfig
|
||||||
|
source arch/mips/src/pic32mz/Kconfig
|
||||||
|
|
||||||
endif
|
endif
|
||||||
|
158
arch/mips/include/pic32mz/chip.h
Normal file
158
arch/mips/include/pic32mz/chip.h
Normal file
@ -0,0 +1,158 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
* arch/mips/include/pic32mz/chip.h
|
||||||
|
*
|
||||||
|
* Copyright (C) 2015 Gregory Nutt. All rights reserved.
|
||||||
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
|
*
|
||||||
|
* 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_MIPS_INCLUDE_PIC32MZ_CHIP_H
|
||||||
|
#define __ARCH_MIPS_INCLUDE_PIC32MZ_CHIP_H
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Included Files
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#include <nuttx/config.h>
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Pre-Processor Definitions
|
||||||
|
****************************************************************************/
|
||||||
|
/* Configuration ************************************************************/
|
||||||
|
config ARCH_CHIP_PIC32MZ2048ECH
|
||||||
|
bool "PIC32MZ2048ECH"
|
||||||
|
select ARCH_CHIP_PIC32MZEC
|
||||||
|
---help---
|
||||||
|
Microchip PIC32MZ2048ECH (MIPS32)
|
||||||
|
ARCH_CHIP_PIC32MZ1
|
||||||
|
|
||||||
|
config ARCH_CHIP_PIC32MZ2048ECM
|
||||||
|
|
||||||
|
/* Available in 64/100/124/144 pin packages. Description here is specifically
|
||||||
|
* for the 144 pin package (PIC32MZ2048ECH144) and should be reviewed for
|
||||||
|
* other parts.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#if defined(CONFIG_ARCH_CHIP_PIC32MZ2048ECH)
|
||||||
|
# define CHIP_PIC32MZEC 1
|
||||||
|
# define CHIP_BOOTFLASH_KB 160 /* 160Kb boot FLASH */
|
||||||
|
# define CHIP_PROGFLASH_KB 2048 /* 2048Kb program FLASH */
|
||||||
|
# define CHIP_DATAMEM_KB 512 /* 512Kb data memory */
|
||||||
|
# define CHIP_NTIMERS 9 /* 5 timers */
|
||||||
|
# define CHIP_NIC 9 /* 5 input capture */
|
||||||
|
# define CHIP_NOC 9 /* 5 output compare */
|
||||||
|
# define CHIP_NUARTS 6 /* 6 UARTS */
|
||||||
|
# define CHIP_UARTFIFOD 8 /* 8 level deep UART FIFOs */
|
||||||
|
# define CHIP_NSPI 6 /* 6 SPI/I2S interfaces */
|
||||||
|
# define CHIP_NCAN 2 /* 2 CAN interfaces */
|
||||||
|
# define CHIP_NCRTYPO 0 /* No crtypo support */
|
||||||
|
# define CHIP_RNG 1 /* 1 Random number generator */
|
||||||
|
# define CHIP_NDMACH 8 /* 8 programmable DMA channels */
|
||||||
|
# define CHIP_NUSBDMACHAN 16 /* 16 dedicated DMA channels */
|
||||||
|
# define CHIP_NADC10 48 /* 48 ADC channels */
|
||||||
|
# define CHIP_NCM 2 /* 2 Analog comparators */
|
||||||
|
# define CHIP_USBHSOTG 1 /* 1 USB 2.0 HSOTG */
|
||||||
|
# define CHIP_NI2C 5 /* 5 I2C interfaces */
|
||||||
|
# define CHIP_NPMP 1 /* Have parallel master port */
|
||||||
|
# define CHIP_NEBI 1 /* Have eternal bus interface */
|
||||||
|
# define CHIP_NSQI 1 /* 1 Serial quad interface */
|
||||||
|
# define CHIP_NRTCC 1 /* Has RTCC */
|
||||||
|
# define CHIP_NETHERNET 1 /* 1 Ethernet MAC */
|
||||||
|
# define CHIP_NPORTS 10 /* 10 ports (A-H, J-K) */
|
||||||
|
# define CHIP_NJTAG 1 /* Has JTAG */
|
||||||
|
# define CHIP_NTRACE 1 /* Has trace capability */
|
||||||
|
|
||||||
|
/* Available in 64/100/124/144 pin packages. Description here is specifically
|
||||||
|
* for the 144 pin package (PIC32MZ2048ECM144) and should be reviewed for
|
||||||
|
* other parts.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#elif defined(CONFIG_ARCH_CHIP_PIC32MZ2048ECM)
|
||||||
|
# define CHIP_PIC32MZEC 1
|
||||||
|
# define CHIP_BOOTFLASH_KB 160 /* 160Kb boot FLASH */
|
||||||
|
# define CHIP_PROGFLASH_KB 2048 /* 2048Kb program FLASH */
|
||||||
|
# define CHIP_DATAMEM_KB 512 /* 512Kb data memory */
|
||||||
|
# define CHIP_NTIMERS 9 /* 5 timers */
|
||||||
|
# define CHIP_NIC 9 /* 5 input capture */
|
||||||
|
# define CHIP_NOC 9 /* 5 output compare */
|
||||||
|
# define CHIP_NUARTS 6 /* 6 UARTS */
|
||||||
|
# define CHIP_UARTFIFOD 8 /* 8 level deep UART FIFOs */
|
||||||
|
# define CHIP_NSPI 6 /* 6 SPI/I2S interfaces */
|
||||||
|
# define CHIP_NCAN 2 /* 2 CAN interfaces */
|
||||||
|
# define CHIP_NCRTYPO 1 /* Has crtypo support */
|
||||||
|
# define CHIP_RNG 1 /* 1 Random number generator */
|
||||||
|
# define CHIP_NDMACH 8 /* 8 programmable DMA channels */
|
||||||
|
# define CHIP_NUSBDMACHAN 18 /* 18 dedicated DMA channels */
|
||||||
|
# define CHIP_NADC10 48 /* 48 ADC channels */
|
||||||
|
# define CHIP_NCM 2 /* 2 Analog comparators */
|
||||||
|
# define CHIP_USBHSOTG 1 /* 1 USB 2.0 HSOTG */
|
||||||
|
# define CHIP_NI2C 5 /* 5 I2C interfaces */
|
||||||
|
# define CHIP_NPMP 1 /* Have parallel master port */
|
||||||
|
# define CHIP_NEBI 1 /* Have eternal bus interface */
|
||||||
|
# define CHIP_NSQI 1 /* 1 Serial quad interface */
|
||||||
|
# define CHIP_NRTCC 1 /* Has RTCC */
|
||||||
|
# define CHIP_NETHERNET 1 /* 1 Ethernet MAC */
|
||||||
|
# define CHIP_NPORTS 10 /* 10 ports (A-H, J-K) */
|
||||||
|
# define CHIP_NJTAG 1 /* Has JTAG */
|
||||||
|
# define CHIP_NTRACE 1 /* Has trace capability */
|
||||||
|
|
||||||
|
#else
|
||||||
|
# error "Unrecognized PIC32MZ device
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Types
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifndef __ASSEMBLY__
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Inline Functions
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Function Prototypes
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
#define EXTERN extern "C"
|
||||||
|
extern "C"
|
||||||
|
{
|
||||||
|
#else
|
||||||
|
#define EXTERN extern
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#undef EXTERN
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* __ASSEMBLY__ */
|
||||||
|
#endif /* __ARCH_MIPS_INCLUDE_PIC32MZ_CHIP_H */
|
397
arch/mips/include/pic32mz/cp0.h
Normal file
397
arch/mips/include/pic32mz/cp0.h
Normal file
@ -0,0 +1,397 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
* arch/mips/include/pic32mz/cp0.h
|
||||||
|
*
|
||||||
|
* Copyright (C) 2015 Gregory Nutt. All rights reserved.
|
||||||
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
|
*
|
||||||
|
* 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_MIPS_INCLUDE_PIC32MZ_CP0_H
|
||||||
|
#define __ARCH_MIPS_INCLUDE_PIC32MZ_CP0_H
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Included Files
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#include <nuttx/config.h>
|
||||||
|
|
||||||
|
#include <arch/mips32/cp0.h>
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Pre-Processor Definitions
|
||||||
|
****************************************************************************/
|
||||||
|
/* CP0 Register Addresses ***************************************************/
|
||||||
|
|
||||||
|
#ifdef __ASSEMBLY__
|
||||||
|
# define PIC32MZ_CP0_HWRENA $7,0 /* Enables access via RDHWR hardware registers */
|
||||||
|
# define PIC32MZ_CP0_BADVADDR $8,0 /* Address of most recent exception */
|
||||||
|
# define PIC32MZ_CP0_COUNT $9,0 /* Processor cycle count */
|
||||||
|
# define PIC32MZ_CP0_COMPARE $11,0 /* Timer interrupt control */
|
||||||
|
# define PIC32MZ_CP0_STATUS $12,0 /* Processor status and control */
|
||||||
|
# define PIC32MZ_CP0_INTCTL $12,1 /* Interrupt system status and control */
|
||||||
|
# define PIC32MZ_CP0_SRSCTL $12,2 /* Shadow register set status and control */
|
||||||
|
# define PIC32MZ_CP0_SRSMAP $12,3 /* Maps from vectored interrupt to a shadow set */
|
||||||
|
# define PIC32MZ_CP0_CAUSE $13,0 /* Cause of last general exception */
|
||||||
|
# define PIC32MZ_CP0_EPC $14,0 /* Program counter at last exception */
|
||||||
|
# define PIC32MZ_CP0_PRID $15,0 /* Processor identification and revision */
|
||||||
|
# define PIC32MZ_CP0_EBASE $15,1 /* Exception vector base register */
|
||||||
|
# define PIC32MZ_CP0_CONFIG $16,0 /* Configuration register */
|
||||||
|
# define PIC32MZ_CP0_CONFIG1 $16,1 /* Configuration register 1 */
|
||||||
|
# define PIC32MZ_CP0_CONFIG2 $16,2 /* Configuration register 3 */
|
||||||
|
# define PIC32MZ_CP0_CONFIG3 $16,3 /* Configuration register 3 */
|
||||||
|
# define PIC32MZ_CP0_DEBUG $23,3 /* Debug control and exception status */
|
||||||
|
# define PIC32MZ_CP0_DEPC $24,3 /* Program counter at last debug exception */
|
||||||
|
# define PIC32MZ_CP0_ERREPC $30,3 /* Program counter at last error */
|
||||||
|
# define PIC32MZ_CP0_DESAVE $31,3 /* Debug handler scratchpad register */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* CP0 Registers ************************************************************/
|
||||||
|
|
||||||
|
/* Register Number: 0-6: Reserved
|
||||||
|
* Compliance Level: Required for TLB-based MMU; Optional otherwise.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Register Number: 7 Sel: 0 Name: HWREna
|
||||||
|
* Function: Enables access via the RDHWR instruction to selected hardware
|
||||||
|
* registers in non-privileged mode.
|
||||||
|
* Compliance Level: (Reserved for future extensions)
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define CP0_HWRENA_SHIFT (0) /* Bits 0-3: Enable access to a hardware resource */
|
||||||
|
#define CP0_HWRENA_MASK (15 << CP0_HWRENA_SHIFT)
|
||||||
|
# define CP0_HWRENA_BIT0 (1 << CP0_HWRENA_SHIFT)
|
||||||
|
# define CP0_HWRENA_BIT1 (2 << CP0_HWRENA_SHIFT)
|
||||||
|
# define CP0_HWRENA_BIT2 (4 << CP0_HWRENA_SHIFT)
|
||||||
|
# define CP0_HWRENA_BIT3 (8 << CP0_HWRENA_SHIFT)
|
||||||
|
|
||||||
|
/* Register Number: 8 Sel: 0 Name: BadVAddr
|
||||||
|
* Function: Reports the address for the most recent address-related
|
||||||
|
* exception
|
||||||
|
* Compliance Level: Required.
|
||||||
|
*
|
||||||
|
* See arch/mips/include/mips32/cp0.h
|
||||||
|
*
|
||||||
|
* Register Number: 9 Sel: 0 Name: Count
|
||||||
|
* Function: Processor cycle count
|
||||||
|
* Compliance Level: Required.
|
||||||
|
*
|
||||||
|
* See arch/mips/include/mips32/cp0.h
|
||||||
|
*
|
||||||
|
* Register Number: 10 Reserved.
|
||||||
|
* Compliance Level: Required for TLB-based MMU; Optional otherwise.
|
||||||
|
*
|
||||||
|
* Register Number: 11 Sel: 0 Name: Compare
|
||||||
|
* Function: Timer interrupt control
|
||||||
|
* Compliance Level: Required.
|
||||||
|
*
|
||||||
|
* See arch/mips/include/mips32/cp0.h
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Register Number: 12 Sel: 0 Name: Status
|
||||||
|
* Function: Processor status and control
|
||||||
|
* Compliance Level: Required.
|
||||||
|
*
|
||||||
|
* See arch/mips/include/mips32/cp0.h
|
||||||
|
* NOTES:
|
||||||
|
* 1. The following are reserved bits in the PIC32:
|
||||||
|
* CP0_STATUS_UX Bit 5: Enables 64-bit user address space (Not MIPS32)
|
||||||
|
* CP0_STATUS_SX Bit 6: Enables 64-bit supervisor address space (Not MIPS32)
|
||||||
|
* CP0_STATUS_KX Bit 7: Enables 64-bit kernel address space (Not MIPS32)
|
||||||
|
* CP0_STATUS_IMPL Bits 16-17: Implementation dependent
|
||||||
|
* CP0_STATUS_TS Bit 21: TLB detected match on multiple entries
|
||||||
|
* CP0_STATUS_PX Bit 23: Enables 64-bit operations (Not MIPS32)
|
||||||
|
* CP0_STATUS_MX Bit 24: Enables MDMX™ (Not MIPS32)
|
||||||
|
*/
|
||||||
|
|
||||||
|
#undef CP0_STATUS_UX
|
||||||
|
#undef CP0_STATUS_SX
|
||||||
|
#undef CP0_STATUS_KX
|
||||||
|
#undef CP0_STATUS_IMPL
|
||||||
|
#undef CP0_STATUS_IMPL_SHIFT
|
||||||
|
#undef CP0_STATUS_IMPL_MASK
|
||||||
|
#undef CP0_STATUS_TS
|
||||||
|
#undef CP0_STATUS_PX
|
||||||
|
#undef CP0_STATUS_MX
|
||||||
|
|
||||||
|
/* 2. The following field is of a different width. Apparently, it
|
||||||
|
* excludes the software interrupt bits.
|
||||||
|
*
|
||||||
|
* CP0_STATUS_IM Bits 8-15: Interrupt Mask
|
||||||
|
* Vs.
|
||||||
|
* CP0_STATUS_IPL Bits 10-15: Interrupt priority level
|
||||||
|
* Bitss 8-9 reserved
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define CP0_STATUS_IPL_SHIFT (10) /* Bits 10-15: Interrupt priority level */
|
||||||
|
#define CP0_STATUS_IPL_MASK (0x3f << CP0_STATUS_IPL_SHIFT)
|
||||||
|
|
||||||
|
/* 3. Supervisor mode not supported
|
||||||
|
* CP0_STATUS_KSU Bits 3-4: Operating mode (with supervisor mode)
|
||||||
|
*/
|
||||||
|
|
||||||
|
#undef CP0_STATUS_KSU_SHIFT
|
||||||
|
#undef CP0_STATUS_KSU_MASK
|
||||||
|
#undef CP0_STATUS_KSU_KERNEL
|
||||||
|
#undef CP0_STATUS_KSU_SUPER
|
||||||
|
#undef CP0_STATUS_KSU_USER
|
||||||
|
|
||||||
|
/* Register Number: 12 Sel: 1 Name: IntCtl */
|
||||||
|
|
||||||
|
#define CP0_INTCTL_VS_SHIFT (5) /* Bits 5-9: Vector spacing bits */
|
||||||
|
#define CP0_INTCTL_VS_MASK (0x1f << CP0_INTCTL_VS_SHIFT)
|
||||||
|
# define CP0_INTCTL_VS_0BYTES (0x00 << CP0_INTCTL_VS_SHIFT)
|
||||||
|
# define CP0_INTCTL_VS_32BYTES (0x01 << CP0_INTCTL_VS_SHIFT)
|
||||||
|
# define CP0_INTCTL_VS_64BYTES (0x02 << CP0_INTCTL_VS_SHIFT)
|
||||||
|
# define CP0_INTCTL_VS_128BYTES (0x04 << CP0_INTCTL_VS_SHIFT)
|
||||||
|
# define CP0_INTCTL_VS_256BYTES (0x08 << CP0_INTCTL_VS_SHIFT)
|
||||||
|
# define CP0_INTCTL_VS_512BYTES (0x10 << CP0_INTCTL_VS_SHIFT)
|
||||||
|
|
||||||
|
/* Register Number: 12 Sel: 2 Name: SRSCtl */
|
||||||
|
|
||||||
|
#define CP0_SRSCTL_CSS_SHIFT (0) /* Bits 0-3: Current shadow bit set */
|
||||||
|
#define CP0_SRSCTL_CSS_MASK (15 << CP0_SRSCTL_CSS_SHIFT)
|
||||||
|
#define CP0_SRSCTL_PSS_SHIFT (6) /* Bits 6-9: Previous shadow set */
|
||||||
|
#define CP0_SRSCTL_PSS_MASK (15 << CP0_SRSCTL_PSS_SHIFT)
|
||||||
|
#define CP0_SRSCTL_ESS_SHIFT (12) /* Bits 12-15: Exception shadow sets */
|
||||||
|
#define CP0_SRSCTL_ESS_MASK (15 << CP0_SRSCTL_ESS_SHIFT)
|
||||||
|
#define CP0_SRSCTL_EICSS_SHIFT (18) /* Bits 18-21: External interrupt controller shadow sets */
|
||||||
|
#define CP0_SRSCTL_EICSS_MASK (15 << CP0_SRSCTL_EICSS_SHIFT)
|
||||||
|
#define CP0_SRSCTL_HSS_SHIFT (26) /* Bits 26-29: High shadow sets */
|
||||||
|
#define CP0_SRSCTL_HSS_MASK (15 << CP0_SRSCTL_HSS_SHIFT)
|
||||||
|
# define CP0_SRSCTL_HSS_1SET (0 << CP0_SRSCTL_HSS_SHIFT) /* One shadow set (normal GPR set) */
|
||||||
|
# define CP0_SRSCTL_HSS_2SETS (1 << CP0_SRSCTL_HSS_SHIFT) /* Two shadow sets */
|
||||||
|
# define CP0_SRSCTL_HSS_4SETS (3 << CP0_SRSCTL_HSS_SHIFT) /* Four shadow sets */
|
||||||
|
|
||||||
|
/* Register Number: 12 Sel: 3 Name: SRSMap */
|
||||||
|
|
||||||
|
#define CP0_SRSMAP_SSV0_SHIFT (0) /* Bits 0-3: Shadow set vector 0 */
|
||||||
|
#define CP0_SRSMAP_SSV0_MASK (15 << CP0_SRSMAP_SSV0_SHIFT)
|
||||||
|
#define CP0_SRSMAP_SSV1_SHIFT (4) /* Bits 4-7: Shadow set vector 1 */
|
||||||
|
#define CP0_SRSMAP_SSV1_MASK (15 << CP0_SRSMAP_SSV1_SHIFT)
|
||||||
|
#define CP0_SRSMAP_SSV2_SHIFT (8) /* Bits 8-11: Shadow set vector 2 */
|
||||||
|
#define CP0_SRSMAP_SSV2_MASK (15 << CP0_SRSMAP_SSV2_SHIFT)
|
||||||
|
#define CP0_SRSMAP_SSV3_SHIFT (12) /* Bits 12-15: Shadow set vector 3 */
|
||||||
|
#define CP0_SRSMAP_SSV3_MASK (15 << CP0_SRSMAP_SSV3_SHIFT)
|
||||||
|
#define CP0_SRSMAP_SSV4_SHIFT (16) /* Bits 16-19: Shadow set vector 4 */
|
||||||
|
#define CP0_SRSMAP_SSV4_MASK (15 << CP0_SRSMAP_SSV4_SHIFT)
|
||||||
|
#define CP0_SRSMAP_SSV5_SHIFT (20) /* Bits 20-23: Shadow set vector 5 */
|
||||||
|
#define CP0_SRSMAP_SSV5_MASK (15 << CP0_SRSMAP_SSV5_SHIFT)
|
||||||
|
#define CP0_SRSMAP_SSV6_SHIFT (24) /* Bits 24-27: Shadow set vector 6 */
|
||||||
|
#define CP0_SRSMAP_SSV6_MASK (15 << CP0_SRSMAP_SSV6_SHIFT)
|
||||||
|
#define CP0_SRSMAP_SSV7_SHIFT (28) /* Bits 28-31: Shadow set vector 7 */
|
||||||
|
#define CP0_SRSMAP_SSV7_MASK (15 << CP0_SRSMAP_SSV7_SHIFT)
|
||||||
|
|
||||||
|
/* Register Number: 13 Sel: 0 Name: Cause
|
||||||
|
* Function: Cause of last general exception
|
||||||
|
* Compliance Level: Required.
|
||||||
|
*
|
||||||
|
* See arch/mips/include/mips32/cp0.h
|
||||||
|
* NOTES: The following bits are added in the PIC32:
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define CP0_CAUSE_R (1 << 26) /* Bit 26: R bit */
|
||||||
|
#define CP0_CAUSE_DC (1 << 27) /* Bit 27: Disable count */
|
||||||
|
#define CP0_CAUSE_TI (1 << 30) /* Bit 30: Timer interrupt bit *.
|
||||||
|
|
||||||
|
/* Register Number: 14 Sel: 0 Name: EPC
|
||||||
|
* Function: Program counter at last exception
|
||||||
|
* Compliance Level: Required.
|
||||||
|
*
|
||||||
|
* See arch/mips/include/mips32/cp0.h
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Register Number: 15 Sel: 0 Name: PRId
|
||||||
|
* Function: Processor identification and revision
|
||||||
|
* Compliance Level: Required.
|
||||||
|
*
|
||||||
|
* See arch/mips/include/mips32/cp0.h
|
||||||
|
* NOTE: Slightly different bit interpretations of some fields:
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define CP0_PRID_PATCH_SHIFT (5) /* Bits 0-1: Patch level */
|
||||||
|
#define CP0_PRID_PATCH_MASK (3 << CP0_PRID_PATCH_SHIFT)
|
||||||
|
#define CP0_PRID_MINOR_SHIFT (2) /* Bits 2-4: Minor revision number */
|
||||||
|
#define CP0_PRID_MINOR_MASK (7 << CP0_PRID_MINOR_SHIFT)
|
||||||
|
#define CP0_PRID_MAJOR_SHIFT (5) /* Bits 5-7: Major revision number */
|
||||||
|
#define CP0_PRID_MAJOR_MASK (7 << CP0_PRID_MAJOR_SHIFT)
|
||||||
|
|
||||||
|
#undef CP0_PRID_OPTIONS_SHIFT
|
||||||
|
#undef CP0_PRID_OPTIONS_MASK
|
||||||
|
|
||||||
|
/* Register Number: 15 Sel: 1 Name: EBASE */
|
||||||
|
|
||||||
|
#define CP_EBASE_CPUNUM_SHIFT (0) /* Bits 0-9: CPU number */
|
||||||
|
#define CP_EBASE_CPUNUM_MASK (0x3ff << CP_EBASE_CPUNUM_SHIFT)
|
||||||
|
#define CP_EBASE_SHIFT (12) /* Bits 30-31=10, Bits 12-29: Exception base */
|
||||||
|
#define CP_EBASE_MASK (0x3ffff << CP_EBASE_SHIFT)
|
||||||
|
|
||||||
|
/* Register Number: 16 Sel: 0 Name: Config
|
||||||
|
* Function: Configuration register
|
||||||
|
* Compliance Level: Required.
|
||||||
|
*
|
||||||
|
* See arch/mips/include/mips32/cp0.h
|
||||||
|
* 1. PIC32MZ is always little-endian.
|
||||||
|
* 2. Implementation specific bits defined.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#undef CP0_CONFIG_IMPL_SHIFT
|
||||||
|
#undef CP0_CONFIG_IMPL_MASK
|
||||||
|
|
||||||
|
#define CP0_CONFIG_K23_SHIFT (0) /* Bits 28-30: KSEG2 and KSEG3 cacheability */
|
||||||
|
#define CP0_CONFIG_K23_MASK (7 << CP0_CONFIG_K23_SHIFT)
|
||||||
|
# define CP0_CONFIG_K23_UNCACHED (2 << CP0_CONFIG_K23_SHIFT)
|
||||||
|
# define CP0_CONFIG_K23_CACHEABLE (3 << CP0_CONFIG_K23_SHIFT)
|
||||||
|
#define CP0_CONFIG_KU_SHIFT (0) /* Bits 0-2: KUSEG and USEG cacheability */
|
||||||
|
#define CP0_CONFIG_KU_MASK (7 << CP0_CONFIG_KU_SHIFT)
|
||||||
|
# define CP0_CONFIG_KU_UNCACHED (2 << CP0_CONFIG_KU_SHIFT)
|
||||||
|
# define CP0_CONFIG_KU_CACHEABLE (3 << CP0_CONFIG_KU_SHIFT)
|
||||||
|
#define CP0_CONFIG_UDI (1 << 22) /* Bit 22: User defined bit */
|
||||||
|
#define CP0_CONFIG_SB (1 << 21) /* Bit 32: Simple BE bus mode bit */
|
||||||
|
#define CP0_CONFIG_MDU (1 << 20) /* Multipley/Divide unit bit */
|
||||||
|
#define CP0_CONFIG_DS (1 << 16) /* Dual SRAM bit */
|
||||||
|
|
||||||
|
/* Register Number: 16 Sel: 1 Name: Config1
|
||||||
|
* Function: Configuration register 1
|
||||||
|
* Compliance Level: Required.
|
||||||
|
*
|
||||||
|
* See arch/mips/include/mips32/cp0.h
|
||||||
|
*
|
||||||
|
* Register Number: 16 Sel: 2 Name: Config2
|
||||||
|
* Function: Configuration register 2
|
||||||
|
* Compliance Level: Optional.
|
||||||
|
*
|
||||||
|
* See arch/mips/include/mips32/cp0.h
|
||||||
|
*/
|
||||||
|
|
||||||
|
#undef CP0_CONFIG2_TBS_SHIFT
|
||||||
|
#undef CP0_CONFIG2_TBS_MASK
|
||||||
|
|
||||||
|
/* Register Number: 16 Sel: 3 Name: Config3
|
||||||
|
* Function: Configuration register 3
|
||||||
|
* Compliance Level: Optional.
|
||||||
|
*
|
||||||
|
* See arch/mips/include/mips32/cp0.h
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define CP0_CONFIG3_SP (1 << 4) /* Bit 4: Support page bit */
|
||||||
|
#define CP0_CONFIG3_VINT (1 << 5) /* Bit 5: Vector interrupt bit */
|
||||||
|
#define CP0_CONFIG3_VEIC (1 << 6) /* Bit 6: External interrupt controller supported */
|
||||||
|
|
||||||
|
/* Register Number: 17-22 Reserved
|
||||||
|
* Compliance Level: Optional.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Register Number: 23 Sel: 0 Name: Debug
|
||||||
|
* Function: EJTAG Debug register
|
||||||
|
* Compliance Level: Optional.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define CP0_DEBUG_DSS (1 << 0) /* Bit 0: Debug single-step exception */
|
||||||
|
#define CP0_DEBUG_DBP (1 << 1) /* Bit 1: Debug software breakpoint exception */
|
||||||
|
#define CP0_DEBUG_DDBL (1 << 2) /* Bit 2: Debug data break exception on load */
|
||||||
|
#define CP0_DEBUG_DDBS (1 << 3) /* Bit 3: Debug data break exception on store */
|
||||||
|
#define CP0_DEBUG_DIB (1 << 4) /* Bit 4: Debug instruction break exception */
|
||||||
|
#define CP0_DEBUG_DINT (1 << 5) /* Bit 5: Debug interrupt exception */
|
||||||
|
#define CP0_DEBUG_SST (1 << 8) /* Bit 6: Enable debug single step exception */
|
||||||
|
#define CP0_DEBUG_NOSST (1 << 9) /* Bit 7: No single step feature available */
|
||||||
|
#define CP0_DEBUG_DEXCCODE_SHIFT (10) /* Bits 10-14: Cause of latest exception in DEBUG mode */
|
||||||
|
#define CP0_DEBUG_DEXCCODE_MASK (31 << CP0_DEBUG_DEXCCODE_SHIFT)
|
||||||
|
#define CP0_DEBUG_VER_SHIFT (15) /* Bits 15-17: EJTAG version */
|
||||||
|
#define CP0_DEBUG_VER_MASK (7 << CP0_DEBUG_VER_SHIFT)
|
||||||
|
#define CP0_DEBUG_DDBLIMPR (1 << 18) /* Bit 18: Imprecise debug data break load instruction */
|
||||||
|
#define CP0_DEBUG_DDBSIMPR (1 << 19) /* Bit 19: Imprecise debug data break store instruction */
|
||||||
|
#define CP0_DEBUG_IEXI (1 << 20) /* Bit 20: Imprecise error exception inhibit */
|
||||||
|
#define CP0_DEBUG_DBUSEP (1 << 21) /* Bit 21: Data access bus error exception pending */
|
||||||
|
#define CP0_DEBUG_CACHEEP (1 << 22) /* Bit 22: Imprecise cache error exception is pending */
|
||||||
|
#define CP0_DEBUG_MCHECKP (1 << 23) /* Bit 23: Imprecise machine check exception is pending */
|
||||||
|
#define CP0_DEBUG_IBUSEP (1 << 24) /* Bit 24: Bus error exception pending */
|
||||||
|
#define CP0_DEBUG_COUNTDM (1 << 25) /* Bit 25: Count register behavior (1=running) */
|
||||||
|
#define CP0_DEBUG_HALT (1 << 26) /* Bit 26: Internal system bus clock stopped */
|
||||||
|
#define CP0_DEBUG_DOZE (1 << 27) /* Bit 27: Processor in low power mode */
|
||||||
|
#define CP0_DEBUG_LSNM (1 << 28) /* Bit 28: Load/store in DSEG goes to main memory */
|
||||||
|
#define CP0_DEBUG_NODCR (1 << 29) /* Bit 29: No DSEG preset */
|
||||||
|
#define CP0_DEBUG_DM (1 << 30) /* Bit 30: Processor is operating in DEBUG mode */
|
||||||
|
#define CP0_DEBUG_DBD (1 << 31) /* Bit 31: Last debug exception occurred in a dely slot */
|
||||||
|
|
||||||
|
/* Register Number: 23 Sel: ? Name: Debug2
|
||||||
|
* Is this documented anywhere?
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Register Number: 24 Sel: 0 Name: DEPC
|
||||||
|
* Function: Program counter at last EJTAG debug exception
|
||||||
|
* Compliance Level: Optional.
|
||||||
|
*
|
||||||
|
* See arch/mips/include/mips32/cp0.h
|
||||||
|
*
|
||||||
|
* Register Number: 25-29 Reserved
|
||||||
|
* Compliance Level: Recommended/Optional.
|
||||||
|
*
|
||||||
|
* Register Number: 30 Sel: 0 Name: ErrorEPC
|
||||||
|
* Function: Program counter at last error
|
||||||
|
* Compliance Level: Required.
|
||||||
|
*
|
||||||
|
* See arch/mips/include/mips32/cp0.h
|
||||||
|
*
|
||||||
|
* Register Number: 31 Sel: 0 Name: DeSAVE
|
||||||
|
* Function: EJTAG debug exception save register
|
||||||
|
* Compliance Level: Optional.
|
||||||
|
*
|
||||||
|
* See arch/mips/include/mips32/cp0.h
|
||||||
|
*/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Types
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifndef __ASSEMBLY__
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Inline Functions
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Function Prototypes
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
#define EXTERN extern "C"
|
||||||
|
extern "C"
|
||||||
|
{
|
||||||
|
#else
|
||||||
|
#define EXTERN extern
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#undef EXTERN
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* __ASSEMBLY__ */
|
||||||
|
#endif /* __ARCH_MIPS_INCLUDE_PIC32MZ_CP0_H */
|
213
arch/mips/include/pic32mz/irq.h
Normal file
213
arch/mips/include/pic32mz/irq.h
Normal file
@ -0,0 +1,213 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
* arch/mips/include/pic32mz/irq.h
|
||||||
|
*
|
||||||
|
* Copyright (C) 2015 Gregory Nutt. All rights reserved.
|
||||||
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/* This file should never be included directed but, rather, only indirectly
|
||||||
|
* through nuttx/irq.h
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __ARCH_MIPS_INCLUDE_PIC32MZ_IRQ_H
|
||||||
|
#define __ARCH_MIPS_INCLUDE_PIC32MZ_IRQ_H
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Included Files
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#include <nuttx/config.h>
|
||||||
|
#include <arch/pic32mz/chip.h>
|
||||||
|
|
||||||
|
#if defined(CHIP_PIC32MZEC) || defined(CHIP_PIC32MZ2)
|
||||||
|
# include <arch/pic32mz/irq_pic32mzxxxec.h.h>
|
||||||
|
#else
|
||||||
|
# error "Unknown PIC32MZ family
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Pre-processor Definitions
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Types
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifndef __ASSEMBLY__
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Inline functions
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: cp0_getintctl
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Get the CP0 IntCtl register
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* None
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* None
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
static inline uint32_t cp0_getintctl(void)
|
||||||
|
{
|
||||||
|
register uint32_t intctl;
|
||||||
|
__asm__ __volatile__
|
||||||
|
(
|
||||||
|
"\t.set push\n"
|
||||||
|
"\t.set noat\n"
|
||||||
|
"\t mfc0 %0, $12, 1\n" /* Get CP0 IntCtl register */
|
||||||
|
"\t.set pop\n"
|
||||||
|
: "=r" (intctl)
|
||||||
|
:
|
||||||
|
: "memory"
|
||||||
|
);
|
||||||
|
|
||||||
|
return intctl;
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: cp0_putintctl
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Write the CP0 IntCtl register
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* None
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* None
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
static inline void cp0_putintctl(uint32_t intctl)
|
||||||
|
{
|
||||||
|
__asm__ __volatile__
|
||||||
|
(
|
||||||
|
"\t.set push\n"
|
||||||
|
"\t.set noat\n"
|
||||||
|
"\t.set noreorder\n"
|
||||||
|
"\tmtc0 %0, $12, 1\n" /* Set the IntCtl to the provided value */
|
||||||
|
"\t.set pop\n"
|
||||||
|
:
|
||||||
|
: "r" (intctl)
|
||||||
|
: "memory"
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: cp0_getebase
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Get the CP0 EBASE register
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* None
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* None
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
static inline uint32_t cp0_getebase(void)
|
||||||
|
{
|
||||||
|
register uint32_t ebase;
|
||||||
|
__asm__ __volatile__
|
||||||
|
(
|
||||||
|
"\t.set push\n"
|
||||||
|
"\t.set noat\n"
|
||||||
|
"\t mfc0 %0, $15, 1\n" /* Get CP0 EBASE register */
|
||||||
|
"\t.set pop\n"
|
||||||
|
: "=r" (ebase)
|
||||||
|
:
|
||||||
|
: "memory"
|
||||||
|
);
|
||||||
|
|
||||||
|
return ebase;
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: cp0_putebase
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Write the CP0 EBASE register
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* None
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* None
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
static inline void cp0_putebase(uint32_t ebase)
|
||||||
|
{
|
||||||
|
__asm__ __volatile__
|
||||||
|
(
|
||||||
|
"\t.set push\n"
|
||||||
|
"\t.set noat\n"
|
||||||
|
"\t.set noreorder\n"
|
||||||
|
"\tmtc0 %0, $15, 1\n" /* Set the EBASE to the provided value */
|
||||||
|
"\t.set pop\n"
|
||||||
|
:
|
||||||
|
: "r" (ebase)
|
||||||
|
: "memory"
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Variables
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Function Prototypes
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
#define EXTERN extern "C"
|
||||||
|
extern "C"
|
||||||
|
{
|
||||||
|
#else
|
||||||
|
#define EXTERN extern
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#undef EXTERN
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* __ASSEMBLY__ */
|
||||||
|
#endif /* __ARCH_MIPS_INCLUDE_PIC32MZ_IRQ_H */
|
||||||
|
|
283
arch/mips/include/pic32mz/irq_pic32mzxxxec.h
Normal file
283
arch/mips/include/pic32mz/irq_pic32mzxxxec.h
Normal file
@ -0,0 +1,283 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
* arch/mips/include/pic32mz/irq_pic32mzxxxec.h
|
||||||
|
*
|
||||||
|
* Copyright (C) 2015 Gregory Nutt. All rights reserved.
|
||||||
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/* This file should never be included directed but, rather, only indirectly
|
||||||
|
* through nuttx/irq.h
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __ARCH_MIPS_INCLUDE_PIC32MZ_IRQ_PIC32MZXXXEC_H
|
||||||
|
#define __ARCH_MIPS_INCLUDE_PIC32MZ_IRQ_PIC32MZXXXEC_H
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Included Files
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Pre-processor Definitions
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/* Interrupt vector numbers. These should be used to attach to interrupts
|
||||||
|
* and to change interrupt priorities.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define PIC32MZ_IRQ_CT 0 /* Vector: 0, Core Timer Interrupt */
|
||||||
|
#define PIC32MZ_IRQ_CS0 1 /* Vector: 1, Core Software Interrupt 0 */
|
||||||
|
#define PIC32MZ_IRQ_CS1 2 /* Vector: 2, Core Software Interrupt 1 */
|
||||||
|
#define PIC32MZ_IRQ_INT0 3 /* Vector: 3, External Interrupt 0 */
|
||||||
|
#define PIC32MZ_IRQ_T1 4 /* Vector: 4, Timer 1 */
|
||||||
|
#define PIC32MZ_IRQ_ICE1 5 /* Vector: 5, Input Capture 1 Error */
|
||||||
|
#define PIC32MZ_IRQ_IC1 6 /* Vector: 6, Input Capture 1 */
|
||||||
|
#define PIC32MZ_IRQ_OC1 7 /* Vector: 7, Output Compare 1 */
|
||||||
|
#define PIC32MZ_IRQ_INT1 8 /* Vector: 8, External Interrupt 1 */
|
||||||
|
#define PIC32MZ_IRQ_T2 9 /* Vector: 9, Timer 2 */
|
||||||
|
#define PIC32MZ_IRQ_ICE2 10 /* Vector: 10, Input Capture 2 Error */
|
||||||
|
#define PIC32MZ_IRQ_IC2 11 /* Vector: 11, Input Capture 2 */
|
||||||
|
#define PIC32MZ_IRQ_OC2 12 /* Vector: 12, Output Compare 2 */
|
||||||
|
#define PIC32MZ_IRQ_INT2 13 /* Vector: 13, External Interrupt 2 */
|
||||||
|
#define PIC32MZ_IRQ_T3 14 /* Vector: 14, Timer 3 */
|
||||||
|
#define PIC32MZ_IRQ_ICE3 15 /* Vector: 15, Input Capture 3 Error */
|
||||||
|
#define PIC32MZ_IRQ_IC3 16 /* Vector: 16, Input Capture 3 */
|
||||||
|
#define PIC32MZ_IRQ_OC3 17 /* Vector: 17, Output Compare 3 */
|
||||||
|
#define PIC32MZ_IRQ_INT3 18 /* Vector: 18, External Interrupt 3 */
|
||||||
|
#define PIC32MZ_IRQ_T4 19 /* Vector: 19, Timer 4 */
|
||||||
|
#define PIC32MZ_IRQ_ICE4 20 /* Vector: 20, Input Capture 4 Error */
|
||||||
|
#define PIC32MZ_IRQ_IC4 21 /* Vector: 21, Input Capture 4 */
|
||||||
|
#define PIC32MZ_IRQ_OC4 22 /* Vector: 22, Output Compare 4 */
|
||||||
|
#define PIC32MZ_IRQ_INT4 23 /* Vector: 23, External Interrupt 4 */
|
||||||
|
#define PIC32MZ_IRQ_T5 24 /* Vector: 24, Timer 5 */
|
||||||
|
#define PIC32MZ_IRQ_ICE5 25 /* Vector: 25, Input Capture 5 Error */
|
||||||
|
#define PIC32MZ_IRQ_IC5 26 /* Vector: 26, Input Capture 5 */
|
||||||
|
#define PIC32MZ_IRQ_OC5 27 /* Vector: 27, Output Compare 5 */
|
||||||
|
#define PIC32MZ_IRQ_T6 28 /* Vector: 28, Timer 6 */
|
||||||
|
#define PIC32MZ_IRQ_ICE6 29 /* Vector: 29, Input Capture 6 Error */
|
||||||
|
#define PIC32MZ_IRQ_IC6 30 /* Vector: 30, Input Capture 6 */
|
||||||
|
#define PIC32MZ_IRQ_OC6 31 /* Vector: 31, Output Compare 6 */
|
||||||
|
#define PIC32MZ_IRQ_T7 32 /* Vector: 32, Timer 7 */
|
||||||
|
#define PIC32MZ_IRQ_ICE7 33 /* Vector: 33, Input Capture 7 Error */
|
||||||
|
#define PIC32MZ_IRQ_IC7 34 /* Vector: 34, Input Capture 7 */
|
||||||
|
#define PIC32MZ_IRQ_OC7 35 /* Vector: 35, Output Compare 7 */
|
||||||
|
#define PIC32MZ_IRQ_T8 36 /* Vector: 36, Timer 8 */
|
||||||
|
#define PIC32MZ_IRQ_ICE8 37 /* Vector: 37, Input Capture 8 Error */
|
||||||
|
#define PIC32MZ_IRQ_IC8 38 /* Vector: 38, Input Capture 8 */
|
||||||
|
#define PIC32MZ_IRQ_OC8 39 /* Vector: 39, Output Compare 8 */
|
||||||
|
#define PIC32MZ_IRQ_T9 40 /* Vector: 40, Timer 9 */
|
||||||
|
#define PIC32MZ_IRQ_ICE9 41 /* Vector: 41, Input Capture 9 Error */
|
||||||
|
#define PIC32MZ_IRQ_IC9 42 /* Vector: 42, Input Capture 9 */
|
||||||
|
#define PIC32MZ_IRQ_OC9 43 /* Vector: 43, Output Compare 9 */
|
||||||
|
#define PIC32MZ_IRQ_AD1 44 /* Vector: 44, ADC1 Global Interrupt */
|
||||||
|
/* Vector: 45, Reserved */
|
||||||
|
#define PIC32MZ_IRQ_AD1CMP1 46 /* Vector: 46, ADC1 Digital Comparator 1 */
|
||||||
|
#define PIC32MZ_IRQ_AD1CMP2 47 /* Vector: 47, ADC1 Digital Comparator 2 */
|
||||||
|
#define PIC32MZ_IRQ_AD1CMP3 48 /* Vector: 48, ADC1 Digital Comparator 3 */
|
||||||
|
#define PIC32MZ_IRQ_AD1CMP4 49 /* Vector: 49, ADC1 Digital Comparator 4 */
|
||||||
|
#define PIC32MZ_IRQ_AD1CMP5 50 /* Vector: 50, ADC1 Digital Comparator 5 */
|
||||||
|
#define PIC32MZ_IRQ_AD1CMP6 51 /* Vector: 51, ADC1 Digital Comparator 6 */
|
||||||
|
#define PIC32MZ_IRQ_AD1FLT1 52 /* Vector: 52, ADC1 Digital Filter 1 */
|
||||||
|
#define PIC32MZ_IRQ_AD1FLT2 53 /* Vector: 53, ADC1 Digital Filter 2 */
|
||||||
|
#define PIC32MZ_IRQ_AD1FLT3 54 /* Vector: 54, ADC1 Digital Filter 3 */
|
||||||
|
#define PIC32MZ_IRQ_AD1FLT4 55 /* Vector: 55, ADC1 Digital Filter 4 */
|
||||||
|
#define PIC32MZ_IRQ_AD1FLT5 56 /* Vector: 56, ADC1 Digital Filter 5 */
|
||||||
|
#define PIC32MZ_IRQ_AD1FLT6 57 /* Vector: 57, ADC1 Digital Filter 6 */
|
||||||
|
/* Vector: 58, Reserved */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT0 59 /* Vector: 59, ADC1 Data 0 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT1 60 /* Vector: 60, ADC1 Data 1 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT2 61 /* Vector: 61, ADC1 Data 2 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT3 62 /* Vector: 62, ADC1 Data 3 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT4 63 /* Vector: 63, ADC1 Data 4 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT5 64 /* Vector: 64, ADC1 Data 5 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT6 65 /* Vector: 65, ADC1 Data 6 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT7 66 /* Vector: 66, ADC1 Data 7 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT8 67 /* Vector: 67, ADC1 Data 8 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT9 68 /* Vector: 68, ADC1 Data 9 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT10 69 /* Vector: 69, ADC1 Data 10 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT11 70 /* Vector: 70, ADC1 Data 11 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT12 71 /* Vector: 71, ADC1 Data 12 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT13 72 /* Vector: 72, ADC1 Data 13 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT14 73 /* Vector: 73, ADC1 Data 14 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT15 74 /* Vector: 74, ADC1 Data 15 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT16 75 /* Vector: 75, ADC1 Data 16 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT17 76 /* Vector: 76, ADC1 Data 17 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT18 77 /* Vector: 77, ADC1 Data 18 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT19 78 /* Vector: 78, ADC1 Data 19 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT20 79 /* Vector: 79, ADC1 Data 20 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT21 80 /* Vector: 80, ADC1 Data 21 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT22 81 /* Vector: 81, ADC1 Data 22 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT23 82 /* Vector: 82, ADC1 Data 23 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT24 83 /* Vector: 83, ADC1 Data 24 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT25 84 /* Vector: 84, ADC1 Data 25 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT26 85 /* Vector: 85, ADC1 Data 26 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT27 86 /* Vector: 86, ADC1 Data 27 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT28 87 /* Vector: 87, ADC1 Data 28 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT29 88 /* Vector: 88, ADC1 Data 29 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT30 89 /* Vector: 89, ADC1 Data 30 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT31 90 /* Vector: 90, ADC1 Data 31 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT32 91 /* Vector: 91, ADC1 Data 32 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT33 92 /* Vector: 92, ADC1 Data 33 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT34 93 /* Vector: 93, ADC1 Data 34 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT35 94 /* Vector: 94, ADC1 Data 35 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT36 95 /* Vector: 95, ADC1 Data 36 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT37 96 /* Vector: 96, ADC1 Data 37 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT38 97 /* Vector: 97, ADC1 Data 38 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT39 98 /* Vector: 98, ADC1 Data 39 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT40 99 /* Vector: 99, ADC1 Data 40 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT41 100 /* Vector: 100, ADC1 Data 41 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT42 101 /* Vector: 101, ADC1 Data 42 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT43 102 /* Vector: 102, ADC1 Data 43 */
|
||||||
|
#define PIC32MZ_IRQ_AD1DAT44 103 /* Vector: 103, ADC1 Data 44 */
|
||||||
|
#define PIC32MZ_IRQ_COREPERF 104 /* Vector: 104, Core Performance Counter Interrupt */
|
||||||
|
#define PIC32MZ_IRQ_COREFDBG 105 /* Vector: 105, Core Fast Debug Channel Interrupt */
|
||||||
|
#define PIC32MZ_IRQ_BUSPROT 106 /* Vector: 106, System Bus Protection Violation */
|
||||||
|
#define PIC32MZ_IRQ_CTYPTO 107 /* Vector: 107, Crypto Engine Event */
|
||||||
|
/* Vector: 108, Reserved */
|
||||||
|
#define PIC32MZ_IRQ_SPI1F 109 /* Vector: 109, SPI1 Fault */
|
||||||
|
#define PIC32MZ_IRQ_SPI1RX 110 /* Vector: 110, SPI1 Receive Done */
|
||||||
|
#define PIC32MZ_IRQ_SPI1TX 111 /* Vector: 111, SPI1 Transfer Done */
|
||||||
|
#define PIC32MZ_IRQ_UART1F 112 /* Vector: 112, UART1 Fault */
|
||||||
|
#define PIC32MZ_IRQ_UART1RX 113 /* Vector: 113, UART1 Receive Done */
|
||||||
|
#define PIC32MZ_IRQ_UART1TX 114 /* Vector: 114, UART1 Transfer Done */
|
||||||
|
#define PIC32MZ_IRQ_I2C1COL 115 /* Vector: 115, I2C1 Bus Collision Event */
|
||||||
|
#define PIC32MZ_IRQ_I2C1S 116 /* Vector: 116, I2C1 Slave Event */
|
||||||
|
#define PIC32MZ_IRQ_I2C1M 117 /* Vector: 117, I2C1 Master Event */
|
||||||
|
#define PIC32MZ_IRQ_PORTA 118 /* Vector: 118, PORTA Input Change Interrupt */
|
||||||
|
#define PIC32MZ_IRQ_PORTB 119 /* Vector: 119, PORTB Input Change Interrupt */
|
||||||
|
#define PIC32MZ_IRQ_PORTC 120 /* Vector: 120, PORTC Input Change Interrupt */
|
||||||
|
#define PIC32MZ_IRQ_PORTD 121 /* Vector: 121, PORTD Input Change Interrupt */
|
||||||
|
#define PIC32MZ_IRQ_PORTE 122 /* Vector: 122, PORTE Input Change Interrupt */
|
||||||
|
#define PIC32MZ_IRQ_PORTF 123 /* Vector: 123, PORTF Input Change Interrupt */
|
||||||
|
#define PIC32MZ_IRQ_PORTG 124 /* Vector: 124, PORTG Input Change Interrupt */
|
||||||
|
#define PIC32MZ_IRQ_PORTH 125 /* Vector: 125, PORTH Input Change Interrupt */
|
||||||
|
#define PIC32MZ_IRQ_PORTJ 126 /* Vector: 126, PORTJ Input Change Interrupt */
|
||||||
|
#define PIC32MZ_IRQ_PORTK 127 /* Vector: 127, PORTK Input Change Interrupt */
|
||||||
|
#define PIC32MZ_IRQ_PMP 128 /* Vector: 128, Parallel Master Port */
|
||||||
|
#define PIC32MZ_IRQ_PMPE 129 /* Vector: 129, Parallel Master Port Error */
|
||||||
|
#define PIC32MZ_IRQ_CMP1 130 /* Vector: 130, Comparator 1 Interrupt */
|
||||||
|
#define PIC32MZ_IRQ_CMP2 131 /* Vector: 131, Comparator 2 Interrupt */
|
||||||
|
#define PIC32MZ_IRQ_USBGEN 132 /* Vector: 132, USB General Event */
|
||||||
|
#define PIC32MZ_IRQ_USBDMA 133 /* Vector: 133, USB DMA Event */
|
||||||
|
#define PIC32MZ_IRQ_DMA0 134 /* Vector: 134, DMA Channel 0 */
|
||||||
|
#define PIC32MZ_IRQ_DMA1 135 /* Vector: 135, DMA Channel 1 */
|
||||||
|
#define PIC32MZ_IRQ_DMA2 136 /* Vector: 136, DMA Channel 2 */
|
||||||
|
#define PIC32MZ_IRQ_DMA3 137 /* Vector: 137, DMA Channel 3 */
|
||||||
|
#define PIC32MZ_IRQ_DMA4 138 /* Vector: 138, DMA Channel 4 */
|
||||||
|
#define PIC32MZ_IRQ_DMA5 139 /* Vector: 139, DMA Channel 5 */
|
||||||
|
#define PIC32MZ_IRQ_DMA6 140 /* Vector: 140, DMA Channel 6 */
|
||||||
|
#define PIC32MZ_IRQ_DMA7 141 /* Vector: 141, DMA Channel 7 */
|
||||||
|
#define PIC32MZ_IRQ_SPI2F 142 /* Vector: 142, SPI2 Fault */
|
||||||
|
#define PIC32MZ_IRQ_SPI2RX 143 /* Vector: 143, SPI2 Receive Done */
|
||||||
|
#define PIC32MZ_IRQ_SPI2TX 144 /* Vector: 144, SPI2 Transfer Done */
|
||||||
|
#define PIC32MZ_IRQ_UART2F 145 /* Vector: 145, UART2 Fault */
|
||||||
|
#define PIC32MZ_IRQ_UART2RX 146 /* Vector: 146, UART2 Receive Done */
|
||||||
|
#define PIC32MZ_IRQ_UART2TX 147 /* Vector: 147, UART2 Transfer Done */
|
||||||
|
#define PIC32MZ_IRQ_I2C2COL 148 /* Vector: 148, I2C2 Bus Collision Event */
|
||||||
|
#define PIC32MZ_IRQ_I2C2S 149 /* Vector: 149, I2C2 Slave Event */
|
||||||
|
#define PIC32MZ_IRQ_I2C2M 150 /* Vector: 150, I2C2 Master Event */
|
||||||
|
#define PIC32MZ_IRQ_CAN1 151 /* Vector: 151, Control Area Network 1 */
|
||||||
|
#define PIC32MZ_IRQ_CAN2 152 /* Vector: 152, Control Area Network 2 */
|
||||||
|
#define PIC32MZ_IRQ_ETH 153 /* Vector: 153, Ethernet interrupt */
|
||||||
|
#define PIC32MZ_IRQ_SPI3F 154 /* Vector: 154, SPI3 Fault */
|
||||||
|
#define PIC32MZ_IRQ_SPI3RX 155 /* Vector: 155, SPI3 Receive Done */
|
||||||
|
#define PIC32MZ_IRQ_SPI3TX 156 /* Vector: 156, SPI3 Transfer Done */
|
||||||
|
#define PIC32MZ_IRQ_UART3F 157 /* Vector: 157, UART3 Fault */
|
||||||
|
#define PIC32MZ_IRQ_UART3RX 158 /* Vector: 158, UART3 Receive Done */
|
||||||
|
#define PIC32MZ_IRQ_UART3TX 159 /* Vector: 159, UART3 Transfer Done */
|
||||||
|
#define PIC32MZ_IRQ_I2C3COL 160 /* Vector: 160, I2C3 Bus Collision Event */
|
||||||
|
#define PIC32MZ_IRQ_I2C3S 161 /* Vector: 161, I2C3 Slave Event */
|
||||||
|
#define PIC32MZ_IRQ_I2C3M 162 /* Vector: 162, I2C3 Master Event */
|
||||||
|
#define PIC32MZ_IRQ_SPI4F 163 /* Vector: 163, SPI4 Fault */
|
||||||
|
#define PIC32MZ_IRQ_SPI4RX 164 /* Vector: 164, SPI4 Receive Done */
|
||||||
|
#define PIC32MZ_IRQ_SPI4TX 165 /* Vector: 165, SPI4 Transfer Done */
|
||||||
|
#define PIC32MZ_IRQ_RTCC 166 /* Vector: 166, Real-Time Clock and Calendar */
|
||||||
|
#define PIC32MZ_IRQ_FCE 167 /* Vector: 167, Flash Control Event */
|
||||||
|
#define PIC32MZ_IRQ_PMSEC 168 /* Vector: 168, Prefetch Module SEC Event */
|
||||||
|
#define PIC32MZ_IRQ_SQI1 169 /* Vector: 169, SQI1 Event */
|
||||||
|
#define PIC32MZ_IRQ_UART4F 170 /* Vector: 170, UART4 Fault */
|
||||||
|
#define PIC32MZ_IRQ_UART4RX 171 /* Vector: 171, UART4 Receive Done */
|
||||||
|
#define PIC32MZ_IRQ_UART4TX 172 /* Vector: 172, UART4 Transfer Done */
|
||||||
|
#define PIC32MZ_IRQ_I2C4COL 173 /* Vector: 173, I2C4 Bus Collision Event */
|
||||||
|
#define PIC32MZ_IRQ_I2C4S 174 /* Vector: 174, I2C4 Slave Event */
|
||||||
|
#define PIC32MZ_IRQ_I2C4M 175 /* Vector: 175, I2C4 Master Event */
|
||||||
|
#define PIC32MZ_IRQ_SPI5F 176 /* Vector: 176, SPI5 Fault */
|
||||||
|
#define PIC32MZ_IRQ_SPI5RX 177 /* Vector: 177, SPI5 Receive Done */
|
||||||
|
#define PIC32MZ_IRQ_SPI5TX 178 /* Vector: 178, SPI5 Transfer Done */
|
||||||
|
#define PIC32MZ_IRQ_UART5F 179 /* Vector: 179, UART5 Fault */
|
||||||
|
#define PIC32MZ_IRQ_UART5RX 180 /* Vector: 180, UART5 Receive Done */
|
||||||
|
#define PIC32MZ_IRQ_UART5TX 181 /* Vector: 181, UART5 Transfer Done */
|
||||||
|
#define PIC32MZ_IRQ_I2C5COL 182 /* Vector: 182, I2C5 Bus Collision Event */
|
||||||
|
#define PIC32MZ_IRQ_I2C5S 183 /* Vector: 183, I2C5 Slave Event */
|
||||||
|
#define PIC32MZ_IRQ_I2C5M 184 /* Vector: 184, I2C5 Master Event */
|
||||||
|
#define PIC32MZ_IRQ_SPI6F 185 /* Vector: 185, SPI6 Fault */
|
||||||
|
#define PIC32MZ_IRQ_SPI6RX 186 /* Vector: 186, SPI6 Receive Done */
|
||||||
|
#define PIC32MZ_IRQ_SPI6TX 187 /* Vector: 187, SPI6 Transfer Done */
|
||||||
|
#define PIC32MZ_IRQ_UART6F 188 /* Vector: 188, UART6 Fault */
|
||||||
|
#define PIC32MZ_IRQ_UART6RX 189 /* Vector: 189, UART6 Receive Done */
|
||||||
|
#define PIC32MZ_IRQ_UART6TX 190 /* Vector: 190, UART6 Transfer Done */
|
||||||
|
|
||||||
|
#define PIC32MZ_IRQ_BAD 191 /* Not a real IRQ number */
|
||||||
|
#define NR_IRQS 191
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Types
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifndef __ASSEMBLY__
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Inline functions
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Variables
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Function Prototypes
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
#define EXTERN extern "C"
|
||||||
|
extern "C"
|
||||||
|
{
|
||||||
|
#else
|
||||||
|
#define EXTERN extern
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#undef EXTERN
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* __ASSEMBLY__ */
|
||||||
|
#endif /* __ARCH_MIPS_INCLUDE_PIC32MZ_IRQ_PIC32MZXXXEC_H */
|
||||||
|
|
740
arch/mips/src/pic32mz/Kconfig
Normal file
740
arch/mips/src/pic32mz/Kconfig
Normal file
@ -0,0 +1,740 @@
|
|||||||
|
#
|
||||||
|
# For a description of the syntax of this configuration file,
|
||||||
|
# see misc/tools/kconfig-language.txt.
|
||||||
|
#
|
||||||
|
|
||||||
|
if ARCH_CHIP_PIC32MZ
|
||||||
|
comment "PIC32MZ Configuration Options"
|
||||||
|
|
||||||
|
choice
|
||||||
|
prompt "PIC32MZ chip selection"
|
||||||
|
default ARCH_CHIP_PIC32MZ460F512L
|
||||||
|
|
||||||
|
config ARCH_CHIP_PIC32MZ2048ECH
|
||||||
|
bool "PIC32MZ2048ECH"
|
||||||
|
select ARCH_CHIP_PIC32MZEC
|
||||||
|
---help---
|
||||||
|
Microchip PIC32MZ2048ECH (MIPS32)
|
||||||
|
ARCH_CHIP_PIC32MZ1
|
||||||
|
|
||||||
|
config ARCH_CHIP_PIC32MZ2048ECM
|
||||||
|
bool "PIC32MZ2048ECH"
|
||||||
|
select ARCH_CHIP_PIC32MZEC
|
||||||
|
---help---
|
||||||
|
Microchip PIC32MZ2048ECH (MIPS32)
|
||||||
|
|
||||||
|
endchoice
|
||||||
|
|
||||||
|
config ARCH_CHIP_PIC32MZEC
|
||||||
|
bool
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_MVEC
|
||||||
|
bool
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_T1
|
||||||
|
bool
|
||||||
|
default y
|
||||||
|
|
||||||
|
menu "PIC32MZ Peripheral Support"
|
||||||
|
|
||||||
|
config PIC32MZ_WDT
|
||||||
|
bool "Watchdog timer (WDT)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_T2
|
||||||
|
bool "Timer 2 (T2)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_T3
|
||||||
|
bool "Timer 3 (T3)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_T4
|
||||||
|
bool "Timer 4 (T4)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_T5
|
||||||
|
bool "Timer 5 (T5)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_IC1
|
||||||
|
bool "Input Capture 1 (IC1)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_IC2
|
||||||
|
bool "Input Capture 2 (IC2)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_IC3
|
||||||
|
bool "Input Capture 3 (IC3)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_IC4
|
||||||
|
bool "Input Capture 4 (IC4)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_IC5
|
||||||
|
bool "Input Capture 5 (IC5)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_OC1
|
||||||
|
bool "Output Compare 1 (OC1)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_OC2
|
||||||
|
bool "Output Compare 2 (OC2)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_OC3
|
||||||
|
bool "Output Compare 3 (OC3)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_OC4
|
||||||
|
bool "Output Compare 4 (OC4)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_OC5
|
||||||
|
bool "Output Compare 5 (OC5)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_I2C1
|
||||||
|
bool "I2C1"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_I2C2
|
||||||
|
bool "I2C2"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_I2C3
|
||||||
|
bool "I2C3"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_I2C4
|
||||||
|
bool "I2C4"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_I2C5
|
||||||
|
bool "I2C5"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_SPI1
|
||||||
|
bool "SPI1"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_SPI2
|
||||||
|
bool "SPI2"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_SPI3
|
||||||
|
bool "SPI3"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_SPI4
|
||||||
|
bool "SPI4"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_UART1
|
||||||
|
bool "UART1"
|
||||||
|
default n
|
||||||
|
select ARCH_HAVE_UART1
|
||||||
|
select ARCH_HAVE_SERIAL_TERMIOS
|
||||||
|
|
||||||
|
config PIC32MZ_UART2
|
||||||
|
bool "UART2"
|
||||||
|
default n
|
||||||
|
select ARCH_HAVE_UART2
|
||||||
|
select ARCH_HAVE_SERIAL_TERMIOS
|
||||||
|
|
||||||
|
config PIC32MZ_UART3
|
||||||
|
bool "UART3"
|
||||||
|
default n
|
||||||
|
select ARCH_HAVE_UART3
|
||||||
|
select ARCH_HAVE_SERIAL_TERMIOS
|
||||||
|
|
||||||
|
config PIC32MZ_UART4
|
||||||
|
bool "UART4"
|
||||||
|
default n
|
||||||
|
select ARCH_HAVE_UART4
|
||||||
|
select ARCH_HAVE_SERIAL_TERMIOS
|
||||||
|
|
||||||
|
config PIC32MZ_UART5
|
||||||
|
bool "UART5"
|
||||||
|
default n
|
||||||
|
select ARCH_HAVE_UART5
|
||||||
|
select ARCH_HAVE_SERIAL_TERMIOS
|
||||||
|
|
||||||
|
config PIC32MZ_UART6
|
||||||
|
bool "UART6"
|
||||||
|
default n
|
||||||
|
select ARCH_HAVE_UART6
|
||||||
|
select ARCH_HAVE_SERIAL_TERMIOS
|
||||||
|
|
||||||
|
config PIC32MZ_ADC
|
||||||
|
bool "ADC1"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_PMP
|
||||||
|
bool "Parallel Master Port (PMP)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_CM1
|
||||||
|
bool "Comparator 1 (CM1)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_CM2
|
||||||
|
bool "Comparator 2 (CM2)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_CM3
|
||||||
|
bool "Comparator 3 (CM3)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_RTCC
|
||||||
|
bool "Real-Time Clock and Calendar (RTCC)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_DMA
|
||||||
|
bool "DMA"
|
||||||
|
default n
|
||||||
|
select ARCH_DMA
|
||||||
|
|
||||||
|
config PIC32MZ_FLASH
|
||||||
|
bool "FLASH"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_USBDEV
|
||||||
|
bool "USB device"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_USBHOST
|
||||||
|
bool "USB host"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_CAN1
|
||||||
|
bool "Controller area network 1 (CAN1)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_CAN2
|
||||||
|
bool "Controller area network 2 (CAN2)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
config PIC32MZ_ETHERNET
|
||||||
|
bool "Ethernet"
|
||||||
|
default n
|
||||||
|
select NETDEVICES
|
||||||
|
select ARCH_HAVE_PHY
|
||||||
|
|
||||||
|
config PIC32MZ_CTMU
|
||||||
|
bool "Charge Time Measurement Unit (CMTU)"
|
||||||
|
default n
|
||||||
|
|
||||||
|
endmenu
|
||||||
|
|
||||||
|
menu "PIC32MZ Peripheral Interrupt Priorities"
|
||||||
|
|
||||||
|
config PIC32MZ_CTPRIO
|
||||||
|
int "Core Timer Interrupt (CT)"
|
||||||
|
default 16
|
||||||
|
---help---
|
||||||
|
Core Timer Interrupt. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_CS0PRIO
|
||||||
|
int "Core Software Interrupt 0 (CS0)"
|
||||||
|
default 16
|
||||||
|
---help---
|
||||||
|
Core Software Interrupt 0. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_CS1PRIO
|
||||||
|
int "Core Software Interrupt 1 (CS1)"
|
||||||
|
default 16
|
||||||
|
---help---
|
||||||
|
Core Software Interrupt 1. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_INT0PRIO
|
||||||
|
int "External Interrupt 0 (INT0)"
|
||||||
|
default 16
|
||||||
|
---help---
|
||||||
|
External Interrupt 0. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_INT1PRIO
|
||||||
|
int "External Interrupt 1 (INT1)"
|
||||||
|
default 16
|
||||||
|
---help---
|
||||||
|
External Interrupt 1. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_INT2PRIO
|
||||||
|
int "External Interrupt 2 (INT2)"
|
||||||
|
default 16
|
||||||
|
---help---
|
||||||
|
External Interrupt 2. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_INT3PRIO
|
||||||
|
int "External Interrupt 3 (INT3)"
|
||||||
|
default 16
|
||||||
|
---help---
|
||||||
|
External Interrupt 3. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_INT4PRIO
|
||||||
|
int "External Interrupt 4 (INT4)"
|
||||||
|
default 16
|
||||||
|
---help---
|
||||||
|
External Interrupt 4. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_FSCMPRIO
|
||||||
|
int "Fail-Safe Clock Monitor (FSCM)"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_
|
||||||
|
---help---
|
||||||
|
Fail-Safe Clock Monitor. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_T1PRIO
|
||||||
|
int "Timer 1 (T1)"
|
||||||
|
default 16
|
||||||
|
---help---
|
||||||
|
Timer 1 (System timer) priority. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_T2PRIO
|
||||||
|
int "Timer 2 (T2)"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_T2
|
||||||
|
---help---
|
||||||
|
Timer 2 priority. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_T3PRIO
|
||||||
|
int "Timer 3 (T3)"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_T3
|
||||||
|
---help---
|
||||||
|
Timer 3 priority. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_T4PRIO
|
||||||
|
int "Timer 4 (T4)"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_T4
|
||||||
|
---help---
|
||||||
|
Timer 4 priority. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_T5PRIO
|
||||||
|
int "Timer 5 (T5)"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_
|
||||||
|
---help---
|
||||||
|
Timer 5 priority. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_IC1PRIO
|
||||||
|
int "Input Capture 1 (IC1)"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_IC1
|
||||||
|
---help---
|
||||||
|
Input Capture 1. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_IC2PRIO
|
||||||
|
int "Input Capture 2 (IC2)"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_IC2
|
||||||
|
---help---
|
||||||
|
Input Capture 2. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_IC3PRIO
|
||||||
|
int "Input Capture 3 (IC3)"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_IC3
|
||||||
|
---help---
|
||||||
|
Input Capture 3. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_IC4PRIO
|
||||||
|
int "Input Capture 4 (IC4)"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_IC4
|
||||||
|
---help---
|
||||||
|
Input Capture 4. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_IC5PRIO
|
||||||
|
int "Input Capture 5 (IC5)"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_IC5
|
||||||
|
---help---
|
||||||
|
Input Capture 5. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_OC1PRIO
|
||||||
|
int "Output Compare 1 (OC1)"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_OC1
|
||||||
|
---help---
|
||||||
|
Output Compare 1. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_OC2PRIO
|
||||||
|
int "Output Compare 2 (OC2)"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_OC2
|
||||||
|
---help---
|
||||||
|
Output Compare 2. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_OC3PRIO
|
||||||
|
int "Output Compare 3 (OC3)"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_OC3
|
||||||
|
---help---
|
||||||
|
Output Compare 3. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_OC4PRIO
|
||||||
|
int "Output Compare 4 (OC4)"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_OC4
|
||||||
|
---help---
|
||||||
|
Output Compare 4. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_OC5PRIO
|
||||||
|
int "Output Compare 5 (OC5)"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_OC5
|
||||||
|
---help---
|
||||||
|
Output Compare 5. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_I2C1PRIO
|
||||||
|
int "I2C1"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_I2C1
|
||||||
|
---help---
|
||||||
|
I2C 1. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_I2C2PRIO
|
||||||
|
int "I2C2"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_I2C3
|
||||||
|
---help---
|
||||||
|
I2C 2. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_I2C3PRIO
|
||||||
|
int "I2C3"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_I2C3
|
||||||
|
---help---
|
||||||
|
I2C 3. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_I2C4PRIO
|
||||||
|
int "I2C4"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_I2C4
|
||||||
|
---help---
|
||||||
|
I2C 4. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_I2C5PRIO
|
||||||
|
int "I2C5"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_I2C5
|
||||||
|
---help---
|
||||||
|
I2C 5. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_SPI1PRIO
|
||||||
|
int "SPI1"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_SPI1
|
||||||
|
---help---
|
||||||
|
SPI 2
|
||||||
|
|
||||||
|
config PIC32MZ_SPI2PRIO
|
||||||
|
int "SPI2"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_SPI2
|
||||||
|
---help---
|
||||||
|
SPI 2
|
||||||
|
|
||||||
|
config PIC32MZ_UART1PRIO
|
||||||
|
int "UART1"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_UART1
|
||||||
|
---help---
|
||||||
|
UART 1. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_UART2PRIO
|
||||||
|
int "UART2"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_UART2
|
||||||
|
---help---
|
||||||
|
UART 2. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_CNPRIO
|
||||||
|
int "CN"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_CN
|
||||||
|
---help---
|
||||||
|
Input Change Interrupt. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_ADCPRIO
|
||||||
|
int "ADC1"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_ADC1
|
||||||
|
---help---
|
||||||
|
ADC1 Convert Done. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_PMPPRIO
|
||||||
|
int "Parallel Master Port (PMP)"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_PMP
|
||||||
|
---help---
|
||||||
|
Parallel Master Port. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_CM1PRIO
|
||||||
|
int "Comparator 1 (CM1)"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_CM1
|
||||||
|
---help---
|
||||||
|
Comparator 1. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_CM2PRIO
|
||||||
|
int "Comparator 2 (CM2)"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_CM2
|
||||||
|
---help---
|
||||||
|
Comparator 2. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_RTCCPRIO
|
||||||
|
int "Real-Time Clock and Calendar (RTCC)"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_RTCC
|
||||||
|
---help---
|
||||||
|
Real-Time Clock and Calendar. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_DMA0PRIO
|
||||||
|
int "DMA0"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_DMA
|
||||||
|
---help---
|
||||||
|
DMA Channel 0. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_DMA1PRIO
|
||||||
|
int "DMA1"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_DMA
|
||||||
|
---help---
|
||||||
|
DMA Channel 1. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_DMA2PRIO
|
||||||
|
int "DMA2"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_DMA
|
||||||
|
---help---
|
||||||
|
DMA Channel 2. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_DMA3PRIO
|
||||||
|
int "DMA3"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_DMA
|
||||||
|
---help---
|
||||||
|
DMA Channel 3. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_DMA4PRIO
|
||||||
|
int "DMA4"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_DMA
|
||||||
|
---help---
|
||||||
|
DMA Channel 4. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_DMA5PRIO
|
||||||
|
int "DMA5"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_DMA
|
||||||
|
---help---
|
||||||
|
DMA Channel 5. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_DMA6PRIO
|
||||||
|
int "DMA6"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_DMA
|
||||||
|
---help---
|
||||||
|
DMA Channel 6. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_DMA7PRIO
|
||||||
|
int "DMA7"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_DMA
|
||||||
|
---help---
|
||||||
|
DMA Channel 7. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_FCEPRIO
|
||||||
|
int "FCE"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_FLASH
|
||||||
|
---help---
|
||||||
|
Flash Control Event. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
config PIC32MZ_USBPRIO
|
||||||
|
int "USB"
|
||||||
|
default 16
|
||||||
|
depends on PIC32MZ_USBDEV || PIC32MZ_USBHOST
|
||||||
|
---help---
|
||||||
|
USB. Range 4-31, Default 16.
|
||||||
|
|
||||||
|
endmenu
|
||||||
|
|
||||||
|
menu "PIC32MZ PHY/Ethernet device driver settings"
|
||||||
|
depends on PIC32MZ_ETHERNET
|
||||||
|
|
||||||
|
config PHY_AUTONEG
|
||||||
|
bool "Auto-negotion"
|
||||||
|
default y
|
||||||
|
depends on PIC32MZ_ETHERNET
|
||||||
|
---help---
|
||||||
|
Enable auto-negotion
|
||||||
|
|
||||||
|
config PHY_SPEED100
|
||||||
|
bool "100Mbps spped"
|
||||||
|
default n
|
||||||
|
depends on PIC32MZ_ETHERNET && !PHY_AUTONEG
|
||||||
|
---help---
|
||||||
|
Select 100Mbit vs. 10Mbit speed.
|
||||||
|
|
||||||
|
config PHY_FDUPLEX
|
||||||
|
bool "Full duplex"
|
||||||
|
default n
|
||||||
|
depends on PIC32MZ_ETHERNET && !PHY_AUTONEG
|
||||||
|
---help---
|
||||||
|
Select full (vs. half) duplex
|
||||||
|
|
||||||
|
config NET_NTXDESC
|
||||||
|
int "Number Tx descriptors"
|
||||||
|
default 2
|
||||||
|
depends on PIC32MZ_ETHERNET
|
||||||
|
---help---
|
||||||
|
Configured number of Tx descriptors. Default: 2
|
||||||
|
|
||||||
|
config NET_NRXDESC
|
||||||
|
int "Number Rx descriptors"
|
||||||
|
default 4
|
||||||
|
depends on PIC32MZ_ETHERNET
|
||||||
|
---help---
|
||||||
|
Configured number of Rx descriptors. Default: 4
|
||||||
|
|
||||||
|
config NET_PRIORITY
|
||||||
|
int ""
|
||||||
|
default 28
|
||||||
|
depends on PIC32MZ_ETHERNET
|
||||||
|
---help---
|
||||||
|
Ethernet interrupt priority. The is default is the higest priority.
|
||||||
|
|
||||||
|
config NET_WOL
|
||||||
|
bool "Wake-up on LAN"
|
||||||
|
default n
|
||||||
|
depends on PIC32MZ_ETHERNET
|
||||||
|
---help---
|
||||||
|
Enable Wake-up on LAN (not fully implemented).
|
||||||
|
|
||||||
|
config NET_REGDEBUG
|
||||||
|
bool "Register level debug"
|
||||||
|
default n
|
||||||
|
depends on PIC32MZ_ETHERNET && DEBUG
|
||||||
|
---help---
|
||||||
|
Enabled low level register debug. Also needs DEBUG.
|
||||||
|
|
||||||
|
config NET_HASH
|
||||||
|
bool "Hash"
|
||||||
|
default n
|
||||||
|
depends on PIC32MZ_ETHERNET
|
||||||
|
---help---
|
||||||
|
Enable receipt of near-perfect match frames.
|
||||||
|
|
||||||
|
config NET_MULTICAST
|
||||||
|
bool "Multicast"
|
||||||
|
default y if NET_IGMP
|
||||||
|
depends on PIC32MZ_ETHERNET
|
||||||
|
---help---
|
||||||
|
Enable receipt of multicast (and unicast) frames. Automatically set if
|
||||||
|
NET_IGMP is selected.
|
||||||
|
|
||||||
|
endmenu
|
||||||
|
|
||||||
|
menu "Device Configuration 0 (DEVCFG0)"
|
||||||
|
|
||||||
|
config PIC32MZ_DEBUGGER
|
||||||
|
int "Debugger"
|
||||||
|
default 3
|
||||||
|
---help---
|
||||||
|
Background Debugger Enable. Default 3 (disabled). The value 2 enables.
|
||||||
|
|
||||||
|
config PIC32MZ_ICESEL
|
||||||
|
int "ICE channel"
|
||||||
|
default 1
|
||||||
|
---help---
|
||||||
|
In-Circuit Emulator/Debugger Communication Channel Select. Default 1 (PG2)
|
||||||
|
|
||||||
|
config PIC32MZ_PROGFLASHWP
|
||||||
|
hex "Program FLASH write protect"
|
||||||
|
default 0x3ff if ARCH_CHIP_PIC32MZ1 || ARCH_CHIP_PIC32MZ2
|
||||||
|
default 0xff if !ARCH_CHIP_PIC32MZ1 && !ARCH_CHIP_PIC32MZ2
|
||||||
|
---help---
|
||||||
|
Program FLASH write protect. Default 0xff (disabled)
|
||||||
|
|
||||||
|
config PIC32MZ_BOOTFLASHWP
|
||||||
|
int "Boot FLASH write protect"
|
||||||
|
default 1
|
||||||
|
---help---
|
||||||
|
Default 1 (disabled)
|
||||||
|
|
||||||
|
config PIC32MZ_CODEWP
|
||||||
|
int "Code write protect"
|
||||||
|
default 1
|
||||||
|
---help---
|
||||||
|
Default 1 (disabled)
|
||||||
|
|
||||||
|
endmenu
|
||||||
|
|
||||||
|
menu "Device Configuration 1 (DEVCFG1)"
|
||||||
|
|
||||||
|
config PIC32MZ_OSCOUT
|
||||||
|
int "USB ID"
|
||||||
|
default 0
|
||||||
|
depends on ARCH_CHIP_PIC32MZ1 || ARCH_CHIP_PIC32MZ2
|
||||||
|
---help---
|
||||||
|
USB USBID Selection. Default 1 if USB enabled (USBID pin is controlled by the USB
|
||||||
|
module), but 0 (GPIO) otherwise.
|
||||||
|
|
||||||
|
endmenu
|
||||||
|
|
||||||
|
menu "Device Configuration 3 (DEVCFG3)"
|
||||||
|
|
||||||
|
config PIC32MZ_USBIDO
|
||||||
|
int "USB ID"
|
||||||
|
default 1 if PIC32MZ_USB
|
||||||
|
default 0 if !PIC32MZ_USB
|
||||||
|
---help---
|
||||||
|
USB USBID Selection. Default 1 if USB enabled (USBID pin is controlled by the USB
|
||||||
|
module), but 0 (GPIO) otherwise.
|
||||||
|
|
||||||
|
config PIC32MZ_VBUSIO
|
||||||
|
int "USB VBUSON"
|
||||||
|
default 1 if PIC32MZ_USB
|
||||||
|
default 0 if !PIC32MZ_USB
|
||||||
|
---help---
|
||||||
|
USB VBUSON Selection (Default 1 if USB enabled (VBUSON pin is controlled by the USB
|
||||||
|
module, but 0 (GPIO) otherwise.
|
||||||
|
|
||||||
|
config PIC32MZ_WDENABLE
|
||||||
|
bool "Watchdog enable"
|
||||||
|
default 0
|
||||||
|
---help---
|
||||||
|
Enabled watchdog on power up. Default 0 (watchdog can be enabled later by software).
|
||||||
|
|
||||||
|
config PIC32MZ_FETHIO
|
||||||
|
int "Ethernet I/O pins"
|
||||||
|
default 1
|
||||||
|
---help---
|
||||||
|
Ethernet I/O Pin Selection bit:
|
||||||
|
|
||||||
|
1 = Default Ethernet I/O Pins
|
||||||
|
0 = Alternate Ethernet I/O Pins
|
||||||
|
|
||||||
|
config PIC32MZ_FMIIEN
|
||||||
|
int "Ethernet MII"
|
||||||
|
default 1
|
||||||
|
---help---
|
||||||
|
Ethernet MII Enable bit
|
||||||
|
|
||||||
|
1 = MII enabled
|
||||||
|
0 = RMII enabled
|
||||||
|
|
||||||
|
endmenu
|
||||||
|
|
||||||
|
endif
|
@ -553,7 +553,7 @@ config ARCH_BOARD_PCDUINO_A10
|
|||||||
but the others may be compatible.
|
but the others may be compatible.
|
||||||
|
|
||||||
config ARCH_BOARD_PIC32MX_STARTERKIT
|
config ARCH_BOARD_PIC32MX_STARTERKIT
|
||||||
bool "Microchip PIC32 Ethernet Starter Kit (DM320004)"
|
bool "Microchip PIC32MX Ethernet Starter Kit (DM320004)"
|
||||||
depends on ARCH_CHIP_PIC32MX795F512L
|
depends on ARCH_CHIP_PIC32MX795F512L
|
||||||
select ARCH_HAVE_LEDS
|
select ARCH_HAVE_LEDS
|
||||||
---help---
|
---help---
|
||||||
@ -569,6 +569,22 @@ config ARCH_BOARD_PIC32MX7MMB
|
|||||||
This is the port NuttX to the Mikroelektronika PIC32MX7 Multimedia Board
|
This is the port NuttX to the Mikroelektronika PIC32MX7 Multimedia Board
|
||||||
(MMB). See http://www.mikroe.com/ for further information.
|
(MMB). See http://www.mikroe.com/ for further information.
|
||||||
|
|
||||||
|
config ARCH_BOARD_PIC32MZ_STARTERKIT
|
||||||
|
bool "Microchip PIC32MZ Ethernet Starter Kit ((DM320006)"
|
||||||
|
depends on ARCH_CHIP_PIC32MZ2048ECH || ARCH_CHIP_PIC32MZ2048ECM
|
||||||
|
select ARCH_HAVE_LEDS
|
||||||
|
---help---
|
||||||
|
This is the port of NuttX to the Microchip PIC32MZ Embedded
|
||||||
|
Connectivity (EC) Starter Kit. There are two configurations of the
|
||||||
|
starter kit:
|
||||||
|
|
||||||
|
1) The PIC32MZ Embedded Connectivity Starter Kit based on the
|
||||||
|
PIC32MZ2048ECH144-I/PH chip (DM320006), and
|
||||||
|
2) The PIC32MZ Embedded Connectivity Starter Kit based on the
|
||||||
|
PIC32MZ2048ECM144-I/PH w/Crypto Engine (DM320006-C)
|
||||||
|
|
||||||
|
See www.microchip.com for further information.
|
||||||
|
|
||||||
config ARCH_BOARD_PIRELLI_DPL10
|
config ARCH_BOARD_PIRELLI_DPL10
|
||||||
bool "Pirelli DPL10 phone"
|
bool "Pirelli DPL10 phone"
|
||||||
depends on ARCH_CHIP_CALYPSO
|
depends on ARCH_CHIP_CALYPSO
|
||||||
@ -1111,6 +1127,7 @@ config ARCH_BOARD
|
|||||||
default "pcduino-a10" if ARCH_BOARD_PCDUINO_A10
|
default "pcduino-a10" if ARCH_BOARD_PCDUINO_A10
|
||||||
default "pic32mx-starterkit" if ARCH_BOARD_PIC32MX_STARTERKIT
|
default "pic32mx-starterkit" if ARCH_BOARD_PIC32MX_STARTERKIT
|
||||||
default "pic32mx7mmb" if ARCH_BOARD_PIC32MX7MMB
|
default "pic32mx7mmb" if ARCH_BOARD_PIC32MX7MMB
|
||||||
|
default "pic32mz-starterkit" if ARCH_BOARD_PIC32MZ_STARTERKIT
|
||||||
default "pirelli_dpl10" if ARCH_BOARD_PIRELLI_DPL10
|
default "pirelli_dpl10" if ARCH_BOARD_PIRELLI_DPL10
|
||||||
default "nucleo-f4x1re" if ARCH_BOARD_NUCLEO_F401RE || ARCH_BOARD_NUCLEO_F411RE
|
default "nucleo-f4x1re" if ARCH_BOARD_NUCLEO_F401RE || ARCH_BOARD_NUCLEO_F411RE
|
||||||
default "qemu-i486" if ARCH_BOARD_QEMU_I486
|
default "qemu-i486" if ARCH_BOARD_QEMU_I486
|
||||||
@ -1379,6 +1396,9 @@ endif
|
|||||||
if ARCH_BOARD_PIC32MX7MMB
|
if ARCH_BOARD_PIC32MX7MMB
|
||||||
source "configs/pic32mx7mmb/Kconfig"
|
source "configs/pic32mx7mmb/Kconfig"
|
||||||
endif
|
endif
|
||||||
|
if ARCH_BOARD_PIC32MZ_STARTERKIT
|
||||||
|
source "configs/pic32mz-starterkit/Kconfig"
|
||||||
|
endif
|
||||||
if ARCH_BOARD_PIRELLI_DPL10
|
if ARCH_BOARD_PIRELLI_DPL10
|
||||||
source "configs/pirelli_dpl10/Kconfig"
|
source "configs/pirelli_dpl10/Kconfig"
|
||||||
endif
|
endif
|
||||||
|
@ -463,6 +463,18 @@ configs/pic32mx7mmb
|
|||||||
http://www.mikroe.com/ for further information.
|
http://www.mikroe.com/ for further information.
|
||||||
|
|
||||||
configs/pirelli_dpl10
|
configs/pirelli_dpl10
|
||||||
|
configs/pic32mz-starterkit
|
||||||
|
This directory contains the port of NuttX to the Microchip PIC32MZ
|
||||||
|
Embedded Connectivity (EC) Starter Kit. There are two configurations of
|
||||||
|
the starter kit:
|
||||||
|
|
||||||
|
1) The PIC32MZ Embedded Connectivity Starter Kit based on the
|
||||||
|
PIC32MZ2048ECH144-I/PH chip (DM320006), and
|
||||||
|
2) The PIC32MZ Embedded Connectivity Starter Kit based on the
|
||||||
|
PIC32MZ2048ECM144-I/PH w/Crypto Engine (DM320006-C)
|
||||||
|
|
||||||
|
See www.microchip.com for further information.
|
||||||
|
|
||||||
This directory contains the board support for Pirelli "Discus" DP-L10 phones.
|
This directory contains the board support for Pirelli "Discus" DP-L10 phones.
|
||||||
It is a variant of the compal_e88 config with the small changes for the
|
It is a variant of the compal_e88 config with the small changes for the
|
||||||
differences in the board.
|
differences in the board.
|
||||||
|
@ -182,6 +182,9 @@ Where <subdir> is one of the following:
|
|||||||
2. Serial Output
|
2. Serial Output
|
||||||
|
|
||||||
The OS test produces all of its test output on the serial console.
|
The OS test produces all of its test output on the serial console.
|
||||||
This configuration has UART1 enabled as a serial console. I have
|
This configuration has UART1 enabled as a serial console.
|
||||||
been unable to get this UART work on the MEB. But on the Expansion
|
|
||||||
I/O board, this maps to RX = J11 pin 41 and TX = J11 pin 43
|
3. Toolchain
|
||||||
|
|
||||||
|
By default, the Pinguino MIPs tool chain is used. This toolchain
|
||||||
|
selection can easily be changed with 'make menuconfig'.
|
||||||
|
@ -70,6 +70,7 @@ CONFIG_ARCH_MIPS=y
|
|||||||
CONFIG_ARCH="mips"
|
CONFIG_ARCH="mips"
|
||||||
CONFIG_ARCH_FAMILY="mips32"
|
CONFIG_ARCH_FAMILY="mips32"
|
||||||
CONFIG_ARCH_CHIP="pic32mz"
|
CONFIG_ARCH_CHIP="pic32mz"
|
||||||
|
# CONFIG_ARCH_CHIP_PIC32MX is not set
|
||||||
CONFIG_ARCH_CHIP_PIC32MZ=y
|
CONFIG_ARCH_CHIP_PIC32MZ=y
|
||||||
CONFIG_ARCH_MIPS32=y
|
CONFIG_ARCH_MIPS32=y
|
||||||
|
|
||||||
@ -78,162 +79,89 @@ CONFIG_ARCH_MIPS32=y
|
|||||||
#
|
#
|
||||||
# CONFIG_MIPS32_TOOLCHAIN_GNU_ELF is not set
|
# CONFIG_MIPS32_TOOLCHAIN_GNU_ELF is not set
|
||||||
# CONFIG_MIPS32_TOOLCHAIN_MICROCHIPW is not set
|
# CONFIG_MIPS32_TOOLCHAIN_MICROCHIPW is not set
|
||||||
CONFIG_MIPS32_TOOLCHAIN_MICROCHIPW_LITE=y
|
# CONFIG_MIPS32_TOOLCHAIN_MICROCHIPW_LITE is not set
|
||||||
# CONFIG_MIPS32_TOOLCHAIN_PINGUINOW is not set
|
CONFIG_MIPS32_TOOLCHAIN_PINGUINOW=y
|
||||||
# CONFIG_MIPS32_FRAMEPOINTER is not set
|
# CONFIG_MIPS32_FRAMEPOINTER is not set
|
||||||
|
|
||||||
#
|
#
|
||||||
# PIC32MX Configuration Options
|
# PIC32MZ Configuration Options
|
||||||
#
|
#
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX110F016B is not set
|
# CONFIG_ARCH_CHIP_PIC32MZ2048ECH is not set
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX110F016C is not set
|
CONFIG_ARCH_CHIP_PIC32MZ2048ECM=y
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX110F016D is not set
|
CONFIG_ARCH_CHIP_PIC32MZEC=y
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX120F032B is not set
|
# CONFIG_PIC32MZ_MVEC is not set
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX120F032C is not set
|
CONFIG_PIC32MZ_T1=y
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX120F032D is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX130F064B is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX130F064C is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX130F064D is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX150F128B is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX150F128C is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX150F128D is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX210F016B is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX210F016C is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX210F016D is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX220F032B is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX220F032C is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX220F032D is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX230F064B is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX230F064C is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX230F064D is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX250F128B is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX250F128C is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX250F128D is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX320F032H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX320F064H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX320F128H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX320F128L is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX340F128H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX340F256H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX340F512H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX340F128L is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX360F256L is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX360F512L is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX420F032H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX440F128H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX440F128L is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX440F256H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX440F512H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX460F256L is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX460F512L is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX534F064H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX534F064L is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX564F064H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX564F064L is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX564F128H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX564F128L is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX575F256H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX575F256L is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX575F512H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX575F512L is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX664F064H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX664F064L is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX664F128H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX664F128L is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX675F256H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX675F256L is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX675F512H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX675F512L is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX695F512H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX695F512L is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX764F128H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX764F128L is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX775F256H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX775F256L is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX775F512H is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX775F512L is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX795F512H is not set
|
|
||||||
CONFIG_ARCH_CHIP_PIC32MX795F512L=y
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX1 is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX2 is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX3 is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX4 is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX5 is not set
|
|
||||||
# CONFIG_ARCH_CHIP_PIC32MX6 is not set
|
|
||||||
CONFIG_ARCH_CHIP_PIC32MX7=y
|
|
||||||
# CONFIG_PIC32MX_MVEC is not set
|
|
||||||
CONFIG_PIC32MX_T1=y
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# PIC32MX Peripheral Support
|
# PIC32MZ Peripheral Support
|
||||||
#
|
#
|
||||||
# CONFIG_PIC32MX_WDT is not set
|
# CONFIG_PIC32MZ_WDT is not set
|
||||||
# CONFIG_PIC32MX_T2 is not set
|
# CONFIG_PIC32MZ_T2 is not set
|
||||||
# CONFIG_PIC32MX_T3 is not set
|
# CONFIG_PIC32MZ_T3 is not set
|
||||||
# CONFIG_PIC32MX_T4 is not set
|
# CONFIG_PIC32MZ_T4 is not set
|
||||||
# CONFIG_PIC32MX_T5 is not set
|
# CONFIG_PIC32MZ_T5 is not set
|
||||||
# CONFIG_PIC32MX_IC1 is not set
|
# CONFIG_PIC32MZ_IC1 is not set
|
||||||
# CONFIG_PIC32MX_IC2 is not set
|
# CONFIG_PIC32MZ_IC2 is not set
|
||||||
# CONFIG_PIC32MX_IC3 is not set
|
# CONFIG_PIC32MZ_IC3 is not set
|
||||||
# CONFIG_PIC32MX_IC4 is not set
|
# CONFIG_PIC32MZ_IC4 is not set
|
||||||
# CONFIG_PIC32MX_IC5 is not set
|
# CONFIG_PIC32MZ_IC5 is not set
|
||||||
# CONFIG_PIC32MX_OC1 is not set
|
# CONFIG_PIC32MZ_OC1 is not set
|
||||||
# CONFIG_PIC32MX_OC2 is not set
|
# CONFIG_PIC32MZ_OC2 is not set
|
||||||
# CONFIG_PIC32MX_OC3 is not set
|
# CONFIG_PIC32MZ_OC3 is not set
|
||||||
# CONFIG_PIC32MX_OC4 is not set
|
# CONFIG_PIC32MZ_OC4 is not set
|
||||||
# CONFIG_PIC32MX_OC5 is not set
|
# CONFIG_PIC32MZ_OC5 is not set
|
||||||
# CONFIG_PIC32MX_I2C1 is not set
|
# CONFIG_PIC32MZ_I2C1 is not set
|
||||||
# CONFIG_PIC32MX_I2C2 is not set
|
# CONFIG_PIC32MZ_I2C2 is not set
|
||||||
# CONFIG_PIC32MX_I2C3 is not set
|
# CONFIG_PIC32MZ_I2C3 is not set
|
||||||
# CONFIG_PIC32MX_I2C4 is not set
|
# CONFIG_PIC32MZ_I2C4 is not set
|
||||||
# CONFIG_PIC32MX_I2C5 is not set
|
# CONFIG_PIC32MZ_I2C5 is not set
|
||||||
# CONFIG_PIC32MX_SPI1 is not set
|
# CONFIG_PIC32MZ_SPI1 is not set
|
||||||
# CONFIG_PIC32MX_SPI2 is not set
|
# CONFIG_PIC32MZ_SPI2 is not set
|
||||||
# CONFIG_PIC32MX_SPI3 is not set
|
# CONFIG_PIC32MZ_SPI3 is not set
|
||||||
# CONFIG_PIC32MX_SPI4 is not set
|
# CONFIG_PIC32MZ_SPI4 is not set
|
||||||
CONFIG_PIC32MX_UART1=y
|
CONFIG_PIC32MZ_UART1=y
|
||||||
# CONFIG_PIC32MX_UART2 is not set
|
# CONFIG_PIC32MZ_UART2 is not set
|
||||||
# CONFIG_PIC32MX_UART3 is not set
|
# CONFIG_PIC32MZ_UART3 is not set
|
||||||
# CONFIG_PIC32MX_UART4 is not set
|
# CONFIG_PIC32MZ_UART4 is not set
|
||||||
# CONFIG_PIC32MX_UART5 is not set
|
# CONFIG_PIC32MZ_UART5 is not set
|
||||||
# CONFIG_PIC32MX_UART6 is not set
|
# CONFIG_PIC32MZ_UART6 is not set
|
||||||
# CONFIG_PIC32MX_ADC is not set
|
# CONFIG_PIC32MZ_ADC is not set
|
||||||
# CONFIG_PIC32MX_PMP is not set
|
# CONFIG_PIC32MZ_PMP is not set
|
||||||
# CONFIG_PIC32MX_CM1 is not set
|
# CONFIG_PIC32MZ_CM1 is not set
|
||||||
# CONFIG_PIC32MX_CM2 is not set
|
# CONFIG_PIC32MZ_CM2 is not set
|
||||||
# CONFIG_PIC32MX_CM3 is not set
|
# CONFIG_PIC32MZ_CM3 is not set
|
||||||
# CONFIG_PIC32MX_RTCC is not set
|
# CONFIG_PIC32MZ_RTCC is not set
|
||||||
# CONFIG_PIC32MX_DMA is not set
|
# CONFIG_PIC32MZ_DMA is not set
|
||||||
# CONFIG_PIC32MX_FLASH is not set
|
# CONFIG_PIC32MZ_FLASH is not set
|
||||||
# CONFIG_PIC32MX_USBDEV is not set
|
# CONFIG_PIC32MZ_USBDEV is not set
|
||||||
# CONFIG_PIC32MX_USBHOST is not set
|
# CONFIG_PIC32MZ_USBHOST is not set
|
||||||
# CONFIG_PIC32MX_CAN1 is not set
|
# CONFIG_PIC32MZ_CAN1 is not set
|
||||||
# CONFIG_PIC32MX_CAN2 is not set
|
# CONFIG_PIC32MZ_CAN2 is not set
|
||||||
# CONFIG_PIC32MX_ETHERNET is not set
|
# CONFIG_PIC32MZ_ETHERNET is not set
|
||||||
# CONFIG_PIC32MX_CTMU is not set
|
# CONFIG_PIC32MZ_CTMU is not set
|
||||||
|
|
||||||
#
|
#
|
||||||
# PIC32MX Peripheral Interrupt Priorities
|
# PIC32MZ Peripheral Interrupt Priorities
|
||||||
#
|
#
|
||||||
CONFIG_PIC32MX_CTPRIO=16
|
CONFIG_PIC32MZ_CTPRIO=16
|
||||||
CONFIG_PIC32MX_CS0PRIO=16
|
CONFIG_PIC32MZ_CS0PRIO=16
|
||||||
CONFIG_PIC32MX_CS1PRIO=16
|
CONFIG_PIC32MZ_CS1PRIO=16
|
||||||
CONFIG_PIC32MX_INT0PRIO=16
|
CONFIG_PIC32MZ_INT0PRIO=16
|
||||||
CONFIG_PIC32MX_INT1PRIO=16
|
CONFIG_PIC32MZ_INT1PRIO=16
|
||||||
CONFIG_PIC32MX_INT2PRIO=16
|
CONFIG_PIC32MZ_INT2PRIO=16
|
||||||
CONFIG_PIC32MX_INT3PRIO=16
|
CONFIG_PIC32MZ_INT3PRIO=16
|
||||||
CONFIG_PIC32MX_INT4PRIO=16
|
CONFIG_PIC32MZ_INT4PRIO=16
|
||||||
CONFIG_PIC32MX_T1PRIO=16
|
CONFIG_PIC32MZ_T1PRIO=16
|
||||||
CONFIG_PIC32MX_UART1PRIO=16
|
CONFIG_PIC32MZ_UART1PRIO=16
|
||||||
|
|
||||||
#
|
#
|
||||||
# Device Configuration 0 (DEVCFG0)
|
# Device Configuration 0 (DEVCFG0)
|
||||||
#
|
#
|
||||||
CONFIG_PIC32MX_DEBUGGER=2
|
CONFIG_PIC32MZ_DEBUGGER=2
|
||||||
CONFIG_PIC32MX_ICESEL=1
|
CONFIG_PIC32MZ_ICESEL=1
|
||||||
CONFIG_PIC32MX_PROGFLASHWP=0xff
|
CONFIG_PIC32MZ_PROGFLASHWP=0xff
|
||||||
CONFIG_PIC32MX_BOOTFLASHWP=1
|
CONFIG_PIC32MZ_BOOTFLASHWP=1
|
||||||
CONFIG_PIC32MX_CODEWP=1
|
CONFIG_PIC32MZ_CODEWP=1
|
||||||
|
|
||||||
#
|
#
|
||||||
# Device Configuration 1 (DEVCFG1)
|
# Device Configuration 1 (DEVCFG1)
|
||||||
@ -242,11 +170,11 @@ CONFIG_PIC32MX_CODEWP=1
|
|||||||
#
|
#
|
||||||
# Device Configuration 3 (DEVCFG3)
|
# Device Configuration 3 (DEVCFG3)
|
||||||
#
|
#
|
||||||
CONFIG_PIC32MX_USBIDO=0
|
CONFIG_PIC32MZ_USBIDO=0
|
||||||
CONFIG_PIC32MX_VBUSIO=0
|
CONFIG_PIC32MZ_VBUSIO=0
|
||||||
# CONFIG_PIC32MX_WDENABLE is not set
|
# CONFIG_PIC32MZ_WDENABLE is not set
|
||||||
CONFIG_PIC32MX_FETHIO=0
|
CONFIG_PIC32MZ_FETHIO=0
|
||||||
CONFIG_PIC32MX_FMIIEN=0
|
CONFIG_PIC32MZ_FMIIEN=0
|
||||||
|
|
||||||
#
|
#
|
||||||
# Architecture Options
|
# Architecture Options
|
||||||
@ -305,7 +233,6 @@ CONFIG_RAM_SIZE=131072
|
|||||||
# Board Selection
|
# Board Selection
|
||||||
#
|
#
|
||||||
CONFIG_ARCH_BOARD_PIC32MZ_STARTERKIT=y
|
CONFIG_ARCH_BOARD_PIC32MZ_STARTERKIT=y
|
||||||
# CONFIG_ARCH_BOARD_PIC32MX7MMB is not set
|
|
||||||
# CONFIG_ARCH_BOARD_CUSTOM is not set
|
# CONFIG_ARCH_BOARD_CUSTOM is not set
|
||||||
CONFIG_ARCH_BOARD="pic32mz-starterkit"
|
CONFIG_ARCH_BOARD="pic32mz-starterkit"
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user