|
|
@ -51,11 +51,8 @@ bool endstop_monitor_flag = false; |
|
|
|
#define REPORT_NAME_DIGITAL(NAME, COUNTER) _ADD_PIN(#NAME, COUNTER) |
|
|
|
#define REPORT_NAME_ANALOG(NAME, COUNTER) _ADD_PIN(#NAME, COUNTER) |
|
|
|
|
|
|
|
#line 0 // set __LINE__ to a known value for the first pass
|
|
|
|
|
|
|
|
#include "pinsDebug_list.h" |
|
|
|
|
|
|
|
#line 59 // set __LINE__ to the correct line number or else compiler error messages don't make sense
|
|
|
|
#line 56 |
|
|
|
|
|
|
|
// manually add pins that have names that are macros which don't play well with these macros
|
|
|
|
#if SERIAL_PORT == 0 && (AVR_ATmega2560_FAMILY || AVR_ATmega1284_FAMILY) |
|
|
@ -77,7 +74,6 @@ bool endstop_monitor_flag = false; |
|
|
|
#define REPORT_NAME_DIGITAL(NAME, COUNTER) _ADD_PIN(NAME, COUNTER, (uint8_t)1) |
|
|
|
#define REPORT_NAME_ANALOG(NAME, COUNTER) _ADD_PIN(analogInputToDigitalPin(NAME), COUNTER, 0) |
|
|
|
|
|
|
|
|
|
|
|
const char* const pin_array[][3] PROGMEM = { |
|
|
|
|
|
|
|
/**
|
|
|
@ -100,21 +96,18 @@ const char* const pin_array[][3] PROGMEM = { |
|
|
|
#endif |
|
|
|
#endif |
|
|
|
|
|
|
|
#line 0 // set __LINE__ to the SAME known value for the second pass
|
|
|
|
#include "pinsDebug_list.h" |
|
|
|
#line 101 |
|
|
|
|
|
|
|
}; // done populating the array
|
|
|
|
|
|
|
|
#line 109 // set __LINE__ to the correct line number or else compiler error messages don't make sense
|
|
|
|
}; |
|
|
|
|
|
|
|
#define n_array (sizeof (pin_array) / sizeof (const char *))/3 |
|
|
|
#define n_array (sizeof(pin_array) / sizeof(char*)) / 3 |
|
|
|
|
|
|
|
#ifndef TIMER1B |
|
|
|
// working with Teensyduino extension so need to re-define some things
|
|
|
|
#include "pinsDebug_Teensyduino.h" |
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
#define PWM_PRINT(V) do{ sprintf(buffer, "PWM: %4d", V); SERIAL_ECHO(buffer); }while(0) |
|
|
|
#define PWM_CASE(N,Z) \ |
|
|
|
case TIMER##N##Z: \ |
|
|
@ -176,11 +169,10 @@ static bool pwm_status(uint8_t pin) { |
|
|
|
default: |
|
|
|
return false; |
|
|
|
} |
|
|
|
SERIAL_PROTOCOLPGM(" "); |
|
|
|
SERIAL_PROTOCOL_SP(2); |
|
|
|
} // pwm_status
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const volatile uint8_t* const PWM_other[][3] PROGMEM = { |
|
|
|
{ &TCCR0A, &TCCR0B, &TIMSK0 }, |
|
|
|
{ &TCCR1A, &TCCR1B, &TIMSK1 }, |
|
|
@ -247,19 +239,11 @@ const volatile uint8_t* const PWM_OCR[][3] PROGMEM = { |
|
|
|
#define WGM_3 4 |
|
|
|
#define TOIE 0 |
|
|
|
|
|
|
|
|
|
|
|
#define OCR_VAL(T, L) pgm_read_word(&PWM_OCR[T][L]) |
|
|
|
|
|
|
|
|
|
|
|
static void err_is_counter() { |
|
|
|
SERIAL_PROTOCOLPGM(" non-standard PWM mode"); |
|
|
|
} |
|
|
|
static void err_is_interrupt() { |
|
|
|
SERIAL_PROTOCOLPGM(" compare interrupt enabled"); |
|
|
|
} |
|
|
|
static void err_prob_interrupt() { |
|
|
|
SERIAL_PROTOCOLPGM(" overflow interrupt enabled"); |
|
|
|
} |
|
|
|
static void err_is_counter() { SERIAL_PROTOCOLPGM(" non-standard PWM mode"); } |
|
|
|
static void err_is_interrupt() { SERIAL_PROTOCOLPGM(" compare interrupt enabled"); } |
|
|
|
static void err_prob_interrupt() { SERIAL_PROTOCOLPGM(" overflow interrupt enabled"); } |
|
|
|
|
|
|
|
void com_print(uint8_t N, uint8_t Z) { |
|
|
|
uint8_t *TCCRA = (uint8_t*)TCCR_A(N); |
|
|
@ -278,8 +262,7 @@ void com_print(uint8_t N, uint8_t Z) { |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
void timer_prefix(uint8_t T, char L, uint8_t N) { // T - timer L - pwm n - WGM bit layout
|
|
|
|
void timer_prefix(uint8_t T, char L, uint8_t N) { // T - timer L - pwm N - WGM bit layout
|
|
|
|
char buffer[20]; // for the sprintf statements
|
|
|
|
uint8_t *TCCRB = (uint8_t*)TCCR_B(T); |
|
|
|
uint8_t *TCCRA = (uint8_t*)TCCR_A(T); |
|
|
@ -289,7 +272,7 @@ void timer_prefix(uint8_t T, char L, uint8_t N) { // T - timer L - pwm n - |
|
|
|
SERIAL_PROTOCOLPGM(" TIMER"); |
|
|
|
SERIAL_PROTOCOLCHAR(T + '0'); |
|
|
|
SERIAL_PROTOCOLCHAR(L); |
|
|
|
SERIAL_PROTOCOLPGM(" "); |
|
|
|
SERIAL_PROTOCOL_SP(3); |
|
|
|
|
|
|
|
if (N == 3) { |
|
|
|
uint8_t *OCRVAL8 = (uint8_t*)OCR_VAL(T, L - 'A'); |
|
|
@ -327,76 +310,43 @@ static void pwm_details(uint8_t pin) { |
|
|
|
switch (digitalPinToTimer(pin)) { |
|
|
|
|
|
|
|
#if defined(TCCR0A) && defined(COM0A1) |
|
|
|
|
|
|
|
#ifdef TIMER0A |
|
|
|
case TIMER0A: |
|
|
|
timer_prefix(0,'A',3); |
|
|
|
break; |
|
|
|
case TIMER0A: timer_prefix(0, 'A', 3); break; |
|
|
|
#endif |
|
|
|
case TIMER0B: |
|
|
|
timer_prefix(0,'B',3); |
|
|
|
break; |
|
|
|
case TIMER0B: timer_prefix(0, 'B', 3); break; |
|
|
|
#endif |
|
|
|
|
|
|
|
#if defined(TCCR1A) && defined(COM1A1) |
|
|
|
case TIMER1A: |
|
|
|
timer_prefix(1,'A',4); |
|
|
|
break; |
|
|
|
case TIMER1B: |
|
|
|
timer_prefix(1,'B',4); |
|
|
|
break; |
|
|
|
case TIMER1A: timer_prefix(1, 'A', 4); break; |
|
|
|
case TIMER1B: timer_prefix(1, 'B', 4); break; |
|
|
|
#if defined(COM1C1) && defined(TIMER1C) |
|
|
|
case TIMER1C: |
|
|
|
timer_prefix(1,'C',4); |
|
|
|
break; |
|
|
|
case TIMER1C: timer_prefix(1, 'C', 4); break; |
|
|
|
#endif |
|
|
|
#endif |
|
|
|
|
|
|
|
#if defined(TCCR2A) && defined(COM2A1) |
|
|
|
case TIMER2A: |
|
|
|
timer_prefix(2,'A',3); |
|
|
|
break; |
|
|
|
case TIMER2B: |
|
|
|
timer_prefix(2,'B',3); |
|
|
|
break; |
|
|
|
case TIMER2A: timer_prefix(2, 'A', 3); break; |
|
|
|
case TIMER2B: timer_prefix(2, 'B', 3); break; |
|
|
|
#endif |
|
|
|
|
|
|
|
#if defined(TCCR3A) && defined(COM3A1) |
|
|
|
case TIMER3A: |
|
|
|
timer_prefix(3,'A',4); |
|
|
|
break; |
|
|
|
case TIMER3B: |
|
|
|
timer_prefix(3,'B',4); |
|
|
|
break; |
|
|
|
case TIMER3A: timer_prefix(3, 'A', 4); break; |
|
|
|
case TIMER3B: timer_prefix(3, 'B', 4); break; |
|
|
|
#ifdef COM3C1 |
|
|
|
case TIMER3C: |
|
|
|
timer_prefix(3,'C',4); |
|
|
|
break; |
|
|
|
case TIMER3C: timer_prefix(3, 'C', 4); break; |
|
|
|
#endif |
|
|
|
#endif |
|
|
|
|
|
|
|
#ifdef TCCR4A |
|
|
|
case TIMER4A: |
|
|
|
timer_prefix(4,'A',4); |
|
|
|
break; |
|
|
|
case TIMER4B: |
|
|
|
timer_prefix(4,'B',4); |
|
|
|
break; |
|
|
|
case TIMER4C: |
|
|
|
timer_prefix(4,'C',4); |
|
|
|
break; |
|
|
|
case TIMER4A: timer_prefix(4, 'A', 4); break; |
|
|
|
case TIMER4B: timer_prefix(4, 'B', 4); break; |
|
|
|
case TIMER4C: timer_prefix(4, 'C', 4); break; |
|
|
|
#endif |
|
|
|
|
|
|
|
#if defined(TCCR5A) && defined(COM5A1) |
|
|
|
case TIMER5A: |
|
|
|
timer_prefix(5,'A',4); |
|
|
|
break; |
|
|
|
case TIMER5B: |
|
|
|
timer_prefix(5,'B',4); |
|
|
|
break; |
|
|
|
case TIMER5C: |
|
|
|
timer_prefix(5,'C',4); |
|
|
|
break; |
|
|
|
case TIMER5A: timer_prefix(5, 'A', 4); break; |
|
|
|
case TIMER5B: timer_prefix(5, 'B', 4); break; |
|
|
|
case TIMER5C: timer_prefix(5, 'C', 4); break; |
|
|
|
#endif |
|
|
|
|
|
|
|
case NOT_ON_TIMER: break; |
|
|
@ -409,10 +359,16 @@ static void pwm_details(uint8_t pin) { |
|
|
|
// looking for port B7 - PWMs 0A and 1C
|
|
|
|
if ( ('B' == digitalPinToPort(pin) + 64) && (0x80 == digitalPinToBitMask(pin))) { |
|
|
|
#ifndef TEENSYDUINO_IDE |
|
|
|
SERIAL_PROTOCOLPGM("\n . TIMER1C is also tied to this pin "); |
|
|
|
SERIAL_PROTOCOLPGM("\n ."); |
|
|
|
SERIAL_PROTOCOL_SP(18); |
|
|
|
SERIAL_PROTOCOLPGM("TIMER1C is also tied to this pin"); |
|
|
|
SERIAL_PROTOCOL_SP(13); |
|
|
|
timer_prefix(1, 'C', 4); |
|
|
|
#else |
|
|
|
SERIAL_PROTOCOLPGM("\n . TIMER0A is also tied to this pin "); |
|
|
|
SERIAL_PROTOCOLPGM("\n ."); |
|
|
|
SERIAL_PROTOCOL_SP(18); |
|
|
|
SERIAL_PROTOCOLPGM("TIMER0A is also tied to this pin"); |
|
|
|
SERIAL_PROTOCOL_SP(13); |
|
|
|
timer_prefix(0, 'A', 3); |
|
|
|
#endif |
|
|
|
} |
|
|
@ -437,7 +393,7 @@ void print_port(int8_t pin) { // print port number |
|
|
|
for (x = '0'; x < '9' && temp != 1; x++) temp >>= 1; |
|
|
|
SERIAL_CHAR(x); |
|
|
|
#else |
|
|
|
SERIAL_PROTOCOLPGM(" "); |
|
|
|
SERIAL_PROTOCOL_SP(10); |
|
|
|
#endif |
|
|
|
} |
|
|
|
|
|
|
@ -460,9 +416,12 @@ inline void report_pin_state_extended(int8_t pin, bool ignore, bool extended = t |
|
|
|
sprintf(buffer, " (A%2d) ", int(pin - analogInputToDigitalPin(0))); // analog pin number
|
|
|
|
SERIAL_ECHO(buffer); |
|
|
|
} |
|
|
|
else SERIAL_ECHOPGM(" "); // add padding if not an analog pin
|
|
|
|
else SERIAL_ECHO_SP(8); // add padding if not an analog pin
|
|
|
|
} |
|
|
|
else { |
|
|
|
SERIAL_CHAR('.'); |
|
|
|
SERIAL_ECHO_SP(25); // add padding if not the first instance found
|
|
|
|
} |
|
|
|
else SERIAL_ECHOPGM(". "); // add padding if not the first instance found
|
|
|
|
name_mem_pointer = (char*)pgm_read_word(&pin_array[x][0]); |
|
|
|
for (uint8_t y = 0; y < 28; y++) { // always print pin name
|
|
|
|
temp_char = pgm_read_byte(name_mem_pointer + y); |
|
|
@ -506,17 +465,19 @@ inline void report_pin_state_extended(int8_t pin, bool ignore, bool extended = t |
|
|
|
SERIAL_ECHO(buffer); |
|
|
|
} |
|
|
|
else |
|
|
|
SERIAL_ECHOPGM(" "); // add padding if not an analog pin
|
|
|
|
SERIAL_ECHO_SP(8); // add padding if not an analog pin
|
|
|
|
SERIAL_ECHOPGM("<unused/unknown>"); |
|
|
|
if (get_pinMode(pin)) |
|
|
|
if (get_pinMode(pin)) { |
|
|
|
SERIAL_PROTOCOL_SP(12); |
|
|
|
SERIAL_PROTOCOLPAIR("Output = ", digitalRead_mod(pin)); |
|
|
|
} |
|
|
|
else { |
|
|
|
if (IS_ANALOG(pin)) { |
|
|
|
sprintf(buffer, " Analog in = %5d", analogRead(pin - analogInputToDigitalPin(0))); |
|
|
|
SERIAL_ECHO(buffer); |
|
|
|
} |
|
|
|
else |
|
|
|
SERIAL_ECHOPGM(" "); // add padding if not an analog pin
|
|
|
|
SERIAL_ECHO_SP(9); // add padding if not an analog pin
|
|
|
|
|
|
|
|
SERIAL_PROTOCOLPAIR(" Input = ", digitalRead_mod(pin)); |
|
|
|
} |
|
|
|