Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Appearance settings

Commit 4959b7f

Browse filesBrowse files
TAMCTecP-R-O-C-H-Y
andauthored
add TAMC Termod S3 (espressif#7217)
Co-authored-by: Jan Procházka <90197375+P-R-O-C-H-Y@users.noreply.github.com>
1 parent 1065e38 commit 4959b7f
Copy full SHA for 4959b7f

File tree

Expand file treeCollapse file tree

3 files changed

+362
-0
lines changed
Filter options
Expand file treeCollapse file tree

3 files changed

+362
-0
lines changed

‎boards.txt

Copy file name to clipboardExpand all lines: boards.txt
+207Lines changed: 207 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -16196,6 +16196,213 @@ franzininho_wifi_msc_esp32s2.menu.EraseFlash.all.upload.erase_cmd=-e
1619616196

1619716197
##############################################################
1619816198

16199+
tamc_termod_s3.name=TAMC Termod S3
16200+
tamc_termod_s3.vid.0=0x303a
16201+
tamc_termod_s3.pid.0=0x1001
16202+
16203+
tamc_termod_s3.bootloader.tool=esptool_py
16204+
tamc_termod_s3.bootloader.tool.default=esptool_py
16205+
16206+
tamc_termod_s3.upload.tool=esptool_py
16207+
tamc_termod_s3.upload.tool.default=esptool_py
16208+
tamc_termod_s3.upload.tool.network=esp_ota
16209+
16210+
tamc_termod_s3.upload.maximum_size=1310720
16211+
tamc_termod_s3.upload.maximum_data_size=327680
16212+
tamc_termod_s3.upload.flags=
16213+
tamc_termod_s3.upload.extra_flags=
16214+
tamc_termod_s3.upload.use_1200bps_touch=false
16215+
tamc_termod_s3.upload.wait_for_upload_port=false
16216+
16217+
tamc_termod_s3.serial.disableDTR=false
16218+
tamc_termod_s3.serial.disableRTS=false
16219+
16220+
tamc_termod_s3.build.tarch=xtensa
16221+
tamc_termod_s3.build.bootloader_addr=0x0
16222+
tamc_termod_s3.build.target=esp32s3
16223+
tamc_termod_s3.build.mcu=esp32s3
16224+
tamc_termod_s3.build.core=esp32
16225+
tamc_termod_s3.build.variant=tamc_termod_s3
16226+
tamc_termod_s3.build.board=TAMC_TERMOD_S3
16227+
16228+
tamc_termod_s3.build.usb_mode=1
16229+
tamc_termod_s3.build.cdc_on_boot=1
16230+
tamc_termod_s3.build.msc_on_boot=0
16231+
tamc_termod_s3.build.dfu_on_boot=0
16232+
tamc_termod_s3.build.f_cpu=240000000L
16233+
tamc_termod_s3.build.flash_size=8MB
16234+
tamc_termod_s3.build.flash_freq=80m
16235+
tamc_termod_s3.build.flash_mode=dio
16236+
tamc_termod_s3.build.boot=qio
16237+
tamc_termod_s3.build.boot_freq=80m
16238+
tamc_termod_s3.build.partitions=default
16239+
tamc_termod_s3.build.defines=
16240+
tamc_termod_s3.build.loop_core=
16241+
tamc_termod_s3.build.event_core=
16242+
tamc_termod_s3.build.psram_type=qspi
16243+
tamc_termod_s3.build.memory_type={build.boot}_{build.psram_type}
16244+
16245+
tamc_termod_s3.menu.PSRAM.enabled=QSPI PSRAM
16246+
tamc_termod_s3.menu.PSRAM.enabled.build.defines=-DBOARD_HAS_PSRAM
16247+
tamc_termod_s3.menu.PSRAM.enabled.build.psram_type=qspi
16248+
tamc_termod_s3.menu.PSRAM.disabled=Disabled
16249+
tamc_termod_s3.menu.PSRAM.disabled.build.defines=
16250+
tamc_termod_s3.menu.PSRAM.disabled.build.psram_type=qspi
16251+
tamc_termod_s3.menu.PSRAM.opi=OPI PSRAM
16252+
tamc_termod_s3.menu.PSRAM.opi.build.defines=-DBOARD_HAS_PSRAM
16253+
tamc_termod_s3.menu.PSRAM.opi.build.psram_type=opi
16254+
16255+
tamc_termod_s3.menu.FlashMode.qio=QIO 80MHz
16256+
tamc_termod_s3.menu.FlashMode.qio.build.flash_mode=dio
16257+
tamc_termod_s3.menu.FlashMode.qio.build.boot=qio
16258+
tamc_termod_s3.menu.FlashMode.qio.build.boot_freq=80m
16259+
tamc_termod_s3.menu.FlashMode.qio.build.flash_freq=80m
16260+
tamc_termod_s3.menu.FlashMode.qio120=QIO 120MHz
16261+
tamc_termod_s3.menu.FlashMode.qio120.build.flash_mode=dio
16262+
tamc_termod_s3.menu.FlashMode.qio120.build.boot=qio
16263+
tamc_termod_s3.menu.FlashMode.qio120.build.boot_freq=120m
16264+
tamc_termod_s3.menu.FlashMode.qio120.build.flash_freq=80m
16265+
tamc_termod_s3.menu.FlashMode.dio=DIO 80MHz
16266+
tamc_termod_s3.menu.FlashMode.dio.build.flash_mode=dio
16267+
tamc_termod_s3.menu.FlashMode.dio.build.boot=dio
16268+
tamc_termod_s3.menu.FlashMode.dio.build.boot_freq=80m
16269+
tamc_termod_s3.menu.FlashMode.dio.build.flash_freq=80m
16270+
tamc_termod_s3.menu.FlashMode.opi=OPI 80MHz
16271+
tamc_termod_s3.menu.FlashMode.opi.build.flash_mode=dout
16272+
tamc_termod_s3.menu.FlashMode.opi.build.boot=opi
16273+
tamc_termod_s3.menu.FlashMode.opi.build.boot_freq=80m
16274+
tamc_termod_s3.menu.FlashMode.opi.build.flash_freq=80m
16275+
16276+
tamc_termod_s3.menu.FlashSize.4M=4MB (32Mb)
16277+
tamc_termod_s3.menu.FlashSize.4M.build.flash_size=4MB
16278+
tamc_termod_s3.menu.FlashSize.8M=8MB (64Mb)
16279+
tamc_termod_s3.menu.FlashSize.8M.build.flash_size=8MB
16280+
tamc_termod_s3.menu.FlashSize.8M.build.partitions=default_8MB
16281+
tamc_termod_s3.menu.FlashSize.16M=16MB (128Mb)
16282+
tamc_termod_s3.menu.FlashSize.16M.build.flash_size=16MB
16283+
16284+
tamc_termod_s3.menu.LoopCore.1=Core 1
16285+
tamc_termod_s3.menu.LoopCore.1.build.loop_core=-DARDUINO_RUNNING_CORE=1
16286+
tamc_termod_s3.menu.LoopCore.0=Core 0
16287+
tamc_termod_s3.menu.LoopCore.0.build.loop_core=-DARDUINO_RUNNING_CORE=0
16288+
16289+
tamc_termod_s3.menu.EventsCore.1=Core 1
16290+
tamc_termod_s3.menu.EventsCore.1.build.event_core=-DARDUINO_EVENT_RUNNING_CORE=1
16291+
tamc_termod_s3.menu.EventsCore.0=Core 0
16292+
tamc_termod_s3.menu.EventsCore.0.build.event_core=-DARDUINO_EVENT_RUNNING_CORE=0
16293+
16294+
tamc_termod_s3.menu.USBMode.hwcdc=Hardware CDC and JTAG
16295+
tamc_termod_s3.menu.USBMode.hwcdc.build.usb_mode=1
16296+
tamc_termod_s3.menu.USBMode.default=USB-OTG (TinyUSB)
16297+
tamc_termod_s3.menu.USBMode.default.build.usb_mode=0
16298+
16299+
tamc_termod_s3.menu.CDCOnBoot.cdc=Enabled
16300+
tamc_termod_s3.menu.CDCOnBoot.cdc.build.cdc_on_boot=1
16301+
tamc_termod_s3.menu.CDCOnBoot.default=Disabled
16302+
tamc_termod_s3.menu.CDCOnBoot.default.build.cdc_on_boot=0
16303+
16304+
tamc_termod_s3.menu.MSCOnBoot.default=Disabled
16305+
tamc_termod_s3.menu.MSCOnBoot.default.build.msc_on_boot=0
16306+
tamc_termod_s3.menu.MSCOnBoot.msc=Enabled (Requires USB-OTG Mode)
16307+
tamc_termod_s3.menu.MSCOnBoot.msc.build.msc_on_boot=1
16308+
16309+
tamc_termod_s3.menu.DFUOnBoot.default=Disabled
16310+
tamc_termod_s3.menu.DFUOnBoot.default.build.dfu_on_boot=0
16311+
tamc_termod_s3.menu.DFUOnBoot.dfu=Enabled (Requires USB-OTG Mode)
16312+
tamc_termod_s3.menu.DFUOnBoot.dfu.build.dfu_on_boot=1
16313+
16314+
tamc_termod_s3.menu.UploadMode.default=UART0 / Hardware CDC
16315+
tamc_termod_s3.menu.UploadMode.default.upload.use_1200bps_touch=false
16316+
tamc_termod_s3.menu.UploadMode.default.upload.wait_for_upload_port=false
16317+
tamc_termod_s3.menu.UploadMode.cdc=USB-OTG CDC (TinyUSB)
16318+
tamc_termod_s3.menu.UploadMode.cdc.upload.use_1200bps_touch=true
16319+
tamc_termod_s3.menu.UploadMode.cdc.upload.wait_for_upload_port=true
16320+
16321+
tamc_termod_s3.menu.PartitionScheme.default=Default 4MB with spiffs (1.2MB APP/1.5MB SPIFFS)
16322+
tamc_termod_s3.menu.PartitionScheme.default.build.partitions=default
16323+
tamc_termod_s3.menu.PartitionScheme.defaultffat=Default 4MB with ffat (1.2MB APP/1.5MB FATFS)
16324+
tamc_termod_s3.menu.PartitionScheme.defaultffat.build.partitions=default_ffat
16325+
tamc_termod_s3.menu.PartitionScheme.default_8MB=8M Flash (3MB APP/1.5MB FAT)
16326+
tamc_termod_s3.menu.PartitionScheme.default_8MB.build.partitions=default_8MB
16327+
tamc_termod_s3.menu.PartitionScheme.default_8MB.upload.maximum_size=3342336
16328+
tamc_termod_s3.menu.PartitionScheme.minimal=Minimal (1.3MB APP/700KB SPIFFS)
16329+
tamc_termod_s3.menu.PartitionScheme.minimal.build.partitions=minimal
16330+
tamc_termod_s3.menu.PartitionScheme.no_ota=No OTA (2MB APP/2MB SPIFFS)
16331+
tamc_termod_s3.menu.PartitionScheme.no_ota.build.partitions=no_ota
16332+
tamc_termod_s3.menu.PartitionScheme.no_ota.upload.maximum_size=2097152
16333+
tamc_termod_s3.menu.PartitionScheme.noota_3g=No OTA (1MB APP/3MB SPIFFS)
16334+
tamc_termod_s3.menu.PartitionScheme.noota_3g.build.partitions=noota_3g
16335+
tamc_termod_s3.menu.PartitionScheme.noota_3g.upload.maximum_size=1048576
16336+
tamc_termod_s3.menu.PartitionScheme.noota_ffat=No OTA (2MB APP/2MB FATFS)
16337+
tamc_termod_s3.menu.PartitionScheme.noota_ffat.build.partitions=noota_ffat
16338+
tamc_termod_s3.menu.PartitionScheme.noota_ffat.upload.maximum_size=2097152
16339+
tamc_termod_s3.menu.PartitionScheme.noota_3gffat=No OTA (1MB APP/3MB FATFS)
16340+
tamc_termod_s3.menu.PartitionScheme.noota_3gffat.build.partitions=noota_3gffat
16341+
tamc_termod_s3.menu.PartitionScheme.noota_3gffat.upload.maximum_size=1048576
16342+
tamc_termod_s3.menu.PartitionScheme.huge_app=Huge APP (3MB No OTA/1MB SPIFFS)
16343+
tamc_termod_s3.menu.PartitionScheme.huge_app.build.partitions=huge_app
16344+
tamc_termod_s3.menu.PartitionScheme.huge_app.upload.maximum_size=3145728
16345+
tamc_termod_s3.menu.PartitionScheme.min_spiffs=Minimal SPIFFS (1.9MB APP with OTA/190KB SPIFFS)
16346+
tamc_termod_s3.menu.PartitionScheme.min_spiffs.build.partitions=min_spiffs
16347+
tamc_termod_s3.menu.PartitionScheme.min_spiffs.upload.maximum_size=1966080
16348+
tamc_termod_s3.menu.PartitionScheme.fatflash=16M Flash (2MB APP/12.5MB FAT)
16349+
tamc_termod_s3.menu.PartitionScheme.fatflash.build.partitions=ffat
16350+
tamc_termod_s3.menu.PartitionScheme.fatflash.upload.maximum_size=2097152
16351+
tamc_termod_s3.menu.PartitionScheme.app3M_fat9M_16MB=16M Flash (3MB APP/9MB FATFS)
16352+
tamc_termod_s3.menu.PartitionScheme.app3M_fat9M_16MB.build.partitions=app3M_fat9M_16MB
16353+
tamc_termod_s3.menu.PartitionScheme.app3M_fat9M_16MB.upload.maximum_size=3145728
16354+
tamc_termod_s3.menu.PartitionScheme.rainmaker=RainMaker
16355+
tamc_termod_s3.menu.PartitionScheme.rainmaker.build.partitions=rainmaker
16356+
tamc_termod_s3.menu.PartitionScheme.rainmaker.upload.maximum_size=3145728
16357+
16358+
tamc_termod_s3.menu.CPUFreq.240=240MHz (WiFi)
16359+
tamc_termod_s3.menu.CPUFreq.240.build.f_cpu=240000000L
16360+
tamc_termod_s3.menu.CPUFreq.160=160MHz (WiFi)
16361+
tamc_termod_s3.menu.CPUFreq.160.build.f_cpu=160000000L
16362+
tamc_termod_s3.menu.CPUFreq.80=80MHz (WiFi)
16363+
tamc_termod_s3.menu.CPUFreq.80.build.f_cpu=80000000L
16364+
tamc_termod_s3.menu.CPUFreq.40=40MHz
16365+
tamc_termod_s3.menu.CPUFreq.40.build.f_cpu=40000000L
16366+
tamc_termod_s3.menu.CPUFreq.20=20MHz
16367+
tamc_termod_s3.menu.CPUFreq.20.build.f_cpu=20000000L
16368+
tamc_termod_s3.menu.CPUFreq.10=10MHz
16369+
tamc_termod_s3.menu.CPUFreq.10.build.f_cpu=10000000L
16370+
16371+
tamc_termod_s3.menu.UploadSpeed.921600=921600
16372+
tamc_termod_s3.menu.UploadSpeed.921600.upload.speed=921600
16373+
tamc_termod_s3.menu.UploadSpeed.115200=115200
16374+
tamc_termod_s3.menu.UploadSpeed.115200.upload.speed=115200
16375+
tamc_termod_s3.menu.UploadSpeed.256000.windows=256000
16376+
tamc_termod_s3.menu.UploadSpeed.256000.upload.speed=256000
16377+
tamc_termod_s3.menu.UploadSpeed.230400.windows.upload.speed=256000
16378+
tamc_termod_s3.menu.UploadSpeed.230400=230400
16379+
tamc_termod_s3.menu.UploadSpeed.230400.upload.speed=230400
16380+
tamc_termod_s3.menu.UploadSpeed.460800.linux=460800
16381+
tamc_termod_s3.menu.UploadSpeed.460800.macosx=460800
16382+
tamc_termod_s3.menu.UploadSpeed.460800.upload.speed=460800
16383+
tamc_termod_s3.menu.UploadSpeed.512000.windows=512000
16384+
tamc_termod_s3.menu.UploadSpeed.512000.upload.speed=512000
16385+
16386+
tamc_termod_s3.menu.DebugLevel.none=None
16387+
tamc_termod_s3.menu.DebugLevel.none.build.code_debug=0
16388+
tamc_termod_s3.menu.DebugLevel.error=Error
16389+
tamc_termod_s3.menu.DebugLevel.error.build.code_debug=1
16390+
tamc_termod_s3.menu.DebugLevel.warn=Warn
16391+
tamc_termod_s3.menu.DebugLevel.warn.build.code_debug=2
16392+
tamc_termod_s3.menu.DebugLevel.info=Info
16393+
tamc_termod_s3.menu.DebugLevel.info.build.code_debug=3
16394+
tamc_termod_s3.menu.DebugLevel.debug=Debug
16395+
tamc_termod_s3.menu.DebugLevel.debug.build.code_debug=4
16396+
tamc_termod_s3.menu.DebugLevel.verbose=Verbose
16397+
tamc_termod_s3.menu.DebugLevel.verbose.build.code_debug=5
16398+
16399+
tamc_termod_s3.menu.EraseFlash.none=Disabled
16400+
tamc_termod_s3.menu.EraseFlash.none.upload.erase_cmd=
16401+
tamc_termod_s3.menu.EraseFlash.all=Enabled
16402+
tamc_termod_s3.menu.EraseFlash.all.upload.erase_cmd=-e
16403+
16404+
##############################################################
16405+
1619916406
dpu_esp32.name=DPU ESP32
1620016407

1620116408
dpu_esp32.bootloader.tool=esptool_py
+117Lines changed: 117 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,117 @@
1+
#ifndef Pins_Arduino_h
2+
#define Pins_Arduino_h
3+
4+
#include <stdint.h>
5+
#include "soc/soc_caps.h"
6+
7+
#define USB_VID 0x303a
8+
#define USB_PID 0x1001
9+
10+
#define EXTERNAL_NUM_INTERRUPTS 46
11+
#define NUM_DIGITAL_PINS 48
12+
#define NUM_ANALOG_INPUTS 20
13+
14+
// Some boards have too low voltage on this pin (board design bug)
15+
// Use different pin with 3V and connect with 48
16+
// and change this setup for the chosen pin (for example 38)
17+
static const uint8_t LED_BUILTIN = SOC_GPIO_PIN_COUNT+48;
18+
#define BUILTIN_LED LED_BUILTIN // backward compatibility
19+
#define LED_BUILTIN LED_BUILTIN
20+
#define RGB_BUILTIN LED_BUILTIN
21+
#define RGB_BRIGHTNESS 64
22+
23+
#define analogInputToDigitalPin(p) (((p)<20)?(analogChannelToDigitalPin(p)):-1)
24+
#define digitalPinToInterrupt(p) (((p)<48)?(p):-1)
25+
#define digitalPinHasPWM(p) (p < 46)
26+
27+
static const uint8_t TX = 43;
28+
static const uint8_t RX = 44;
29+
30+
static const uint8_t SDA = 8;
31+
static const uint8_t SCL = 9;
32+
33+
static const uint8_t SS = 10;
34+
static const uint8_t MOSI = 11;
35+
static const uint8_t MISO = 13;
36+
static const uint8_t SCK = 12;
37+
38+
static const uint8_t A0 = 1;
39+
static const uint8_t A1 = 2;
40+
static const uint8_t A2 = 3;
41+
static const uint8_t A3 = 4;
42+
static const uint8_t A4 = 5;
43+
static const uint8_t A5 = 6;
44+
static const uint8_t A6 = 7;
45+
static const uint8_t A7 = 8;
46+
static const uint8_t A8 = 9;
47+
static const uint8_t A9 = 10;
48+
static const uint8_t A10 = 11;
49+
static const uint8_t A11 = 12;
50+
static const uint8_t A12 = 13;
51+
static const uint8_t A13 = 14;
52+
static const uint8_t A14 = 15;
53+
static const uint8_t A15 = 16;
54+
static const uint8_t A16 = 17;
55+
static const uint8_t A17 = 18;
56+
static const uint8_t A18 = 19;
57+
static const uint8_t A19 = 20;
58+
59+
static const uint8_t T1 = 1;
60+
static const uint8_t T2 = 2;
61+
static const uint8_t T3 = 3;
62+
static const uint8_t T4 = 4;
63+
static const uint8_t T5 = 5;
64+
static const uint8_t T6 = 6;
65+
static const uint8_t T7 = 7;
66+
static const uint8_t T8 = 8;
67+
static const uint8_t T9 = 9;
68+
static const uint8_t T10 = 10;
69+
static const uint8_t T11 = 11;
70+
static const uint8_t T12 = 12;
71+
static const uint8_t T13 = 13;
72+
static const uint8_t T14 = 14;
73+
74+
static const uint8_t BAT_LV = 1;
75+
static const uint8_t CHG = 2;
76+
static const uint8_t TFT_CS = 10;
77+
static const uint8_t TFT_DC = 18;
78+
static const uint8_t TFT_RST = 14;
79+
static const uint8_t TFT_BCKL = 48; // TFT Backlight is enabled by soldering JP2 together
80+
static const uint8_t SD_CS = 21;
81+
static const uint8_t SD_CD = 47; // uSD Card Detect is enabled by soldering JP1 together.
82+
83+
#define DISPLAY_PORTRAIT 2
84+
#define DISPLAY_LANDSCAPE 3
85+
#define DISPLAY_PORTRAIT_FLIP 0
86+
#define DISPLAY_LANDSCAPE_FLIP 1
87+
88+
#define DISPLAY_WIDTH 240
89+
#define DISPLAY_HEIGHT 320
90+
91+
/**
92+
* Get battery voltage in volts
93+
* @return Battery voltage in volts
94+
*/
95+
float getBatteryVoltage();
96+
/**
97+
* Get battery level in percent
98+
* @return Battery level in percent(0-100)
99+
*/
100+
float getBatteryCapacity();
101+
/**
102+
* Get battery charge state
103+
* @return Battery charge state(true=charging, false=not charging)
104+
*/
105+
bool getChargingState();
106+
/**
107+
* Set on charge start callback
108+
* @param func On charge start Callback function
109+
*/
110+
void setOnChargeStart(void (*func)());
111+
/**
112+
* Set on charge end callback
113+
* @param func On charge end Callback function
114+
*/
115+
void setOnChargeEnd(void (*func)());
116+
117+
#endif /* Pins_Arduino_h */

‎variants/tamc_termod_s3/variant.cpp

Copy file name to clipboard
+38Lines changed: 38 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,38 @@
1+
#include "Arduino.h"
2+
3+
float getBatteryVoltage() {
4+
int analogVolt = analogReadMilliVolts(1);
5+
float voltage = analogVolt / 1000.0;
6+
voltage = voltage * (100.0+200.0) / 200.0;
7+
return voltage;
8+
}
9+
10+
float getBatteryCapacity() {
11+
float voltage = getBatteryVoltage();
12+
float capacity = (voltage - 3.3) / (4.2 - 3.3) * 100.0;
13+
capacity = constrain(capacity, 0, 100);
14+
return capacity;
15+
}
16+
17+
bool getChargingState() {
18+
pinMode(CHG, INPUT_PULLUP);
19+
return !digitalRead(CHG);
20+
}
21+
22+
void (*__onChargeStart__)();
23+
void (*__onChargeEnd__)();
24+
void setOnChargeStart(void (*func)()) { __onChargeStart__ = func; }
25+
void setOnChargeEnd(void (*func)()) { __onChargeEnd__ = func; }
26+
27+
void ARDUINO_ISR_ATTR chargeIsr() {
28+
if (getChargingState()) {
29+
__onChargeStart__();
30+
} else {
31+
__onChargeEnd__();
32+
}
33+
}
34+
35+
extern "C" void initVariant(void){
36+
attachInterrupt(CHG, chargeIsr, CHANGE);
37+
analogReadResolution(12);
38+
}

0 commit comments

Comments
0 (0)
Morty Proxy This is a proxified and sanitized view of the page, visit original site.