Skip to content

denko-rb/arduino-yaml-board-maps

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Arduino Board Maps in YAML Format

The aim of this script is to map common identifiers used in the Arduino IDE to their integer pin numbers. For example, on many Arduino boards, the analog input pin labeled A0 maps to an integer pin number of 14, but this isn't always the case. With the large variety of boards the Arduino IDE supports, it's difficult to keep track of mappings manually.

How to identify the board?

Along with the maps inside the yaml folder, there is BoardMap.h. Include that in a sketch, and it will #define BOARD_MAP, based on your board selection in Arduino. The value of BOARD_MAP is the filename for that board's map, minus the .yml extension.

Why map the pins?

If the sketch tells a remote machine its BOARD_MAP, the map can be loaded from its file. From there, the remote machine uses it to translate between pin identifiers and integers, before sending instructions to the board, or receiving messages from it.

This is the exact use case this was deisgned for, in support of the denko Ruby gem. It allows more intuitive pin referencing in Ruby, while simplifying the Arduino sketch so it only handles pins as integers.

Supported Arduino Cores

Mappings

  • A0 analog input pins (sequential on AVR, disordered on others)
  • DAC0 digital-to-analog-pins
  • D0 pins (some on RP2040. Many on ESP8266 where DX doesn't map to GPIOX)
  • T0 pins (capacitive touch pins on ESP32)
  • SCL, SDA, SCLX, SDAX, default and numbered hardware I2C pins
  • MOSI, MISO, SCK, SS, MOSIX, MISOX, SCKX, SSX, default and numbered hardware SPI pins
  • LED_BUILTIN which is usually defined for the on-board LED

TODO: Add UART and CAN?

Usage

Clone or download this repo. Use BoardMap.h and all the files inside yaml as descibed above.

Each map is a flat dictionary where each key (an identifier) maps to one integer.

Note: All keys are prefixed with :, so they automatically translate to Ruby symbols when loaded.

Development

Be warned. This is mostly a hack that runs a bunch of regex matches on boards.txt and header files from each Arduino core. 🤷‍♂️

  • Clone this repo.
  • Clone the submodules inside the core folder with git submodule init and git submodule update. No need for recursion, but will still be close to 4GB.
  • Make changes and ruby run.rb to udpate BoardMap.h and all the YAML files.

About

YAML formatted pin maps for Arduino-supported boards

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published