Skip to content

Commit a6c02bc

Browse files
committed
Add some missing defines
fixes: espressif#76fixes: espressif#5fixes: espressif#91
1 parent 54b1b8b commit a6c02bc

File tree

11 files changed

+28
-18
lines changed

11 files changed

+28
-18
lines changed

‎cores/esp32/Arduino.h‎

Lines changed: 16 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -100,12 +100,20 @@ extern "C"{
100100
#definebitClear(value, bit) ((value) &= ~(1UL << (bit)))
101101
#definebitWrite(value, bit, bitvalue) (bitvalue ? bitSet(value, bit) : bitClear(value, bit))
102102

103+
// avr-libc defines _NOP() since 1.6.2
104+
#ifndef _NOP
105+
#define_NOP() do{__asm__volatile ("nop")} while (0)
106+
#endif
107+
108+
typedefunsignedint word;
109+
103110
#definebit(b) (1UL << (b))
104111
#define_BV(b) (1UL << (b))
105112

106113
#definedigitalPinToPort(pin) (((pin)>31)?1:0)
107-
#definedigitalPinToBitMask(pin) (1UL << (pin))
114+
#definedigitalPinToBitMask(pin) (1UL << (((pin)>31)?((pin)-31):(pin)))
108115
#definedigitalPinToTimer(pin) (0)
116+
#defineanalogInPinToBit(P) (P)
109117
#defineportOutputRegister(port) ((volatileuint32_t*)((port)?GPIO_OUT1_REG:GPIO_OUT_REG))
110118
#defineportInputRegister(port) ((volatileuint32_t*)((port)?GPIO_IN1_REG:GPIO_IN_REG))
111119
#defineportModeRegister(port) ((volatileuint32_t*)((port)?GPIO_ENABLE1_REG:GPIO_ENABLE_REG))
@@ -118,6 +126,13 @@ extern "C"{
118126
typedefbool boolean;
119127
typedefuint8_t byte;
120128

129+
voidinit(void);
130+
voidinitVariant(void);
131+
voidinitArduino(void);
132+
133+
voidsetup(void);
134+
voidloop(void);
135+
121136
uint8_tshiftIn(uint8_t dataPin, uint8_t clockPin, uint8_t bitOrder);
122137
voidshiftOut(uint8_t dataPin, uint8_t clockPin, uint8_t bitOrder, uint8_t val);
123138

‎cores/esp32/esp32-hal-gpio.c‎

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -26,6 +26,8 @@
2626

2727
#defineETS_GPIO_INUM 12
2828

29+
constint8_tesp32_adc2gpio[20] ={36, -1, -1, 39, 32, 33, 34, 35, -1, -1, 4, 0, 2, 15, 13, 12, 14, 27, 25, 26};
30+
2931
constDRAM_ATTResp32_gpioMux_tesp32_gpioMux[GPIO_PIN_COUNT]={
3032
{0x44, 11, 11, 1},
3133
{0x88, -1, -1, -1},

‎cores/esp32/esp32-hal-gpio.h‎

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -65,6 +65,7 @@ typedef struct{
6565
} esp32_gpioMux_t;
6666

6767
externconstesp32_gpioMux_tesp32_gpioMux[40];
68+
externconstint8_tesp32_adc2gpio[20];
6869

6970
#definedigitalPinIsValid(pin) ((pin) < 40 && esp32_gpioMux[(pin)].reg)
7071
#definedigitalPinCanOutput(pin) ((pin) < 34 && esp32_gpioMux[(pin)].reg)

‎cores/esp32/main.cpp‎

Lines changed: 2 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -1,21 +1,13 @@
11
#include"freertos/FreeRTOS.h"
22
#include"freertos/task.h"
3-
#include"esp32-hal.h"
3+
#include"Arduino.h"
44

55
#if CONFIG_AUTOSTART_ARDUINO
66

7-
extern"C"voidinitArduino();
8-
externvoidloop();
9-
externvoidsetup();
10-
117
voidloopTask(void *pvParameters)
128
{
13-
bool setup_done = false;
9+
setup();
1410
for(;){
15-
if(!setup_done){
16-
setup();
17-
setup_done = true;
18-
}
1911
loop();
2012
}
2113
}

‎variants/esp32/pins_arduino.h‎

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,7 @@
55
#defineNUM_DIGITAL_PINS 40
66
#defineNUM_ANALOG_INPUTS 16
77

8-
#defineanalogInputToDigitalPin(p)
8+
#defineanalogInputToDigitalPin(p) (((p)<20)?(esp32_adc2gpio[(p)]):-1)
99
#definedigitalPinToInterrupt(p) (((p)<40)?(p):-1)
1010
#definedigitalPinHasPWM(p) (p < 34)
1111

‎variants/esp320/pins_arduino.h‎

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,7 @@
55
#defineNUM_DIGITAL_PINS 12
66
#defineNUM_ANALOG_INPUTS 5
77

8-
#defineanalogInputToDigitalPin(p)
8+
#defineanalogInputToDigitalPin(p) (((p)<20)?(esp32_adc2gpio[(p)]):-1)
99
#definedigitalPinToInterrupt(p) (((p)<40)?(p):-1)
1010
#definedigitalPinHasPWM(p) (p < 34)
1111

‎variants/espea32/pins_arduino.h‎

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,7 @@
55
#defineNUM_DIGITAL_PINS 40
66
#defineNUM_ANALOG_INPUTS 16
77

8-
#defineanalogInputToDigitalPin(p)
8+
#defineanalogInputToDigitalPin(p) (((p)<20)?(esp32_adc2gpio[(p)]):-1)
99
#definedigitalPinToInterrupt(p) (((p)<40)?(p):-1)
1010
#definedigitalPinHasPWM(p) (p < 34)
1111

‎variants/lolin32/pins_arduino.h‎

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,7 @@
55
#defineNUM_DIGITAL_PINS 40
66
#defineNUM_ANALOG_INPUTS 16
77

8-
#defineanalogInputToDigitalPin(p)
8+
#defineanalogInputToDigitalPin(p) (((p)<20)?(esp32_adc2gpio[(p)]):-1)
99
#definedigitalPinToInterrupt(p) (((p)<40)?(p):-1)
1010
#definedigitalPinHasPWM(p) (p < 34)
1111

‎variants/nano32/pins_arduino.h‎

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,7 @@
55
#defineNUM_DIGITAL_PINS 38
66
#defineNUM_ANALOG_INPUTS 16
77

8-
#defineanalogInputToDigitalPin(p)
8+
#defineanalogInputToDigitalPin(p) (((p)<20)?(esp32_adc2gpio[(p)]):-1)
99
#definedigitalPinToInterrupt(p) (((p)<40)?(p):-1)
1010
#definedigitalPinHasPWM(p) (p < 34)
1111

‎variants/node32s/pins_arduino.h‎

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,7 @@
55
#defineNUM_DIGITAL_PINS 40
66
#defineNUM_ANALOG_INPUTS 16
77

8-
#defineanalogInputToDigitalPin(p)
8+
#defineanalogInputToDigitalPin(p) (((p)<20)?(esp32_adc2gpio[(p)]):-1)
99
#definedigitalPinToInterrupt(p) (((p)<40)?(p):-1)
1010
#definedigitalPinHasPWM(p) (p < 34)
1111

0 commit comments

Comments
(0)