1 Commits

Author SHA1 Message Date
Andrew Gillham
1b9c3e7314 Create an Ethernet shield version.
This alpha version can be connected to across the network using the OLS
client and an Ethernet shield.
2013-06-22 22:04:05 -07:00
3 changed files with 263 additions and 213 deletions

4
README
View File

@@ -1,7 +1,7 @@
SUMP compatible logic analyzer for Arduino SUMP compatible logic analyzer for Arduino
========================================== ==========================================
NOTE: NOTE: v0.09 switched the channels BACK to pins 8-13 for trigger reliability. NOTE: NOTE: v0.09 switches the channels BACK to pins 8-13 for trigger reliability.
Please report any issues. Uncomment USE_PORTD for pins 2-7. Please report any issues. Uncomment USE_PORTD for pins 2-7.
This Arduino sketch implements a SUMP protocol compatible with the standard This Arduino sketch implements a SUMP protocol compatible with the standard
@@ -54,5 +54,5 @@ Please try it out and report back.
This master branch now supports Arduino 1.0 only. This master branch now supports Arduino 1.0 only.
Checkout branch logic_analyzer_v0_5 for Arduino 22 support. Checkout branch logic_analyzer_v0_5 for Arduino 22 support.
Release: v0.10 July 22, 2013. Release: v0.09 June 22, 2013.

View File

