diff options
Diffstat (limited to 'cores/arduino')
| -rwxr-xr-x | cores/arduino/Arduino.h | 1 | ||||
| -rw-r--r-- | cores/arduino/HardwareSerial.cpp | 4 | ||||
| -rwxr-xr-x | cores/arduino/Print.cpp | 2 | ||||
| -rw-r--r-- | cores/arduino/Stream.cpp | 20 | ||||
| -rwxr-xr-x | cores/arduino/WInterrupts.c | 4 | ||||
| -rw-r--r-- | cores/arduino/WString.cpp | 4 | ||||
| -rw-r--r-- | cores/arduino/wiring_analog.c | 2 | ||||
| -rwxr-xr-x | cores/arduino/wiring_digital.c | 10 | 
8 files changed, 29 insertions, 18 deletions
| diff --git a/cores/arduino/Arduino.h b/cores/arduino/Arduino.h index bfec943..830c995 100755 --- a/cores/arduino/Arduino.h +++ b/cores/arduino/Arduino.h @@ -20,6 +20,7 @@ extern "C"{  #define INPUT 0x0  #define OUTPUT 0x1 +#define INPUT_PULLUP 0x2  #define true 0x1  #define false 0x0 diff --git a/cores/arduino/HardwareSerial.cpp b/cores/arduino/HardwareSerial.cpp index 1b1fa71..9985b78 100644 --- a/cores/arduino/HardwareSerial.cpp +++ b/cores/arduino/HardwareSerial.cpp @@ -46,8 +46,8 @@  struct ring_buffer  {    unsigned char buffer[SERIAL_BUFFER_SIZE]; -  volatile int head; -  volatile int tail; +  volatile unsigned int head; +  volatile unsigned int tail;  };  #if defined(USBCON) diff --git a/cores/arduino/Print.cpp b/cores/arduino/Print.cpp index ff9b154..e541a6c 100755 --- a/cores/arduino/Print.cpp +++ b/cores/arduino/Print.cpp @@ -41,7 +41,7 @@ size_t Print::write(const uint8_t *buffer, size_t size)  size_t Print::print(const __FlashStringHelper *ifsh)  { -  const prog_char *p = (const prog_char *)ifsh; +  const char PROGMEM *p = (const char PROGMEM *)ifsh;    size_t n = 0;    while (1) {      unsigned char c = pgm_read_byte(p++); diff --git a/cores/arduino/Stream.cpp b/cores/arduino/Stream.cpp index 5fad8dd..3d5b905 100644 --- a/cores/arduino/Stream.cpp +++ b/cores/arduino/Stream.cpp @@ -99,25 +99,27 @@ bool Stream::findUntil(char *target, size_t targetLen, char *terminator, size_t    size_t index = 0;  // maximum target string length is 64k bytes!    size_t termIndex = 0;    int c; - +      if( *target == 0) -     return true;   // return true if target is a null string +    return true;   // return true if target is a null string    while( (c = timedRead()) > 0){ +     +    if(c != target[index]) +      index = 0; // reset index if any char does not match +          if( c == target[index]){ -    //////Serial.print("found "); Serial.write(c); Serial.print("index now"); Serial.println(index+1); +      //////Serial.print("found "); Serial.write(c); Serial.print("index now"); Serial.println(index+1);        if(++index >= targetLen){ // return true if all chars in the target match          return true;        }      } -    else{ -      index = 0;  // reset index if any char does not match -    } +          if(termLen > 0 && c == terminator[termIndex]){ -       if(++termIndex >= termLen) -         return false;       // return false if terminate string found before target string +      if(++termIndex >= termLen) +        return false;       // return false if terminate string found before target string      }      else -        termIndex = 0; +      termIndex = 0;    }    return false;  } diff --git a/cores/arduino/WInterrupts.c b/cores/arduino/WInterrupts.c index 1449cfb..3b9fe08 100755 --- a/cores/arduino/WInterrupts.c +++ b/cores/arduino/WInterrupts.c @@ -32,7 +32,7 @@  #include "wiring_private.h" -volatile static voidFuncPtr intFunc[EXTERNAL_NUM_INTERRUPTS]; +static volatile voidFuncPtr intFunc[EXTERNAL_NUM_INTERRUPTS];  // volatile static voidFuncPtr twiIntFunc;  void attachInterrupt(uint8_t interruptNum, void (*userFunc)(void), int mode) { @@ -121,8 +121,6 @@ void attachInterrupt(uint8_t interruptNum, void (*userFunc)(void), int mode) {      #elif defined(MCUCR) && defined(ISC20) && defined(GIMSK) && defined(GIMSK)        MCUCR = (MCUCR & ~((1 << ISC20) | (1 << ISC21))) | (mode << ISC20);        GIMSK |= (1 << INT2); -    #else -      #warning attachInterrupt may need some more work for this cpu (case 1)      #endif        break;  #endif diff --git a/cores/arduino/WString.cpp b/cores/arduino/WString.cpp index 3e81331..c6839fc 100644 --- a/cores/arduino/WString.cpp +++ b/cores/arduino/WString.cpp @@ -500,7 +500,7 @@ int String::lastIndexOf( char theChar ) const  int String::lastIndexOf(char ch, unsigned int fromIndex) const  { -	if (fromIndex >= len || fromIndex < 0) return -1; +	if (fromIndex >= len) return -1;  	char tempchar = buffer[fromIndex + 1];  	buffer[fromIndex + 1] = '\0';  	char* temp = strrchr( buffer, ch ); @@ -516,7 +516,7 @@ int String::lastIndexOf(const String &s2) const  int String::lastIndexOf(const String &s2, unsigned int fromIndex) const  { -  	if (s2.len == 0 || len == 0 || s2.len > len || fromIndex < 0) return -1; +  	if (s2.len == 0 || len == 0 || s2.len > len) return -1;  	if (fromIndex >= len) fromIndex = len - 1;  	int found = -1;  	for (char *p = buffer; p <= buffer + fromIndex; p++) { diff --git a/cores/arduino/wiring_analog.c b/cores/arduino/wiring_analog.c index 902b153..a8bc817 100644 --- a/cores/arduino/wiring_analog.c +++ b/cores/arduino/wiring_analog.c @@ -45,6 +45,8 @@ int analogRead(uint8_t pin)  	if (pin >= 54) pin -= 54; // allow for channel or pin numbers  #elif defined(__AVR_ATmega32U4__)  	if (pin >= 18) pin -= 18; // allow for channel or pin numbers +#elif defined(__AVR_ATmega1284__) +	if (pin >= 24) pin -= 24; // allow for channel or pin numbers  #else  	if (pin >= 14) pin -= 14; // allow for channel or pin numbers  #endif diff --git a/cores/arduino/wiring_digital.c b/cores/arduino/wiring_digital.c index 97ef134..584a28a 100755 --- a/cores/arduino/wiring_digital.c +++ b/cores/arduino/wiring_digital.c @@ -32,17 +32,25 @@ void pinMode(uint8_t pin, uint8_t mode)  {  	uint8_t bit = digitalPinToBitMask(pin);  	uint8_t port = digitalPinToPort(pin); -	volatile uint8_t *reg; +	volatile uint8_t *reg, *out;  	if (port == NOT_A_PIN) return;  	// JWS: can I let the optimizer do this?  	reg = portModeRegister(port); +	out = portOutputRegister(port);  	if (mode == INPUT) {   		uint8_t oldSREG = SREG;                  cli();  		*reg &= ~bit; +		*out &= ~bit; +		SREG = oldSREG; +	} else if (mode == INPUT_PULLUP) { +		uint8_t oldSREG = SREG; +                cli(); +		*reg &= ~bit; +		*out |= bit;  		SREG = oldSREG;  	} else {  		uint8_t oldSREG = SREG; | 
