SoftwareSerial mit verschiedenen IDE Versionen - Interessant!

Hallo,

ich habe ein wenig verglichen und gemessen wie “genau” die SoftwareSerial in verschiedenen IDE Versionen funktioniert. Der Scetch / Code ist jedesmal was sehr einfaches und völlig identisch.

Im Detail (siehe Screenshots im Anhang):

1.0.6 / 57.6k: funktioniert, Genauigkeit / Timing ist so la la

1.6.0 / 57.6k: funktioniert nicht, Timing viel zu ungenau (war auch schon mit 1.5.8 genau so)

1.6.1 / 57.6k: funktioniert gut, Genauigkeit / Timing einwandfrei

1.6.1 / 115k: ja, auch das geht, Genauigkeit durchaus noch akzeptabel.

Version 1.6.1 und 1.6.3 verhält sich hier identisch; die 1.6.2 habe ich nicht installiert.

Beste Grüße,
Christian

Kann es sein, daß SoftwareSerial auf (andere) Interrupts allergisch reagiert?

DrDiettrich:
Kann es sein, daß SoftwareSerial auf (andere) Interrupts allergisch reagiert?

Hallo,

das mag sein. Aber mein primitives Testprogramm sollte eigentlich keine großartigen Interrupts verwenden - vielleicht mit Ausnahme von dem was Arduino-Standard ist (millis,…).

Für mich sieht es so aus: bis 1.0.6 ging es prinzipiell und niemand hat sich (seit NewSoftSerial) darum kümmern müssen. Ab der 1.5.x Entwicklung wurde irgend etwas anders, vielleicht Compileroptionen? Und ab der Version 1.6.1 wurde das entsprechend optimiert.

Der Test-Sketch beruht auf Blink without Delay mit der Erweiterung bei jedem “Blink” ein bischen was (Schleifenzähler und freies RAM) über SoftSerial auszugeben - sonnst nichts.

/* Blink without Delay
 
 Turns on and off a light emitting diode(LED) connected to a digital  
 pin, without using the delay() function.  This means that other code
 can run at the same time without being interrupted by the LED code.
 
 The circuit:
 * LED attached from pin 13 to ground.
 * Note: on most Arduinos, there is already an LED on the board
 that's attached to pin 13, so no hardware is needed for this example.
 
 
 created 2005
 by David A. Mellis
 modified 8 Feb 2010
 by Paul Stoffregen
 
 This example code is in the public domain.

 
 http://www.arduino.cc/en/Tutorial/BlinkWithoutDelay
 */

// constants won't change. Used here to 
// set pin numbers:
const int ledPin =  13;      // the number of the LED pin

// Variables will change:
int ledState = LOW;             // ledState used to set the LED
long previousMillis = 0;        // will store last time LED was updated
long counter = 0;

// the follow variables is a long because the time, measured in miliseconds,
// will quickly become a bigger number than can be stored in an int.
long interval = 250;           // interval at which to blink (milliseconds)

#include <SoftwareSerial.h>
SoftwareSerial mySerial(-1, 9); // RX, TX

// #include <AltSoftSerial.h>
// AltSoftSerial mySerial;

void setup() {
  // set the digital pin as output:
  pinMode(ledPin, OUTPUT);  
//  Serial.begin(115200); 
  mySerial.begin(115200);
  
}

void loop()
{
  // here is where you'd put code that needs to be running all the time.

  // check to see if it's time to blink the LED; that is, if the 
  // difference between the current time and last time you blinked 
  // the LED is bigger than the interval at which you want to 
  // blink the LED.
  unsigned long currentMillis = millis();

  if(currentMillis - previousMillis > interval) {
    // save the last time you blinked the LED 
    previousMillis = currentMillis;   

    // if the LED is off turn it on and vice-versa:
    mySerial.print (F("RAM Frei:"));
    mySerial.print (freeRam());
    mySerial.print (F(" Schleifen:"));
    mySerial.println (counter);
    counter = counter + 1;
    if (ledState == LOW)
      ledState = HIGH;
    else
      ledState = LOW;

    // set the LED with the ledState of the variable:
    digitalWrite(ledPin, ledState);
  }
}

int freeRam ()
{
extern int __heap_start, *__brkval;
int v;
return (int) &v - (__brkval == 0 ? (int) &__heap_start : (int) __brkval);
}