diff options
author | Marti Bolivar <mbolivar@leaflabs.com> | 2011-03-04 20:25:26 -0500 |
---|---|---|
committer | Marti Bolivar <mbolivar@leaflabs.com> | 2011-03-08 13:43:41 -0500 |
commit | 8863418f0595c8dfd7d01081be941541539827bb (patch) | |
tree | 94b86a04e6808df1390e88d809dd54c9aa8edccb /examples/test-session.cpp | |
parent | 8241a4c640d036faa148350219ad3deea72a23c2 (diff) | |
download | librambutan-8863418f0595c8dfd7d01081be941541539827bb.tar.gz librambutan-8863418f0595c8dfd7d01081be941541539827bb.zip |
Brought examples/ up to date; PIN_MAP bugfix for D24.
(Cherry-pick from refactor with some modifications).
Diffstat (limited to 'examples/test-session.cpp')
-rw-r--r-- | examples/test-session.cpp | 137 |
1 files changed, 81 insertions, 56 deletions
diff --git a/examples/test-session.cpp b/examples/test-session.cpp index 7601fab..cf1f4ec 100644 --- a/examples/test-session.cpp +++ b/examples/test-session.cpp @@ -20,27 +20,43 @@ int rate = 0; +#if defined(BOARD_maple) || defined(BOARD_maple_RET6) + +#elif defined(BOARD_maple_mini) + +#elif defined(BOARD_maple_native) +const uint8[] pins_to_skip = {LED_PIN}; + +#else +#error "Board not selected correctly." +#endif + #if defined(BOARD_maple) const uint8 pwm_pins[] = {0, 1, 2, 3, 5, 6, 7, 8, 9, 11, 12, 14, 24, 25, 27, 28}; const uint8 adc_pins[] = {0, 1, 2, 10, 11, 12, 13, 15, 16, 17, 18, 19, 20, 27, 28}; +const uint8 pins_to_skip[] = {LED_PIN}; #elif defined(BOARD_maple_mini) +#define USB_DP 23 +#define USB_DM 24 const uint8 pwm_pins[] = {3, 4, 5, 8, 9, 10, 11, 15, 16, 25, 26, 27}; const uint8 adc_pins[] = {3, 4, 5, 6, 7, 8, 9, 10, 11, 33}; // NB: 33 is LED +const uint8 pins_to_skip[] = {LED_PIN, USB_DP, USB_DM}; #elif defined(BOARD_maple_native) -const uint8 pwm_pins[] = {12, 13, 14, 15, 22, 23, 24, 25, 37, 38, 45, - 46, 47, 48, 49, 50, 53, 54}; -const uint8 adc_pins[] = {6, 7, 8, 9, 10, 11, - /* the following are on ADC3, which lacks support: - 39, 40, 41, 42, 43, 45, */ - 46, 47, 48, 49, 50, 51, 52, 53, 54}; +const uint8 pwm_pins[] = { + 12, 13, 14, 15, 22, 23, 24, 25, 37, 38, 45, 46, 47, 48, 49, 50, 53, 54}; +const uint8 adc_pins[] = { + 6, 7, 8, 9, 10, 11, + /* FIXME These are on ADC3, which lacks support: + 39, 40, 41, 42, 43, 45, */ + 46, 47, 48, 49, 50, 51, 52, 53, 54}; +const uint8 pins_to_skip[] = {LED_PIN}; #else -#error "Board type has not been selected correctly" - +#error "Board type has not been selected correctly." #endif uint8 gpio_state[NR_GPIO_PINS]; @@ -62,6 +78,7 @@ void cmd_sequential_pwm_test(void); void cmd_pwm_sweep(void); void cmd_servo_sweep(void); +bool skip_pin_p(uint8 pin); void measure_adc_noise(uint8 pin); void fast_gpio(int pin); void do_serials(HardwareSerial **serials, int n, unsigned baud); @@ -79,10 +96,10 @@ void setup() { // Send a message out over COMM interface COMM.println(" "); COMM.println(" __ __ _ _ "); - COMM.println(" | \/ | __ _ _ __ | | ___| |"); - COMM.println(" | |\/| |/ _` | '_ \| |/ _ \ |"); + COMM.println(" | \\/ | __ _ _ __ | | ___| |"); + COMM.println(" | |\\/| |/ _` | '_ \\| |/ _ \\ |"); COMM.println(" | | | | (_| | |_) | | __/_|"); - COMM.println(" |_| |_|\__,_| .__/|_|\___(_)"); + COMM.println(" |_| |_|\\__,_| .__/|_|\\___(_)"); COMM.println(" |_|"); COMM.println(" by leaflabs"); COMM.println(""); @@ -274,7 +291,7 @@ void cmd_print_help(void) { COMM.println("\tr: Monitor and print GPIO status changes"); COMM.println("\ts: output a sweeping servo PWM on all PWM channels"); COMM.println("\tm: output data on USART1 and USART3 with various rates"); - COMM.println("\t+: test shield mode (for QA, will disrupt Serial2!)"); + COMM.println("\t+: test shield mode (for QA; will disrupt USARTS)"); COMM.println("Unimplemented:"); COMM.println("\te: do everything all at once until new input"); @@ -294,11 +311,11 @@ void measure_adc_noise(uint8 pin) { // TODO // variance algorithm from knuth; see wikipedia // checked against python - for(int i = 0; i<100; i++) { + for(int i = 0; i < 100; i++) { data[i] = analogRead(pin); delta = data[i] - mean; - mean = mean + delta/(i+1); - M2 = M2 + delta*(data[i] - mean); + mean = mean + delta/(i + 1); + M2 = M2 + delta * (data[i] - mean); } //sqrt is broken? @@ -313,7 +330,7 @@ void measure_adc_noise(uint8 pin) { // TODO void cmd_adc_stats(void) { COMM.println("Taking ADC noise stats..."); digitalWrite(BOARD_LED_PIN, 0); - for(uint32 i = 0; i<sizeof(adc_pins); i++) { + for(uint32 i = 0; i < sizeof(adc_pins); i++) { delay(5); measure_adc_noise(adc_pins[i]); } @@ -322,21 +339,21 @@ void cmd_adc_stats(void) { void cmd_stressful_adc_stats(void) { COMM.println("Taking ADC noise stats under duress..."); digitalWrite(BOARD_LED_PIN, 0); - for(uint32 i = 0; i<sizeof(adc_pins); i++) { + for(uint32 i = 0; i < sizeof(adc_pins); i++) { // spool up PWM - for(uint32 j = 2; j<(uint32)sizeof(pwm_pins); j++) { + for(uint32 j = 2; j < (uint32)sizeof(pwm_pins); j++) { if(adc_pins[i] != pwm_pins[j]) { - pinMode(pwm_pins[j],PWM); + pinMode(pwm_pins[j], PWM); pwmWrite(pwm_pins[j], 1000 + i); } } SerialUSB.print(dummy_dat); SerialUSB.print(dummy_dat); measure_adc_noise(adc_pins[i]); - for(uint32 j = 2; j<(uint32)sizeof(pwm_pins); j++) { + for(uint32 j = 2; j < (uint32)sizeof(pwm_pins); j++) { if(adc_pins[i] != pwm_pins[j]) { - pinMode(pwm_pins[j],OUTPUT); - digitalWrite(pwm_pins[j],0); + pinMode(pwm_pins[j], OUTPUT); + digitalWrite(pwm_pins[j], 0); } } } @@ -408,12 +425,12 @@ void cmd_gpio_monitoring(void) { COMM.println("Monitoring GPIO read state changes. Press any key."); digitalWrite(BOARD_LED_PIN, 0); // make sure to skip the TX/RX headers - for(int i = 2; i<NR_GPIO_PINS; i++) { + for(int i = 2; i < NR_GPIO_PINS; i++) { pinMode(i, INPUT_PULLDOWN); gpio_state[i] = (uint8)digitalRead(i); } while(!COMM.available()) { - for(int i = 2; i<NR_GPIO_PINS; i++) { + for(int i = 2; i < NR_GPIO_PINS; i++) { uint8 current_state = (uint8)digitalRead(i); if(current_state != gpio_state[i]) { COMM.print("State change on header D"); @@ -424,7 +441,7 @@ void cmd_gpio_monitoring(void) { } } } - for(int i = 2; i<NR_GPIO_PINS; i++) { + for(int i = 2; i < NR_GPIO_PINS; i++) { pinMode(i, OUTPUT); } } @@ -434,7 +451,7 @@ void cmd_sequential_adc_reads(void) { COMM.println("Press any key for next port, or ESC to stop."); digitalWrite(LED_PIN, 0); // make sure to skip the TX/RX headers - for(uint32 i = 2; i<sizeof(adc_pins); i++) { + for(uint32 i = 2; i < sizeof(adc_pins); i++) { COMM.print("Reading on header D"); COMM.print(adc_pins[i], DEC); COMM.println("..."); @@ -446,13 +463,13 @@ void cmd_sequential_adc_reads(void) { COMM.print(sample,DEC); COMM.print("\t"); COMM.print("|"); - for(int j = 0; j<4096; j+= 100) { + for(int j = 0; j < 4096; j += 100) { if(sample >= j) COMM.print("#"); else COMM.print(" "); } COMM.print("| "); - for(int j = 0; j<12; j++) { - if(sample & (1 << (11-j))) COMM.print("1"); + for(int j = 0; j < 12; j++) { + if(sample & (1 << (11 - j))) COMM.print("1"); else COMM.print("0"); } COMM.println(""); @@ -466,32 +483,33 @@ void cmd_sequential_adc_reads(void) { void cmd_gpio_qa(void) { COMM.println("Doing QA testing for most GPIO pins..."); digitalWrite(BOARD_LED_PIN, 0); - for(int i = 0; i<NR_GPIO_PINS; i++) { + for(int i = 0; i < NR_GPIO_PINS; i++) { pinMode(i, INPUT); gpio_state[i] = 0; } - COMM.println("Waiting to start..."); + COMM.println("Waiting to start; press a key."); while(digitalRead(0) != 1 && !COMM.available()) { continue; } - for(int i=0; i<38; i++) { - if(i == BOARD_LED_PIN) { - COMM.println("Not checking LED"); + for(int i = 0; i < NR_GPIO_PINS; i++) { + if(skip_pin_p(i)) { + COMM.print("Not checking pin "); + COMM.println(i); continue; } - COMM.print("Checking D"); - COMM.print(i,DEC); + COMM.print("Checking pin ") + COMM.print(i, DEC); while(digitalRead(i) == 0) continue; - for(int j=0; j<NR_GPIO_PINS; j++) { - if(digitalRead(j) && j!=i) { + for(int j = 0; j < NR_GPIO_PINS; j++) { + if(digitalRead(j) && j != i) { COMM.print(": FAIL ########################### D"); COMM.println(j, DEC); break; } } while(digitalRead(i) == 1) continue; - for(int j=0; j<NR_GPIO_PINS; j++) { - if(digitalRead(j) && j!=i) { + for(int j = 0; j < NR_GPIO_PINS; j++) { + if(digitalRead(j) && j != i) { COMM.print(": FAIL ########################### D"); COMM.println(j, DEC); break; @@ -499,18 +517,26 @@ void cmd_gpio_qa(void) { } COMM.println(": Ok!"); } - for(int i = 0; i<NR_GPIO_PINS; i++) { + for(int i = 0; i < NR_GPIO_PINS; i++) { pinMode(i, OUTPUT); digitalWrite(i, 0); } } +bool skip_pin_p(uint8 pin) { + for (uint8 i = 0; i < sizeof(pins_to_skip); i++) { + if (pin == pins_to_skip[i]) + return true; + } + return false; +} + void cmd_sequential_gpio_writes(void) { COMM.print("Sequentially toggling all pins except D0, D1. "); COMM.println("Anything for next, ESC to stop."); digitalWrite(BOARD_LED_PIN, 0); // make sure to skip the TX/RX headers - for(uint32 i = 2; i<NR_GPIO_PINS; i++) { + for(uint32 i = 2; i < NR_GPIO_PINS; i++) { COMM.print("GPIO write out on header D"); COMM.print((int)i, DEC); COMM.println("..."); @@ -527,15 +553,15 @@ void cmd_gpio_toggling(void) { COMM.println("Toggling all GPIOs simultaneously. Press any key."); digitalWrite(BOARD_LED_PIN, 0); // make sure to skip the TX/RX headers - for(uint32 i = 2; i<NR_GPIO_PINS; i++) { + for(uint32 i = 2; i < NR_GPIO_PINS; i++) { pinMode(i, OUTPUT); } while(!COMM.available()) { - for(uint32 i = 2; i<NR_GPIO_PINS; i++) { + for(uint32 i = 2; i < NR_GPIO_PINS; i++) { togglePin(i); } } - for(uint32 i = 2; i<NR_GPIO_PINS; i++) { + for(uint32 i = 2; i < NR_GPIO_PINS; i++) { digitalWrite(i, 0); } } @@ -546,7 +572,7 @@ void cmd_sequential_pwm_test(void) { COMM.println("Press any key for next, ESC to stop."); digitalWrite(BOARD_LED_PIN, 0); // make sure to skip the TX/RX headers - for(uint32 i = 2; i<sizeof(pwm_pins); i++) { + for(uint32 i = 2; i < sizeof(pwm_pins); i++) { COMM.print("PWM out on header D"); COMM.print(pwm_pins[i], DEC); COMM.println("..."); @@ -563,19 +589,19 @@ void cmd_pwm_sweep(void) { COMM.println("Testing all PWM ports with a sweep. Press any key."); digitalWrite(BOARD_LED_PIN, 0); // make sure to skip the TX/RX pins - for(uint32 i = 2; i<sizeof(pwm_pins); i++) { + for(uint32 i = 2; i < sizeof(pwm_pins); i++) { pinMode(pwm_pins[i], PWM); pwmWrite(pwm_pins[i], 4000); } while(!COMM.available()) { rate += 20; if(rate > 65500) rate = 0; - for(uint32 i = 2; i<sizeof(pwm_pins); i++) { + for(uint32 i = 2; i < sizeof(pwm_pins); i++) { pwmWrite(pwm_pins[i], rate); } delay(1); } - for(uint32 i = 2; i<sizeof(pwm_pins); i++) { + for(uint32 i = 2; i < sizeof(pwm_pins); i++) { pinMode(pwm_pins[i], OUTPUT); } } @@ -586,7 +612,7 @@ void cmd_servo_sweep(void) { digitalWrite(BOARD_LED_PIN, 0); init_all_timers(21); // make sure to skip the TX/RX headers - for(uint32 i = 2; i<sizeof(pwm_pins); i++) { + for(uint32 i = 2; i < sizeof(pwm_pins); i++) { pinMode(pwm_pins[i], PWM); pwmWrite(pwm_pins[i], 4000); } @@ -597,12 +623,12 @@ void cmd_servo_sweep(void) { while(!COMM.available()) { rate += 20; if(rate > 5734) rate = 4096; - for(uint32 i = 2; i<sizeof(pwm_pins); i++) { + for(uint32 i = 2; i < sizeof(pwm_pins); i++) { pwmWrite(pwm_pins[i], rate); } delay(20); } - for(uint32 i = 2; i<sizeof(pwm_pins); i++) { + for(uint32 i = 2; i < sizeof(pwm_pins); i++) { pinMode(pwm_pins[i], OUTPUT); } init_all_timers(1); @@ -626,13 +652,12 @@ void init_all_timers(uint16 prescale) { // Force init to be called *first*, i.e. before static object allocation. -// Otherwise, statically allocated object that need libmaple may fail. -__attribute__(( constructor )) void premain() { +// Otherwise, statically allocated objects that need libmaple may fail. +__attribute__((constructor)) void premain() { init(); } -int main(void) -{ +int main(void) { setup(); while (1) { |