Firmata Library
The Firmata library implements the Firmata protocol for communicating with software on the host computer.
The Firmata library implements the Firmata protocol for communicating with software on the host computer. This allows you to write custom firmware without having to create your own protocol and objects for the programming environment that you are using.
To use this library
1#include <Firmata.h>Methods
1begin(); //start the library2begin(long); //start the library and override the default baud rate3begin(Stream &s); // start the library using a [Stream](http://www.arduino.cc/en/Reference/Stream) other than Serial (eg Serial1 or EthernetClient)4printVersion(); //send the protocol version to the host computer5blinkVersion(): //blink the protocol version on the build in LED (typically pin 13)6printFirmwareVersion(); //send the firmware name and version to the host computer7setFirmwareVersion(byte major, byte minor); //set the firmware name and version, using the sketch's filename, minus the '.ino'8setFirmwareNameAndVersion(const char *name, byte major, byte minor); //set both the name and version of the firmwareSending Messages
Sending Messages1sendAnalog(byte pin, int value); //send an analog message2sendDigitalPort(byte portNumber, int portData); //send an 8-bit port in a single digital message3sendString(const char* string); //send a string to the host computer4sendString(byte command, byte bytec, byte *bytev); //send a string to the host computer using a custom command type5sendSysex(byte command, byte bytec, byte* bytev); //send a command with an arbitrary array of bytes6write(byte c); //write a byte to the StreamReceiving Messages
Receiving Messages1available(); //check to see if there are any incoming messages in the buffer2processInput(); //process incoming messages from the buffer, sending the data to any registered callback functions3attach(byte command, callbackFunction myFunction); //attach a function to an incoming message type4detach(byte command); //detach a function from an incoming message typeUtility methods
1sendValueAsTwo7bitBytes(int value); //writes value as 2 bytes2startSysex(void); //starts a sysex message3endSysex(void); //ends a sysex messageCallback Functions
In order to attach your function to a message type, your function must match the standard callback function. There are currently three types of callback functions in Firmata: generic, string, and sysex.
generic
1void callbackFunction(byte pin, int value);system_reset
1void systemResetCallbackFunction(void);string
1void stringCallbackFunction(char *myString);sysex
1void sysexCallbackFunction(byte command, byte byteCount, byte *arrayPointer);Message Types
Message TypesThere are various message types that you can attach callback functions to.
1ANALOG_MESSAGE //the analog value for a single pin2DIGITAL_MESSAGE //8-bits of digital pin data (one port)3REPORT_ANALOG //enable/disable the reporting of an analog pin4REPORT_DIGITAL //enable/disable the reporting of a digital port5SET_PIN_MODE //change the pin mode between INPUT/OUTPUT/PWM/etc.6STRING_DATA //C-style strings, uses stringCallbackFunction for the function type7SYSEX_START //generic, arbitrary length messages (via MIDI SysEx protocol), uses sysexCallbackFunction for the function type8SYSTEM_RESET //message to reset firmware to its default state, uses systemResetCallbackFunction for the function typeExample
This example shows how to send and receive analog messages using Firmata.
1#include <Firmata.h>2
3byte analogPin;4
5void analogWriteCallback(byte pin, int value)6{7  pinMode(pin, OUTPUT);8  analogWrite(pin, value);9}10
11void setup()12{13  Firmata.setFirmwareVersion(FIRMATA_MAJOR_VERSION, FIRMATA_MINOR_VERSION);14  Firmata.attach(ANALOG_MESSAGE, analogWriteCallback);15  Firmata.begin();16}17
18void loop()19{20  while (Firmata.available()) {21    Firmata.processInput();22  }23  for (analogPin = 0; analogPin < TOTAL_ANALOG_PINS; analogPin++) {24    Firmata.sendAnalog(analogPin, analogRead(analogPin));25  }26}Suggested changes
The content on docs.arduino.cc is facilitated through a public GitHub repository. You can read more on how to contribute in the contribution policy.
License
The Arduino documentation is licensed under the Creative Commons Attribution-Share Alike 4.0 license.