1#ifndef SERIAL_WOMBAT_H__
2#define SERIAL_WOMBAT_H__
41#define SW_LE16(_a) (uint8_t)((_a) & 0xFF), (uint8_t)((_a) >>8)
44#define SW_LE32(_a) (uint8_t)((_a) & 0xFF), (uint8_t)((_a) >>8) , (uint8_t)((_a) >>16), (uint8_t)((_a) >>24)
46#define ARRAY_UINT32(_array,_index) ((((uint32_t) _array[_index +3])<<24) + (((uint32_t) _array[_index +2])<<16) + (((uint32_t) _array[_index +1])<<8) + _array[_index])
47#define SW18AB_LATEST_FIRMWARE 214
48#define SW08B_LATEST_FIRMWARE 215
49#define SW4B_LATEST_FIRMWARE 203
178#define ERROR_HOST_INCORRECT_NUMBER_BYTES_WRITTEN 0x10000
179#define ERROR_HOST_DATA_TOO_LONG 0x10001
180#define ERROR_HOST_NACK_ADDRESS 0x10002
181#define ERROR_HOST_NACK_DATA 0x10003
182#define ERROR_HOST_OTHER_I2C_ERROR 0x10004
184#define WOMBAT_MAXIMUM_PINS 20
299 char version[8] = { 0 };
300 HardwareSerial * Serial = NULL;
301 TwoWire* i2cInterface = NULL;
306 bool _asleep =
false;
308 bool _currentlyCommunicating =
false;
359 uint8_t tx[8] = { 200,pin,0,0,0,0,0,0x55 };
361 switch (_pinmode[pin])
374 else if (highLow == HIGH)
395 tx[6] = _openDrain[pin];
396 tx[5] = _pullDown[pin];
402 int16_t retvalue = -1;
414 if (version[0] ==
'S' && version[1] ==
'0' && version[2] ==
'4')
444 if (version[0] ==
'S' && version[1] ==
'0' && version[2] ==
'4')
463 uint16_t result = rx[1] -
'0';
465 result += rx[2] -
'0';
467 result += rx[3] -
'0';
469 result += rx[4] -
'0';
471 result += rx[5] -
'0';
492 int16_t
begin(HardwareSerial& serial,
bool reset =
true)
495 Serial->begin(115200);
496 Serial->setTimeout(2);
497 Serial->write((uint8_t*)
"UUUUUUUU", 8);
499 while (Serial->read() >= 0);
523 int16_t
begin(uint8_t i2cAddress);
538 int16_t
begin(TwoWire& wire, uint8_t i2cAddress,
bool reset =
true)
540 i2cInterface = &wire;
543 Wire.beginTransmission(i2cAddress);
544 int error = Wire.endTransmission();
601 int sendPacket(uint8_t tx[], uint8_t rx[],
bool retryIfEchoDoesntMatch, uint8_t beginningBytesToMatch = 8, uint8_t endBytesToMatch = 0);
611 int sendPacket(uint8_t tx[],
bool retryIfEchoDoesntMatch);
634 uint8_t tx[] = {
'V',0x55,0x55,0x55,0x55,0x55,0x55,0x55 };
637 memcpy(version, &rx[1], 7);
639 memcpy(
model, &rx[1], 3);
691 uint8_t tx[] = { 0x81,pin,255,255,0x55,0x55,0x55,0x55 };
694 return(rx[2] + (uint16_t)rx[3] * 256);
718 uint8_t tx[] = { 0x82,pin,(uint8_t)(value & 0xFF),(uint8_t)(value >> 8) ,255,0x55,0x55,0x55 };
721 return (rx[2] + rx[3] * 256);
753 uint32_t mv = 1024 * 65536 / counts;
782 result = result - 65536;
784 return ((int16_t)result);
800 uint8_t tx[9] =
"ReSeT!#*";
813 void pinMode(uint8_t pin, uint8_t mode,
bool pullDown =
false,
bool openDrain =
false)
819 _pullDown[pin] = openDrain;
820 _openDrain[pin] = openDrain;
821 _pinmode[pin] = mode;
884 uint8_t dutyCycleLow = 0;
906 uint8_t tx[8] = {
'V',0x55,0x55,0x55,0x55,0x55,0x55,0x55 };
909 if (rx[0] ==
'V' && (rx[1] ==
'S' || rx[1] ==
'B'))
934 uint8_t tx[8] = { 0x81,67,68,0x55,0x55,0x55,0x55,0x55 };
937 uint32_t returnval = rx[2] + (((uint32_t)rx[3]) << 8) + (((uint32_t)rx[4]) << 16) + (((uint32_t)rx[5]) << 24);
965 uint8_t tx[] =
"BoOtLoAd";
991 uint8_t tx[8] = { 0xA0,
SW_LE16(
address),0x55,0x55,0x55,0x55,0x55 };
1043 return(((uint32_t)rx[4]) + (((uint32_t)rx[5]) <<8) + (((uint32_t)rx[6]) <<16) + (((uint32_t)rx[7]) <<24));
1059 uint16_t bytesRead = 0;
1060 while (bytesRead < count)
1067 for (
int i = 1; i < 8; ++i)
1069 buffer[bytesRead] = rx[i];
1072 if (bytesRead >= count)
1097 uint8_t tx[8] = {
'S',
'l',
'E',
'e',
'P',
'!',
'#',
'*'};
1105 uint8_t tx[8] = {
'!',
'!',
'!',
'!',
'!',
'!',
'!',
'!' };
1112 return (
model[1] ==
'1' &&
model[2] ==
'8');
1117 return (
model[1] ==
'0' &&
model[2] ==
'8');
1167 uint16_t bytesSent = 0;
1174 uint8_t bytesToSend = 4;
1177 bytesToSend = (uint8_t)count;
1185 uint8_t tx[8] = { 0x84,
SW_LE16(index), bytesToSend,0x55,0x55,0x55,0x55 };
1189 for (i = 0; i < bytesToSend; ++i)
1191 tx[4 + i] = buffer[i];
1198 bytesSent = bytesToSend;
1204 uint8_t tx[8] = { 0x85,0x55,0x55,0x55,0x55,0x55,0x55,0x55 };
1207 for (i = 0; i < 7; ++i)
1209 tx[1 + i] = buffer[bytesSent + i];
1222 uint8_t bytesToSend = 4;
1225 bytesToSend = (uint8_t)count;
1233 uint8_t tx[8] = { 0x84,
SW_LE16(index + bytesSent), bytesToSend,0x55,0x55,0x55,0x55 };
1237 for (i = 0; i < bytesToSend; ++i)
1239 tx[4 + i] = buffer[i + bytesSent];
1246 bytesSent += bytesToSend;
1305 static uint8_t
find(
bool keepTrying =
false)
1309 for (
int i2cAddress = 0x60; i2cAddress <= 0x6F; ++i2cAddress)
1311 Wire.beginTransmission(i2cAddress);
1312 int error = Wire.endTransmission();
1317 uint8_t tx[8] = {
'V',0x55,0x55,0x55,0x55,0x55,0x55,0x55 };
1319 Wire.beginTransmission(i2cAddress);
1321 Wire.endTransmission();
1322 Wire.requestFrom((uint8_t)i2cAddress, (uint8_t)8);
1325 while (Wire.available() && count < 8)
1327 rx[count] = Wire.read();
1332 if (rx[0] ==
'V' && rx[1] ==
'S' || rx[1]==
'B')
1340 }
while (keepTrying);
1358 for (
int i = 1; i < 8; ++i)
1381 errorHandler = handler;
1390 int16_t
echo(uint8_t data[], uint8_t count = 7)
1392 uint8_t tx[] =
"!UUUUUUU";
1393 for (
int i = 0; i < 7 && i < count; ++i)
1395 tx[i + 1] = (uint8_t)data[i];
1403 int length = strlen(data);
1404 uint8_t tx[] =
"!UUUUUUU";
1405 for (
int i = 0; i < 7 && i < length; ++i)
1407 tx[i + 1] = (uint8_t)data[i];
1433 for (
int i = 0; i < 32; ++i)
1436 if ((val & 0xFF) != 0xFF)
1438 data[i ] = (char)(val & 0xFF);
1474 uint32_t lastMillis = 0;
1475 uint32_t lastFrames = 0;
1487 uint32_t m = millis();
1488 if (lastMillis == 0)
1499 frames += frameslsb;
1500 lastFrames = frames;
1503 else if ((m - lastMillis) < 10000)
1507 else if (m < lastMillis)
1514 uint32_t diff = m - lastMillis;
1525 frames += frameslsb;
1526 uint32_t framesDif = frames - lastFrames;
1528 if (diff > framesDif )
1537 else if (diff < framesDif)
1549 lastFrames = frames;
#define SW18AB_LATEST_FIRMWARE
#define WOMBAT_MAXIMUM_PINS
void SerialWombatSerialErrorHandlerBrief(uint16_t error, SerialWombatChip *sw)
a sample error handler that can be registered with registerErrorHandler to report protocol errors on ...
#define SW_LE16(_a)
Convert a uint16_t to two bytes in little endian format for array initialization.
@ COMMAND_CAPTURE_STARTUP_SEQUENCE
(0xB6)
@ COMMAND_BINARY_WRITE_FLASH
(0xA4)
@ COMMAND_BINARY_READ_USER_BUFFER
(0x83)
@ COMMAND_BINARY_QUEUE_INFORMATION
(0x94)
@ CONFIGURE_PIN_MODE0
(200)
@ COMMAND_BINARY_QUEUE_INITIALIZE
(0x90)
@ COMMAND_BINARY_SET_PIN_BUFFFER
(0x82)
@ COMMAND_ENABLE_2ND_UART
(0xA6)
@ COMMAND_UART1_RX_7BYTES
(0xB3)
@ COMMAND_ADJUST_FREQUENCY
(0xB7)
@ COMMAND_BINARY_WRITE_USER_BUFFER
(0x84)
@ CONFIGURE_PIN_MODE3
(203)
@ CONFIGURE_PIN_MODE4
(204)
@ CONFIGURE_PIN_MODE_DISABLE
(219)
@ CMD_READ_BUFFER_ASCII
('G')
@ COMMAND_BINARY_QUEUE_CLONE
(0x95)
@ COMMAND_BINARY_QUEUE_ADD_BYTES
(0x91)
@ COMMAND_BINARY_READ_EEPROM
(0xA2)
@ CONFIGURE_PIN_MODE5
(205)
@ COMMAND_BINARY_QUEUE_ADD_7BYTES
(0x92)
@ CONFIGURE_PIN_MODE8
(208)
@ CONFIGURE_PIN_MODE_HW_0
(220)
@ CONFIGURE_PIN_MODE6
(206)
@ CMD_SET_BUFFER_ASCII
('S')
@ CONFIGURE_PIN_MODE2
(202)
@ COMMAND_UART0_TX_7BYTES
(0xB0)
@ COMMAND_BINARY_QUEUE_READ_BYTES
(0x93)
@ CONFIGURE_PIN_INPUTPROCESS
(211)
@ CONFIGURE_PIN_MODE10
(210)
@ COMMAND_BINARY_WRITE_USER_BUFFER_CONTINUE
(0x85)
@ COMMAND_BINARY_CONFIG_DATALOGGER
(0x96)
@ CONFIGURE_PIN_MODE9
(209)
@ COMMAND_UART1_TX_7BYTES
(0xB2)
@ COMMAND_UART0_RX_7BYTES
(0xB1)
@ COMMAND_BINARY_RW_PIN_MEMORY
(0xB5)
@ COMMAND_READ_LAST_ERROR_PACKET
(0xA7)
@ COMMAND_BINARY_WRITE_RAM
(0xA3)
@ COMMAND_BINARY_READ_RAM
(0xA0)
@ COMMAND_BINARY_TEST_SEQUENCE
(0xB4)
@ CONFIGURE_CHANNEL_MODE_HW_2
(222)
@ COMMAND_BINARY_READ_PIN_BUFFFER
(0x81)
@ CONFIGURE_CHANNEL_MODE_HW_1
(221)
@ COMMAND_BINARY_READ_FLASH
(0xA1)
@ CONFIGURE_CHANNEL_MODE_HW_3
(223)
@ COMMAND_SET_PIN_HW
(0xB8)
@ COMMAND_CALIBRATE_ANALOG
(0xA5)
@ CONFIGURE_PIN_MODE7
(207)
@ CONFIGURE_PIN_MODE1
(201)
@ COMMAND_BINARY_PIN_POLL_THRESHOLD
(0x8F)
@ CONFIGURE_PIN_OUTPUTSCALE
(210)
@ COMMAND_BINARY_CONFIGURE
(0x9F)
#define SW08B_LATEST_FIRMWARE
#define SW_LE32(_a)
Convert a uint32_t to four bytes in little endian format for array initialization.
#define SW4B_LATEST_FIRMWARE
@ PIN_MODE_PULSE_ON_CHANGE
(25)
@ PIN_MODE_FRAME_TIMER
(21)
@ PIN_MODE_PULSETIMER
(18)
@ PIN_MODE_PS2KEYBOARD
(32)
@ PIN_MODE_FREQUENCY_OUTPUT
(36)
@ PIN_MODE_QUEUED_PULSE_OUTPUT
(34)
@ PIN_MODE_SW18AB_CAPTOUCH
(22)
@ PIN_MODE_LIQUIDCRYSTAL
(28)
@ PIN_MODE_QUADRATUREENCODER
(5)
@ PIN_MODE_UART_RX_TX
(17)
@ PIN_MODE_HS_COUNTER
< (29)
@ PIN_MODE_PROTECTED_OUTPUT
(8)
@ PIN_MODE_ANALOGINPUT
(2)
@ PIN_MODE_UART1_RX_TX
(23)
@ PIN_MODE_I2C_CONTROLLER
(33)
@ PIN_MODE_RESISTANCEINPUT
(24)
@ PIN_MODE_INPUT_PROCESSOR
(14)
@ PIN_MODE_ULTRASONIC_DISTANCE
(27)
@ PIN_MODE_THROUGHPUT_CONSUMER
(4)
@ PIN_MODE_MATRIX_KEYPAD
(15)
void SerialWombatSerialErrorHandlerVerbose(uint16_t error, SerialWombatChip *sw)
SerialWombatDataSource
A list of Serial Wombat public data sources.
@ SW_DATA_SOURCE_PIN_10
(10) 16 bit public data provided by Pin 10
@ SW_DATA_SOURCE_VBG_COUNTS_VS_VREF
(76) A/D conversion of VBG against VRef . Used for mfg calibration
@ SW_DATA_SOURCE_PIN_5
(5) 16 bit public data provided by Pin 5
@ SW_DATA_SOURCE_PIN_14
(14) 16 bit public data provided by Pin 14
@ SW_DATA_SOURCE_PIN_13
(13) 16 bit public data provided by Pin 13
@ SW_DATA_SOURCE_1024mvCounts
(66) The number of ADC counts that result from a 1.024V reading
@ SW_DATA_SOURCE_TEMPERATURE
(70)The internal core temperature expressed in 100ths deg C
@ SW_DATA_SOURCE_PIN_1
(1) 16 bit public data provided by Pin 1
@ SW_DATA_SOURCE_FRAMES_RUN_LSW
(67) The number of frames run since reset, least significant 16 bits
@ SW_DATA_SOURCE_VCC_mVOLTS
(75) The system source voltage in mV
@ SW_DATA_SOURCE_PIN_11
(11) 16 bit public data provided by Pin 11
@ SW_DATA_SOURCE_8SEC_SAW
(174)Sawtooth wave that goes from 0 to 65535 to 0 every 8192 frames
@ SW_DATA_SOURCE_PIN_4_MV
(104) Pin 4 public output expressed in mV (for analog modes only)
@ SW_DATA_SOURCE_PIN_6
(6) 16 bit public data provided by Pin 6
@ SW_DATA_SOURCE_PIN_15
(15) 16 bit public data provided by Pin 15
@ SW_DATA_SOURCE_LFSR
(78) A Linear Feedback Shift Register that produces a Pseudo random sequence of 16 bit values
@ SW_DATA_SOURCE_OVERRUN_FRAMES
(69) The number of frames that ran more than 1mS
@ SW_DATA_SOURCE_PIN_9
(9) 16 bit public data provided by Pin 9
@ SW_DATA_SOURCE_PIN_12
(12) 16 bit public data provided by Pin 12
@ SW_DATA_SOURCE_PIN_3_MV
(103) Pin 3 public output expressed in mV (for analog modes only)
@ SW_DATA_SOURCE_PIN_8
(8) 16 bit public data provided by Pin 8
@ SW_DATA_SOURCE_PIN_18
(18) 16 bit public data provided by Pin 18
@ SW_DATA_SOURCE_8SEC_SQUARE
(173)Square wave that alternates between 0 and 65535 every 4096 frames
@ SW_DATA_SOURCE_0x55
(85) 0x55 is a reserved value for resyncing. Returns 0x55 0x55
@ SW_DATA_SOURCE_2SEC_SQUARE
(170)Square wave that alternates between 0 and 65535 every 1024 frames
@ SW_DATA_SOURCE_PIN_18_MV
(118) Pin 18 public output expressed in mV (for analog modes only)
@ SW_DATA_SOURCE_ERRORS
(72)The number of incoming packets that have caused errors since reset (rolls over at 65535)
@ SW_DATA_SOURCE_PIN_0_MV
(100) Pin 0 public output expressed in mV (for analog modes only)
@ SW_DATA_SOURCE_PIN_4
(4) 16 bit public data provided by Pin 4
@ SW_DATA_SOURCE_SYSTEM_UTILIZATION
(74) A number between 0 and 65535 that scales to the average length of pin processing frames between ...
@ SW_DATA_SOURCE_PACKETS_RECEIVED
(71) The nubmer of incoming command packets that have been processed since reset (rolls over at 65535...
@ SW_DATA_SOURCE_1HZ_SQUARE
(167) Square wave that alternates between 0 and 65535 every 512 frames
@ SW_DATA_SOURCE_2SEC_SAW
(171)Sawtooth wave that goes from 0 to 65535 to 0 every 2048 frames
@ SW_DATA_SOURCE_PIN_17_MV
(117) Pin 17 public output expressed in mV (for analog modes only)
@ SW_DATA_SOURCE_PIN_1_MV
(101) Pin 1 public output expressed in mV (for analog modes only)
@ SW_DATA_SOURCE_DROPPED_FRAMES
(73) The number of times since reset that a frame ran so far behind that it crossed two subsequent 1m...
@ SW_DATA_SOURCE_PIN_16_MV
(116) Pin 16 public output expressed in mV (for analog modes only)
@ SW_DATA_SOURCE_PIN_0
(0) 16 bit public data provided by Pin 0
@ SW_DATA_SOURCE_PIN_2
(2) 16 bit public data provided by Pin 2
@ SW_DATA_SOURCE_PIN_2_MV
(102) Pin 2 public output expressed in mV (for analog modes only)
@ SW_DATA_SOURCE_PIN_16
(16) 16 bit public data provided by Pin 16
@ SW_DATA_SOURCE_1HZ_SAW
(168) Sawtooth wave that goes from 0 to 65535 to 0 every 1024 frames
@ SW_DATA_SOURCE_PIN_19_MV
(119) Pin 19 public output expressed in mV (for analog modes only)
@ SW_DATA_SOURCE_PIN_7
(7) 16 bit public data provided by Pin 7
@ SW_DATA_SOURCE_FRAMES_RUN_MSW
(68) The number of frames run since reset, most significant 16 bits
@ SW_DATA_SOURCE_INCREMENTING_NUMBER
(65) An number that increments each time it is accessed.
@ SW_DATA_SOURCE_PIN_19
(19) 16 bit public data provided by Pin 19
@ SW_DATA_SOURCE_2HZ_SAW
(165) Sawtooth wave that goes from 0 to 65535 to 0 every 512 frames
@ SW_DATA_SOURCE_PIN_17
(17) 16 bit public data provided by Pin 17
@ SW_DATA_SOURCE_PIN_3
(3) 16 bit public data provided by Pin 3
@ SW_DATA_SOURCE_65SEC_SAW
(177 )Sawtooth wave that goes from 0 to 65535 to 0 every 65536 frames
@ SW_DATA_SOURCE_NONE
(255 ) Used to mean "No Source Selected"
@ SW_DATA_SOURCE_2HZ_SQUARE
(164) Square wave that alternates between 0 and 65535 every 256 frames
@ SW_DATA_SOURCE_65SEC_SQUARE
(176) Square wave that alternates between 0 and 65535 every 32768 frames
#define ARRAY_UINT32(_array, _index)
void(* SerialWombatErrorHandler_t)(uint16_t errorNumber, SerialWombatChip *sw)
Class for a Serial Wombat chip. Each Serial Wombat chip on a project should have its own instance.
uint8_t uniqueIdentifier[16]
bool isLatestFirmware(void)
uint8_t address
The I2C address of the SerialWombatChip instance.
void wake()
Called to send a dummy packet to the Serial Wombat chip to wake it from sleep and ready it for other ...
uint8_t uniqueIdentifierLength
uint32_t comparePublicDataToThreshold(uint16_t threshold=0)
int16_t echo(uint8_t data[], uint8_t count=7)
void digitalWrite(uint8_t pin, uint8_t val)
Set an output pin High or Low.
uint32_t readFlashAddress(uint32_t address)
Read Address from Flash based on 32 bit address.
bool inBoot
Set to true if boot mode is indicated by a version query.
bool isSW08()
Returns true if the instance received a model number corresponding to the Serial Wombat 08 series of ...
void readUniqueIdentifier()
char * readVersion(void)
Request version string (combined model and firmware) and return pointer to it.
void configureDigitalPin(uint8_t pin, uint8_t highLow)
uint16_t readPublicData(uint8_t pin)
Read the 16 Bit public data associated with a Serial Wombat Pin Mode.
uint8_t fwVersion[4]
Contains the last firmware Version retreived by queryVersion() as a zero-terminated string.
uint8_t communicationErrorRetries
How many times to retry a packet if communcation bus (such as I2C) error.
uint16_t readOverflowFrames()
Get the number of times an overflow Frame has occured.
static uint8_t find(bool keepTrying=false)
Search the I2C Bus addresses 0x68 to 0x6F for I2C devices, and test to see if they respond to Serial ...
void readDeviceIdentifier()
int writeUserBuffer(uint16_t index, uint8_t *buffer, uint16_t count)
Write bytes to the User Memory Buffer in the Serial Wombat chip.
int16_t readTemperature_100thsDegC(void)
Measure the Serial Wombat chip's internal temperature.
int sendPacketNoResponse(uint8_t tx[])
Send an 8 byte packet to the Serial Wombat chip, don't wait for a response.
uint8_t readRamAddress(uint16_t address)
Read Address from RAM based on 16 bit address.
int16_t readUserBuffer(uint16_t index, uint8_t *buffer, uint16_t count)
Read data from the Serial Wombat 18AB's internal RAM buffer.
bool isSW18()
Returns true if the instance received a model number corresponding to the Serial Wombat 18 series of ...
int16_t lastErrorCode
The last error code returned as part of a protocol error message expressed as a positive integer.
int16_t readBrand(char *data)
void pinMode(uint8_t pin, uint8_t mode, bool pullDown=false, bool openDrain=false)
Set a pin to INPUT or OUTPUT, with options for pull Ups and open Drain settings.
int16_t setThroughputPin(uint8_t pin)
Set a pin to be a throughput monitoring pin.
int16_t begin(HardwareSerial &serial, bool reset=true)
initialize a Serial Wombat chip to use a Serial Interface.
int sendPacket(uint8_t tx[], uint8_t rx[])
Send an 8 byte packet to the Serial Wombat chip and wait for 8 bytes back.
uint32_t readVersion_uint32(void)
Request version as a uint32.
uint16_t writePublicData(uint8_t pin, uint16_t value)
Write a 16 bit value to a Serial Wombat pin Mode.
uint16_t readSupplyVoltage_mV(void)
Measure the Serial Wombat chip's Supply voltage.
int16_t writeFlashRow(uint32_t address)
Writes a row in flash. Intended for use with the Bootloader, not by end users outside of bootloading ...
int writeUserBuffer(uint16_t index, char *s)
Write bytes to the User Memory Buffer in the Serial Wombat chip.
int16_t eraseFlashPage(uint32_t address)
Erases a page in flash. Intended for use with the Bootloader, not by end users outside of bootloading...
uint16_t returnErrorCode(uint8_t *rx)
uint16_t deviceIdentifier
int16_t writeRamAddress(uint16_t address, uint8_t value)
Write byte to Address in RAM based on 16 bit address.
int16_t writeFrameTimerPin(uint8_t pin)
Set a pin to be a frame timer for system utilization (SW18AB Only)
uint16_t _supplyVoltagemV
void registerErrorHandler(SerialWombatErrorHandler_t handler)
Registers an error handler that is called by the SerialWombatChip sendPacket() command when a protoco...
int16_t begin(TwoWire &wire, uint8_t i2cAddress, bool reset=true)
initialize a Serial Wombat chip to use a specified I2C Interface and address.
void analogWrite(uint8_t pin, int val)
Set a pin to PWM output.
uint16_t errorCount
Incremented every time a communication or command error is detected.
int writeUserBuffer(uint16_t index, const char s[])
Write bytes to the User Memory Buffer in the Serial Wombat chip.
int analogRead(uint8_t pin)
Configures pin as analog input and does an immediate A/D conversion.
uint16_t readPublicData(SerialWombatDataSource dataSource)
Read the 16 Bit public data associated with a Serial Wombat Pin Mode.
bool queryVersion()
Send a version request to the Serial Wombat chip.
void jumpToBoot()
Jump to Bootloader and wait for a UART download of new firmware.
int digitalRead(uint8_t pin)
Reads the state of a Pin.
void hardwareReset()
Send a reset command to the Serial Wombat chip.
uint8_t model[4]
Contains the last model retreived by queryVersion() as a zero-terminated string.
uint32_t readFramesExecuted()
Get the number of 1mS frames that have been executed since Serial Wombat chip reset.
int16_t readLastErrorCommand(uint8_t *cmd)
Returns the last Serial Wombat command that produced a protocol error.
void sleep()
Shuts down most functions of the Serial Wombat chip reducing power consumption.
SerialWombat18ABOscillatorTuner(SerialWombatChip &serialWombatChip)
Class constructor for SerialWombat18OscillatorTuner.
void update()
Call periodically to tune the SW18AB oscillator to reported millis.
This class name is depricated. Do not use for new development. Use SerialWombatChip instead.