1 #ifndef direct_pin_read_h_ 2 #define direct_pin_read_h_ 6 #define IO_REG_TYPE uint8_t 7 #define PIN_TO_BASEREG(pin) (portInputRegister(digitalPinToPort(pin))) 8 #define PIN_TO_BITMASK(pin) (digitalPinToBitMask(pin)) 9 #define DIRECT_PIN_READ(base, mask) (((*(base)) & (mask)) ? 1 : 0) 11 #elif defined(TEENSYDUINO) && (defined(KINETISK) || defined(KINETISL)) 13 #define IO_REG_TYPE uint8_t 14 #define PIN_TO_BASEREG(pin) (portInputRegister(digitalPinToPort(pin))) 15 #define PIN_TO_BITMASK(pin) (digitalPinToBitMask(pin)) 16 #define DIRECT_PIN_READ(base, mask) (((*(base)) & (mask)) ? 1 : 0) 18 #elif defined(__IMXRT1052__) || defined(__IMXRT1062__) 20 #define IO_REG_TYPE uint32_t 21 #define PIN_TO_BASEREG(pin) (portOutputRegister(pin)) 22 #define PIN_TO_BITMASK(pin) (digitalPinToBitMask(pin)) 23 #define DIRECT_PIN_READ(base, mask) (((*(base)) & (mask)) ? 1 : 0) 25 #elif defined(__SAM3X8E__) // || defined(ESP8266) 27 #define IO_REG_TYPE uint32_t 28 #define PIN_TO_BASEREG(pin) (portInputRegister(digitalPinToPort(pin))) 29 #define PIN_TO_BITMASK(pin) (digitalPinToBitMask(pin)) 30 #define DIRECT_PIN_READ(base, mask) (((*(base)) & (mask)) ? 1 : 0) 32 #elif defined(__PIC32MX__) 34 #define IO_REG_TYPE uint32_t 35 #define PIN_TO_BASEREG(pin) (portModeRegister(digitalPinToPort(pin))) 36 #define PIN_TO_BITMASK(pin) (digitalPinToBitMask(pin)) 37 #define DIRECT_PIN_READ(base, mask) (((*(base+4)) & (mask)) ? 1 : 0) 40 #elif defined(ESP8266) 42 #define IO_REG_TYPE uint32_t 43 #define PIN_TO_BASEREG(pin) ((volatile uint32_t *)(0x60000000+(0x318))) 44 #define PIN_TO_BITMASK(pin) (digitalPinToBitMask(pin)) 45 #define DIRECT_PIN_READ(base, mask) (((*(base)) & (mask)) ? 1 : 0) 50 #define IO_REG_TYPE uint32_t 51 #define PIN_TO_BASEREG(pin) (portInputRegister(digitalPinToPort(pin))) 52 #define PIN_TO_BITMASK(pin) (digitalPinToBitMask(pin)) 53 #define DIRECT_PIN_READ(base, mask) (((*(base)) & (mask)) ? 1 : 0) 55 #elif defined(__SAMD21G18A__) || defined(__SAMD51__) 57 #define IO_REG_TYPE uint32_t 58 #define PIN_TO_BASEREG(pin) portModeRegister(digitalPinToPort(pin)) 59 #define PIN_TO_BITMASK(pin) (digitalPinToBitMask(pin)) 60 #define DIRECT_PIN_READ(base, mask) (((*((base)+8)) & (mask)) ? 1 : 0) 62 #elif defined(RBL_NRF51822) 64 #define IO_REG_TYPE uint32_t 65 #define PIN_TO_BASEREG(pin) (0) 66 #define PIN_TO_BITMASK(pin) (pin) 67 #define DIRECT_PIN_READ(base, pin) nrf_gpio_pin_read(pin) 69 #elif defined(__arc__) 71 #include "scss_registers.h" 73 #include "avr/pgmspace.h" 74 #define GPIO_ID(pin) (g_APinDescription[pin].ulGPIOId) 75 #define GPIO_TYPE(pin) (g_APinDescription[pin].ulGPIOType) 76 #define GPIO_BASE(pin) (g_APinDescription[pin].ulGPIOBase) 77 #define EXT_PORT_OFFSET_SS 0x0A 78 #define EXT_PORT_OFFSET_SOC 0x50 79 #define PIN_TO_BASEREG(pin) ((volatile uint32_t *)g_APinDescription[pin].ulGPIOBase) 80 #define PIN_TO_BITMASK(pin) pin 81 #define IO_REG_TYPE uint32_t 82 static inline __attribute__((always_inline))
83 IO_REG_TYPE directRead(volatile IO_REG_TYPE *base, IO_REG_TYPE pin)
86 if (SS_GPIO == GPIO_TYPE(pin)) {
87 ret = READ_ARC_REG(((IO_REG_TYPE)base + EXT_PORT_OFFSET_SS));
89 ret = MMIO_REG_VAL_FROM_BASE((IO_REG_TYPE)base, EXT_PORT_OFFSET_SOC);
91 return ((ret >> GPIO_ID(pin)) & 0x01);
93 #define DIRECT_PIN_READ(base, pin) directRead(base, pin)