mirror of
https://github.com/YuzuZensai/MCUFRIEND_kbv.git
synced 2026-01-06 04:32:38 +00:00
287 lines
12 KiB
C
287 lines
12 KiB
C
#ifndef PIN_SHIELD_8_H_
|
||
#define PIN_SHIELD_8_H_
|
||
|
||
// just provide macros for the 8-bit data bus
|
||
// i.e. write_8(), read_8(), setWriteDir(), setReadDir()
|
||
|
||
|
||
#define LPC810 810
|
||
#define LPC812 812
|
||
#define LPC1343 1343
|
||
#define LPC1768 1768
|
||
#define LPC2103 2103
|
||
#define LPC2148 2148
|
||
#warning Using pin_SHIELD_8.h
|
||
|
||
#if 0
|
||
|
||
#elif defined(NUCLEO) || defined(TARGET_NUCLEO_F072RB) || defined(TARGET_NUCLEO_F401RE) || defined(TARGET_NUCLEO_F411RE) || defined(TARGET_NUCLEO_F103RB)
|
||
#if __MBED__
|
||
#warning MBED knows everything
|
||
#elif defined(STM32F072xB)
|
||
#include <STM32F0XX.h>
|
||
#elif defined(STM32F103xB)
|
||
#if defined(__CC_ARM)
|
||
#include <STM32F10X.h>
|
||
#else
|
||
#include <STM32F1XX.h>
|
||
#endif
|
||
#elif defined(STM32L476xx)
|
||
#include <STM32L4XX.h>
|
||
#elif defined(STM32F401xE) || defined(STM32F411xE)
|
||
#include <STM32F4XX.h>
|
||
#endif
|
||
// configure macros for the data pins. -00=10.06, -O1=7.85, -O1t=7.21, -O2=7.87, -O3=7.45, -O3t=7.03
|
||
#define write_8(d) { \
|
||
GPIOA->BSRR = 0x0700 << 16; \
|
||
GPIOB->BSRR = 0x0438 << 16; \
|
||
GPIOC->BSRR = 0x0080 << 16; \
|
||
GPIOA->BSRR = (((d) & (1<<0)) << 9) \
|
||
| (((d) & (1<<2)) << 8) \
|
||
| (((d) & (1<<7)) << 1); \
|
||
GPIOB->BSRR = (((d) & (1<<3)) << 0) \
|
||
| (((d) & (1<<4)) << 1) \
|
||
| (((d) & (1<<5)) >> 1) \
|
||
| (((d) & (1<<6)) << 4); \
|
||
GPIOC->BSRR = (((d) & (1<<1)) << 6); \
|
||
}
|
||
#define read_8() ( (((GPIOA->IDR & (1<<9)) >> 9) \
|
||
| ((GPIOC->IDR & (1<<7)) >> 6) \
|
||
| ((GPIOA->IDR & (1<<10)) >> 8) \
|
||
| ((GPIOB->IDR & (1<<3)) >> 0) \
|
||
| ((GPIOB->IDR & (1<<5)) >> 1) \
|
||
| ((GPIOB->IDR & (1<<4)) << 1) \
|
||
| ((GPIOB->IDR & (1<<10)) >> 4) \
|
||
| ((GPIOA->IDR & (1<<8)) >> 1)))
|
||
// be wise to clear both MODER bits properly.
|
||
#if defined(STM32F103xB)
|
||
#define GROUP_MODE(port, reg, mask, val) {port->reg = (port->reg & ~(mask)) | ((mask)&(val)); }
|
||
#define GP_OUT(port, reg, mask) GROUP_MODE(port, reg, mask, 0x33333333)
|
||
#define GP_INP(port, reg, mask) GROUP_MODE(port, reg, mask, 0x44444444)
|
||
// PA10,PA9,PA8 PB10 PB5,PB4,PB3 PC7
|
||
#define setWriteDir() {GP_OUT(GPIOA, CRH, 0xFFF); GP_OUT(GPIOB, CRH, 0xF00); GP_OUT(GPIOB, CRL, 0xFFF000); GP_OUT(GPIOC, CRL, 0xF0000000); }
|
||
#define setReadDir() {GP_INP(GPIOA, CRH, 0xFFF); GP_INP(GPIOB, CRH, 0xF00); GP_INP(GPIOB, CRL, 0xFFF000); GP_INP(GPIOC, CRL, 0xF0000000); }
|
||
#else
|
||
#define setWriteDir() { setReadDir(); \
|
||
GPIOA->MODER |= 0x150000; GPIOB->MODER |= 0x100540; GPIOC->MODER |= 0x4000; }
|
||
#define setReadDir() { GPIOA->MODER &= ~0x3F0000; GPIOB->MODER &= ~0x300FC0; GPIOC->MODER &= ~0xC000; }
|
||
#endif
|
||
|
||
|
||
#elif __TARGET_PROCESSOR == LPC1768
|
||
#include <LPC17xx.h>
|
||
// configure macros for the data pins
|
||
#define write_8(d) { \
|
||
LPC_GPIO0->FIOPIN = (LPC_GPIO0->FIOPIN & ~0x01878003) \
|
||
| (((d) & (1<<0)) << 1) \
|
||
| (((d) & (1<<1)) >> 1) \
|
||
| (((d) & (1<<2)) << 22) \
|
||
| (((d) & (1<<3)) << 20) \
|
||
| (((d) & (1<<4)) << 12) \
|
||
| (((d) & (1<<5)) << 10) \
|
||
| (((d) & (1<<6)) << 11) \
|
||
| (((d) & (1<<7)) << 11); \
|
||
}
|
||
#define read_8() ( (((LPC_GPIO0->FIOPIN & (1<<1)) >> 1) \
|
||
| ((LPC_GPIO0->FIOPIN & (1<<0)) << 1) \
|
||
| ((LPC_GPIO0->FIOPIN & (1<<24)) >> 22) \
|
||
| ((LPC_GPIO0->FIOPIN & (1<<23)) >> 20) \
|
||
| ((LPC_GPIO0->FIOPIN & (1<<16)) >> 12) \
|
||
| ((LPC_GPIO0->FIOPIN & (1<<15)) >> 10) \
|
||
| ((LPC_GPIO0->FIOPIN & (1<<17)) >> 11) \
|
||
| ((LPC_GPIO0->FIOPIN & (1<<18)) >> 11)))
|
||
#define setWriteDir() {LPC_GPIO0->FIODIR |= 0x01878003; }
|
||
#define setReadDir() {LPC_GPIO0->FIODIR &= ~0x01878003; }
|
||
|
||
|
||
#elif defined(MKL25Z4) || defined(TARGET_KL25Z)
|
||
#include <MKL25Z4.h>
|
||
// configure macros for the data pins
|
||
#if 1
|
||
#define AMASK ((1<<13)|(1<<12)|(1<<5)|(1<<4))
|
||
#define CMASK ((1<<9)|(1<<8))
|
||
#define DMASK ((1<<5)|(1<<4))
|
||
#define write_8(d) { \
|
||
PTA->PCOR = AMASK; PTC->PCOR = CMASK; PTD->PCOR = DMASK; \
|
||
PTA->PSOR = (((d) & (1<<0)) << 13) \
|
||
| (((d) & (1<<3)) << 9) \
|
||
| (((d) & (1<<4)) >> 0) \
|
||
| (((d) & (1<<5)) >> 0); \
|
||
PTC->PSOR = (((d) & (1<<6)) << 2) \
|
||
| (((d) & (1<<7)) << 2); \
|
||
PTD->PSOR = (((d) & (1<<1)) << 4) \
|
||
| (((d) & (1<<2)) << 2); \
|
||
}
|
||
#define read_8() ( (((PTA->PDIR & (1<<13)) >> 13) \
|
||
| ((PTA->PDIR & (1<<12)) >> 9) \
|
||
| ((PTA->PDIR & (3<<4)) >> 0) \
|
||
| ((PTC->PDIR & (3<<8)) >> 2) \
|
||
| ((PTD->PDIR & (1<<4)) >> 2) \
|
||
| ((PTD->PDIR & (1<<5)) >> 4)))
|
||
#define setWriteDir() {PTA->PDDR |= AMASK;PTC->PDDR |= CMASK;PTD->PDDR |= DMASK; }
|
||
#define setReadDir() {PTA->PDDR &= ~AMASK;PTC->PDDR &= ~CMASK;PTD->PDDR &= ~DMASK; }
|
||
#else
|
||
#define write_8(d) { \
|
||
PTA->PDOR = (PTA->PDOR & ~0x3030) \
|
||
| (((d) & (1<<0)) << 13) \
|
||
| (((d) & (1<<3)) << 9) \
|
||
| (((d) & (3<<4)) << 0); \
|
||
PTC->PDOR = (PTC->PDOR & ~0x0300) \
|
||
| (((d) & (3<<6)) << 2); \
|
||
PTD->PDOR = (PTD->PDOR & ~0x0030) \
|
||
| (((d) & (1<<1)) << 4) \
|
||
| (((d) & (1<<2)) << 2); \
|
||
}
|
||
#define read_8() ( (((PTA->PDIR & (1<<13)) >> 13) \
|
||
| ((PTA->PDIR & (1<<12)) >> 9) \
|
||
| ((PTA->PDIR & (3<<4)) >> 0) \
|
||
| ((PTC->PDIR & (3<<8)) >> 2) \
|
||
| ((PTD->PDIR & (1<<4)) >> 2) \
|
||
| ((PTD->PDIR & (1<<5)) >> 4)))
|
||
#define setWriteDir() {PTA->PDDR |= 0x3030;PTC->PDDR |= 0x0300;PTD->PDDR |= 0x0030; }
|
||
#define setReadDir() {PTA->PDDR &= ~0x3030;PTC->PDDR &= ~0x0300;PTD->PDDR &= ~0x0030; }
|
||
#endif
|
||
|
||
#elif defined(MKL05Z4) || defined(TARGET_KL05Z)
|
||
#include <MKL05Z4.h>
|
||
// configure macros for the data pins
|
||
#define write_8(d) { \
|
||
PTA->PDOR = (PTA->PDOR & ~0x1C00) \
|
||
| (((d) & (1<<2)) << 9) \
|
||
| (((d) & (1<<4)) << 6) \
|
||
| (((d) & (1<<5)) << 7); \
|
||
PTB->PDOR = (PTB->PDOR & ~0x0CE0) \
|
||
| (((d) & (3<<0)) << 10) \
|
||
| (((d) & (1<<3)) << 2) \
|
||
| (((d) & (3<<6)) << 0); \
|
||
}
|
||
#define read_8() ( (((PTA->PDIR & (1<<11)) >> 9) \
|
||
| ((PTA->PDIR & (1<<10)) >> 6) \
|
||
| ((PTA->PDIR & (1<<12)) >> 7) \
|
||
| ((PTB->PDIR & (3<<10)) >> 10) \
|
||
| ((PTB->PDIR & (1<<5)) >> 2) \
|
||
| ((PTB->PDIR & (3<<6)) >> 0)))
|
||
#define setWriteDir() { PTA->PDDR |= 0x1C00; PTB->PDDR |= 0x0CE0; }
|
||
#define setReadDir() { PTA->PDDR &= ~0x1C00; PTB->PDDR &= ~0x0CE0; }
|
||
|
||
|
||
#elif defined(MK20D7) && defined(TEENSY)
|
||
#include <MK20D5.h>
|
||
// configure macros for the data pins
|
||
#define AMASK ((1<<12)|(1<<13))
|
||
#define CMASK ((1<<3))
|
||
#define DMASK ((1<<0)|(1<<2)|(1<<3)|(1<<4)|(1<<7))
|
||
|
||
#define write_8(d) { \
|
||
PTA->PCOR = AMASK; PTC->PCOR = CMASK; PTD->PCOR = DMASK; \
|
||
PTA->PSOR = (((d) & (1<<3)) << 9) \
|
||
| (((d) & (1<<4)) << 9); \
|
||
PTC->PSOR = (((d) & (1<<1)) << 2); \
|
||
PTD->PSOR = (((d) & (1<<0)) << 3) \
|
||
| (((d) & (1<<2)) >> 2) \
|
||
| (((d) & (1<<5)) << 2) \
|
||
| (((d) & (1<<6)) >> 2) \
|
||
| (((d) & (1<<7)) >> 5); \
|
||
}
|
||
#define read_8() ( (((PTD->PDIR & (1<<3)) >> 3) \
|
||
| ((PTC->PDIR & (1<<3)) >> 2) \
|
||
| ((PTD->PDIR & (1<<0)) << 2) \
|
||
| ((PTA->PDIR & (1<<12)) >> 9) \
|
||
| ((PTA->PDIR & (1<<13)) >> 9) \
|
||
| ((PTD->PDIR & (1<<7)) >> 2) \
|
||
| ((PTD->PDIR & (1<<4)) << 2) \
|
||
| ((PTD->PDIR & (1<<2)) << 5)))
|
||
#define setWriteDir() {PTA->PDDR |= AMASK;PTC->PDDR |= CMASK;PTD->PDDR |= DMASK; }
|
||
#define setReadDir() {PTA->PDDR &= ~AMASK;PTC->PDDR &= ~CMASK;PTD->PDDR &= ~DMASK; }
|
||
|
||
#elif defined(MK20D5) || defined(TARGET_K20D50M)
|
||
#include <MK20D5.h>
|
||
// configure macros for the data pins
|
||
#define AMASK ((1<<12)|(1<<5)|(1<<2)|(1<<1))
|
||
#define CMASK ((1<<8)|(1<<4)|(1<<3))
|
||
#define DMASK ((1<<4))
|
||
#define write_8(d) { \
|
||
PTA->PCOR = AMASK; PTC->PCOR = CMASK; PTD->PCOR = DMASK; \
|
||
PTA->PSOR = (((d) & (1<<0)) << 12) \
|
||
| (((d) & (1<<1)) << 1) \
|
||
| (((d) & (1<<2)) << 3) \
|
||
| (((d) & (1<<5)) >> 4); \
|
||
PTC->PSOR = (((d) & (1<<4)) << 4) \
|
||
| (((d) & (3<<6)) >> 3); \
|
||
PTD->PSOR = (((d) & (1<<3)) << 1); \
|
||
}
|
||
#define read_8() ( (((PTA->PDIR & (1<<5)) >> 3) \
|
||
| ((PTA->PDIR & (1<<1)) << 4) \
|
||
| ((PTA->PDIR & (1<<12)) >> 12) \
|
||
| ((PTA->PDIR & (1<<2)) >> 1) \
|
||
| ((PTC->PDIR & (1<<8)) >> 4) \
|
||
| ((PTC->PDIR & (3<<3)) << 3) \
|
||
| ((PTD->PDIR & (1<<4)) >> 1)))
|
||
#define setWriteDir() {PTA->PDDR |= AMASK;PTC->PDDR |= CMASK;PTD->PDDR |= DMASK; }
|
||
#define setReadDir() {PTA->PDDR &= ~AMASK;PTC->PDDR &= ~CMASK;PTD->PDDR &= ~DMASK; }
|
||
|
||
#elif defined(ZERO)
|
||
#include <samd21.h>
|
||
|
||
#ifndef PORTA
|
||
#define PORTA PORT->Group[0]
|
||
#define PORTB PORT->Group[1]
|
||
#endif
|
||
// configure macros for the data pins
|
||
#if defined(D21_XPRO)
|
||
#define AMASK 0x00220000
|
||
#define BMASK 0x0000C0E4
|
||
#define write_8(d) { \
|
||
PORTA.OUT.reg = (PORTA.OUT.reg & ~AMASK) \
|
||
| (((d) & (1<<5)) << 16) \
|
||
| (((d) & (1<<7)) << 10); \
|
||
PORTB.OUT.reg = (PORTB.OUT.reg & ~BMASK) \
|
||
| (((d) & (3<<0)) << 6) \
|
||
| (((d) & (1<<2)) << 12) \
|
||
| (((d) & (1<<3)) >> 1) \
|
||
| (((d) & (1<<4)) << 1) \
|
||
| (((d) & (1<<6)) << 9); \
|
||
}
|
||
#define read_8() ( (((PORTA.IN.reg & (1<<21)) >> 16) \
|
||
| ((PORTA.IN.reg & (1<<17)) >> 10) \
|
||
| ((PORTB.IN.reg & (3<<6)) >> 6) \
|
||
| ((PORTB.IN.reg & (1<<14)) >> 12) \
|
||
| ((PORTB.IN.reg & (1<<2)) << 1) \
|
||
| ((PORTB.IN.reg & (1<<5)) >> 1) \
|
||
| ((PORTB.IN.reg & (1<<15)) >> 9)))
|
||
#define setWriteDir() { \
|
||
PORTA.DIRSET.reg = AMASK; \
|
||
PORTB.DIRSET.reg = BMASK; \
|
||
PORTA.WRCONFIG.reg = (AMASK>>16) | (0<<22) | (0<<28) | (1<<30) | (1<<31); \
|
||
PORTB.WRCONFIG.reg = (BMASK & 0xFFFF) | (0<<22) | (0<<28) | (1<<30); \
|
||
}
|
||
#define setReadDir() { \
|
||
PORTA.DIRCLR.reg = AMASK; \
|
||
PORTB.DIRCLR.reg = BMASK; \
|
||
PORTA.WRCONFIG.reg = (AMASK>>16) | (1<<17) | (0<<28) | (1<<30) | (1<<31); \
|
||
PORTB.WRCONFIG.reg = (BMASK & 0xFFFF) | (1<<17) | (0<<28) | (1<<30); \
|
||
}
|
||
#else
|
||
#define DMASK 0x0030C3C0
|
||
#define write_8(x) {PORTA.OUTCLR.reg = (DMASK); \
|
||
PORTA.OUTSET.reg = (((x) & 0x0F) << 6) \
|
||
| (((x) & 0x30) << 10) \
|
||
| (((x) & 0xC0)<<14); }
|
||
#define read_8() (((PORTA.IN.reg >> 6) & 0x0F) \
|
||
| ((PORTA.IN.reg >> 10) & 0x30) \
|
||
| ((PORTA.IN.reg >> 14) & 0xC0))
|
||
#define setWriteDir() { PORTA.DIRSET.reg = DMASK; \
|
||
PORTA.WRCONFIG.reg = (DMASK & 0xFFFF) | (0<<22) | (1<<28) | (1<<30); \
|
||
PORTA.WRCONFIG.reg = (DMASK>>16) | (0<<22) | (1<<28) | (1<<30) | (1<<31); \
|
||
}
|
||
#define setReadDir() { PORTA.DIRCLR.reg = DMASK; \
|
||
PORTA.WRCONFIG.reg = (DMASK & 0xFFFF) | (1<<17) | (1<<28) | (1<<30); \
|
||
PORTA.WRCONFIG.reg = (DMASK>>16) | (1<<17) | (1<<28) | (1<<30) | (1<<31); \
|
||
}
|
||
#endif
|
||
#else
|
||
#error MCU unselected
|
||
#endif // MCUs
|
||
|
||
#endif //PIN_SHIELD_8_H
|