@@ -29,7 +29,17 @@
*/ */
/* /*
* NOTE: v0.09 switched the channels BACK to pins 8-13 for trigger reliability. * NOTE: This is an ALPHA of support for an Ethernet attached Logic Analyzer.
* Tested with an Arduino Duemilanove and W5100 based Ethernet shield.
* It may work with other combinations, but I haven't tested it.
*
* USE: Configure the mac address (if you want) and the ip address (mandatory)
* for your network and upload it. In the OLS client select network
* instead of serial and use your ip address and port 1234.
* Click capture! You should get some data back from your Arduino.
*
*
* NOTE: v0.09 switches the channels BACK to pins 8-13 for trigger reliability.
* Please report any issues. Uncomment USE_PORTD for pins 2-7. * Please report any issues. Uncomment USE_PORTD for pins 2-7.
* *
* This Arduino sketch implements a SUMP protocol compatible with the standard * This Arduino sketch implements a SUMP protocol compatible with the standard
@@ -78,10 +88,12 @@
* until after the trigger fires. * until after the trigger fires.
* Please try it out and report back. * Please try it out and report back.
* *
* Release: v0.10 July 22, 2013. * Release: v0.09 June 22, 2013.
* *
*/ */
#include <SPI.h>
#include <Ethernet.h>
/* /*
* Function prototypes so this can compile from the cli. * Function prototypes so this can compile from the cli.
* You'll need the 'arduino-core' package and to check the paths in the * You'll need the 'arduino-core' package and to check the paths in the
@@ -98,12 +110,11 @@ void get_metadata(void);
void debugprint(void); void debugprint(void);
void debugdump(void); void debugdump(void);
/* /*
* Should we use PORTD or PORTB? (default is PORTB) * Should we use PORTD or PORTB? (default is PORTB)
* PORTD support with triggers seems to work but needs more testing. * PORTD support with triggers seems to work but needs more testing.
*/ */
//#define USE_PORTD 1 #define USE_PORTD 1
/* /*
* Arduino device profile: ols.profile-agla.cfg * Arduino device profile: ols.profile-agla.cfg
@@ -218,10 +229,30 @@ unsigned int delayTime = 0;
unsigned long divider = 0; unsigned long divider = 0;
boolean rleEnabled = 0; boolean rleEnabled = 0;
/*
* Enter a MAC address and IP address for your Arduino.
*/
byte mac[] = {
0x40, 0x00, 0x01, 0x02, 0x03, 0x04 };
IPAddress ip(192,168,1,200);
// Initialize the Ethernet server library
// with the IP address and port you want to use
// (port 80 is default for HTTP):
EthernetServer server(1234);
EthernetClient client;
void setup() void setup()
{ {
Serial.begin(115200); Serial.begin(115200);
// start the Ethernet connection and the server:
Ethernet.begin(mac, ip);
server.begin();
Serial.print("server is at ");
Serial.println(Ethernet.localIP());
/* /*
* set debug pin (digital pin 8) to output right away so it settles. * set debug pin (digital pin 8) to output right away so it settles.
* this gets toggled during sampling as a way to measure * this gets toggled during sampling as a way to measure
@@ -231,16 +262,24 @@ void setup()
DEBUG_ENABLE; /* debug measurement pin */ DEBUG_ENABLE; /* debug measurement pin */
pinMode(CHAN0, INPUT); pinMode(CHAN0, INPUT);
digitalWrite(CHAN0, LOW);
pinMode(CHAN1, INPUT); pinMode(CHAN1, INPUT);
digitalWrite(CHAN1, LOW);
pinMode(CHAN2, INPUT); pinMode(CHAN2, INPUT);
digitalWrite(CHAN2, LOW);
pinMode(CHAN3, INPUT); pinMode(CHAN3, INPUT);
digitalWrite(CHAN3, LOW);
pinMode(CHAN4, INPUT); pinMode(CHAN4, INPUT);
digitalWrite(CHAN4, LOW);
#ifdef CHAN5 #ifdef CHAN5
pinMode(CHAN5, INPUT); pinMode(CHAN5, INPUT);
digitalWrite(CHAN5, LOW);
#endif #endif
#if defined(__AVR_ATmega1280__) || defined(__AVR_ATmega2560__) #if defined(__AVR_ATmega1280__) || defined(__AVR_ATmega2560__)
pinMode(CHAN6, INPUT); pinMode(CHAN6, INPUT);
digitalWrite(CHAN6, LOW);
pinMode(CHAN7, INPUT); pinMode(CHAN7, INPUT);
digitalWrite(CHAN7, LOW);
#else #else
#ifndef CHAN5 #ifndef CHAN5
pinMode(ledPin, OUTPUT); pinMode(ledPin, OUTPUT);
@@ -252,8 +291,13 @@ void loop()
{ {
int i; int i;
if (Serial.available() > 0) { // listen for incoming clients
cmdByte = Serial.read(); client = server.available();
if (client) {
Serial.println("new client");
while (client.connected()) {
if (client.available()) {
cmdByte = client.read();
switch(cmdByte) { switch(cmdByte) {
case SUMP_RESET: case SUMP_RESET:
/* /*
@@ -264,10 +308,10 @@ void loop()
break; break;
case SUMP_QUERY: case SUMP_QUERY:
/* return the expected bytes. */ /* return the expected bytes. */
Serial.write('1'); client.write('1');
Serial.write('A'); client.write('A');
Serial.write('L'); client.write('L');
Serial.write('S'); client.write('S');
break; break;
case SUMP_ARM: case SUMP_ARM:
/* /*
@@ -404,8 +448,13 @@ void loop()
default: default:
/* ignore any unrecognized bytes. */ /* ignore any unrecognized bytes. */
break; break;
} } /* switch */
} } /* if client.available() */
} /* while */
delay(1);
client.stop();
Serial.println("client disconnected?");
} /* if client */
} }
void blinkled() { void blinkled() {
@@ -424,10 +473,10 @@ void blinkled() {
*/ */
void getCmd() { void getCmd() {
delay(10); delay(10);
cmdBytes[0] = Serial.read(); cmdBytes[0] = client.read();
cmdBytes[1] = Serial.read(); cmdBytes[1] = client.read();
cmdBytes[2] = Serial.read(); cmdBytes[2] = client.read();
cmdBytes[3] = Serial.read(); cmdBytes[3] = client.read();
#ifdef DEBUG #ifdef DEBUG
if (savecount < 120 ) { if (savecount < 120 ) {
@@ -546,9 +595,9 @@ void captureMicro() {
*/ */
for (i = 0 ; i < readCount; i++) { for (i = 0 ; i < readCount; i++) {
#ifdef USE_PORTD #ifdef USE_PORTD
Serial.write(logicdata[i] >> 2); client.write(logicdata[i] >> 2);
#else #else
Serial.write(logicdata[i]); client.write(logicdata[i]);
#endif #endif
} }
} }
@@ -621,9 +670,9 @@ void captureMilli() {
} }
for (i = 0 ; i < readCount; i++) { for (i = 0 ; i < readCount; i++) {
#ifdef USE_PORTD #ifdef USE_PORTD
Serial.write(logicdata[i] >> 2); client.write(logicdata[i] >> 2);
#else #else
Serial.write(logicdata[i]); client.write(logicdata[i]);
#endif #endif
} }
} }
@@ -813,9 +862,9 @@ void triggerMicro() {
logicIndex = 0; logicIndex = 0;
} }
#ifdef USE_PORTD #ifdef USE_PORTD
Serial.write(logicdata[logicIndex++] >> 2); client.write(logicdata[logicIndex++] >> 2);
#else #else
Serial.write(logicdata[logicIndex++]); client.write(logicdata[logicIndex++]);
#endif #endif
} }
} }
@@ -852,69 +901,69 @@ void setupDelay() {
*/ */
void get_metadata() { void get_metadata() {
/* device name */ /* device name */
Serial.write((uint8_t)0x01); client.write((uint8_t)0x01);
Serial.write('A'); client.write('A');
Serial.write('G'); client.write('G');
Serial.write('L'); client.write('L');
Serial.write('A'); client.write('A');
#if defined(__AVR_ATmega1280__) || defined(__AVR_ATmega2560__) #if defined(__AVR_ATmega1280__) || defined(__AVR_ATmega2560__)
Serial.write('M'); client.write('M');
#endif /* Mega */ #endif /* Mega */
Serial.write('v'); client.write('v');
Serial.write('0'); client.write('0');
Serial.write((uint8_t)0x00); client.write((uint8_t)0x00);
/* firmware version */ /* firmware version */
Serial.write((uint8_t)0x02); client.write((uint8_t)0x02);
Serial.write('0'); client.write('0');
Serial.write('.'); client.write('.');
Serial.write('1'); client.write('0');
Serial.write('0'); client.write('9');
Serial.write((uint8_t)0x00); client.write((uint8_t)0x00);
/* sample memory */ /* sample memory */
Serial.write((uint8_t)0x21); client.write((uint8_t)0x21);
Serial.write((uint8_t)0x00); client.write((uint8_t)0x00);
Serial.write((uint8_t)0x00); client.write((uint8_t)0x00);
#if defined(__AVR_ATmega1280__) || defined(__AVR_ATmega2560__) #if defined(__AVR_ATmega1280__) || defined(__AVR_ATmega2560__)
/* 7168 bytes */ /* 7168 bytes */
Serial.write((uint8_t)0x1C); client.write((uint8_t)0x1C);
Serial.write((uint8_t)0x00); client.write((uint8_t)0x00);
#elif defined(__AVR_ATmega328P__) #elif defined(__AVR_ATmega328P__)
/* 1024 bytes */ /* 1024 bytes */
Serial.write((uint8_t)0x04); client.write((uint8_t)0x04);
Serial.write((uint8_t)0x00); client.write((uint8_t)0x00);
#else #else
/* 532 bytes */ /* 532 bytes */
Serial.write((uint8_t)0x02); client.write((uint8_t)0x02);
Serial.write((uint8_t)0x14); client.write((uint8_t)0x14);
#endif /* Mega */ #endif /* Mega */
/* sample rate (1MHz) */ /* sample rate (1MHz) */
Serial.write((uint8_t)0x23); client.write((uint8_t)0x23);
Serial.write((uint8_t)0x00); client.write((uint8_t)0x00);
Serial.write((uint8_t)0x0F); client.write((uint8_t)0x0F);
Serial.write((uint8_t)0x42); client.write((uint8_t)0x42);
Serial.write((uint8_t)0x40); client.write((uint8_t)0x40);
/* number of probes (6 by default on Arduino, 8 on Mega) */ /* number of probes (6 by default on Arduino, 8 on Mega) */
Serial.write((uint8_t)0x40); client.write((uint8_t)0x40);
#if defined(__AVR_ATmega1280__) || defined(__AVR_ATmega2560__) #if defined(__AVR_ATmega1280__) || defined(__AVR_ATmega2560__)
Serial.write((uint8_t)0x08); client.write((uint8_t)0x08);
#else #else
#ifdef CHAN5 #ifdef CHAN5
Serial.write((uint8_t)0x06); client.write((uint8_t)0x06);
#else #else
Serial.write((uint8_t)0x05); client.write((uint8_t)0x05);
#endif /* CHAN5 */ #endif /* CHAN5 */
#endif /* Mega */ #endif /* Mega */
/* protocol version (2) */ /* protocol version (2) */
Serial.write((uint8_t)0x41); client.write((uint8_t)0x41);
Serial.write((uint8_t)0x02); client.write((uint8_t)0x02);
/* end of data */ /* end of data */
Serial.write((uint8_t)0x00); client.write((uint8_t)0x00);
} }
/* /*
@@ -927,36 +976,36 @@ void debugprint() {
int i; int i;
#if 0 #if 0
Serial.print("divider = "); client.print("divider = ");
Serial.println(divider, DEC); client.println(divider, DEC);
Serial.print("delayTime = "); client.print("delayTime = ");
Serial.println(delayTime, DEC); client.println(delayTime, DEC);
Serial.print("trigger_values = "); client.print("trigger_values = ");
Serial.println(trigger_values, BIN); client.println(trigger_values, BIN);
#endif #endif
Serial.print("readCount = "); client.print("readCount = ");
Serial.println(readCount, DEC); client.println(readCount, DEC);
Serial.print("delayCount = "); client.print("delayCount = ");
Serial.println(delayCount, DEC); client.println(delayCount, DEC);
Serial.print("logicIndex = "); client.print("logicIndex = ");
Serial.println(logicIndex, DEC); client.println(logicIndex, DEC);
Serial.print("triggerIndex = "); client.print("triggerIndex = ");
Serial.println(triggerIndex, DEC); client.println(triggerIndex, DEC);
Serial.print("rleEnabled = "); client.print("rleEnabled = ");
Serial.println(rleEnabled, DEC); client.println(rleEnabled, DEC);
Serial.println("Bytes:"); client.println("Bytes:");
for (i = 0 ; i < savecount; i++) { for (i = 0 ; i < savecount; i++) {
if (savebytes[i] == 0x20) { if (savebytes[i] == 0x20) {
Serial.println(); client.println();
} }
else { else {
Serial.print(savebytes[i], HEX); client.print(savebytes[i], HEX);
Serial.write(' '); client.write(' ');
} }
} }
Serial.println("done..."); client.println("done...");
} }
/* /*
@@ -967,17 +1016,17 @@ void debugdump() {
int i; int i;
int j = 1; int j = 1;
Serial.print("\r\n"); client.print("\r\n");
for (i = 0 ; i < MAX_CAPTURE_SIZE; i++) { for (i = 0 ; i < MAX_CAPTURE_SIZE; i++) {
#ifdef USE_PORTD #ifdef USE_PORTD
Serial.print(logicdata[i] >> 2, HEX); client.print(logicdata[i] >> 2, HEX);
#else #else
Serial.print(logicdata[i], HEX); client.print(logicdata[i], HEX);
#endif #endif
Serial.print(" "); client.print(" ");
if (j == 32) { if (j == 32) {
Serial.print("\r\n"); client.print("\r\n");
j = 0; j = 0;
} }
j++; j++;
@@ -991,3 +1040,4 @@ void debugdump() {

View File

@@ -39,7 +39,7 @@ device.capturesize.bound = false
device.channel.numberingschemes = DEFAULT device.channel.numberingschemes = DEFAULT
# Is a delay after opening the port and device detection needed? (0 = no delay, >0 = delay in milliseconds) # Is a delay after opening the port and device detection needed? (0 = no delay, >0 = delay in milliseconds)
device.open.portdelay = 2000 device.open.portdelay = 1500
# The receive timeout for the device (in milliseconds, 100 = default, <=0 = no timeout) # The receive timeout for the device (in milliseconds, 100 = default, <=0 = no timeout)
device.receive.timeout = 100 device.receive.timeout = 100
# Does the device need a high or low DTR-line to operate correctly? (high = true, low = false) # Does the device need a high or low DTR-line to operate correctly? (high = true, low = false)