|
@@ -1087,17 +1087,17 @@ void Temperature::init() {
|
1087
|
1087
|
delay(250);
|
1088
|
1088
|
|
1089
|
1089
|
#define TEMP_MIN_ROUTINE(NR) \
|
1090
|
|
- minttemp[NR] = HEATER_ ## NR ## _MINTEMP; \
|
1091
|
|
- while(analog2temp(minttemp_raw[NR], NR) < HEATER_ ## NR ## _MINTEMP) { \
|
1092
|
|
- if (HEATER_ ## NR ## _RAW_LO_TEMP < HEATER_ ## NR ## _RAW_HI_TEMP) \
|
|
1090
|
+ minttemp[NR] = HEATER_ ##NR## _MINTEMP; \
|
|
1091
|
+ while(analog2temp(minttemp_raw[NR], NR) < HEATER_ ##NR## _MINTEMP) { \
|
|
1092
|
+ if (HEATER_ ##NR## _RAW_LO_TEMP < HEATER_ ##NR## _RAW_HI_TEMP) \
|
1093
|
1093
|
minttemp_raw[NR] += OVERSAMPLENR; \
|
1094
|
1094
|
else \
|
1095
|
1095
|
minttemp_raw[NR] -= OVERSAMPLENR; \
|
1096
|
1096
|
}
|
1097
|
1097
|
#define TEMP_MAX_ROUTINE(NR) \
|
1098
|
|
- maxttemp[NR] = HEATER_ ## NR ## _MAXTEMP; \
|
1099
|
|
- while(analog2temp(maxttemp_raw[NR], NR) > HEATER_ ## NR ## _MAXTEMP) { \
|
1100
|
|
- if (HEATER_ ## NR ## _RAW_LO_TEMP < HEATER_ ## NR ## _RAW_HI_TEMP) \
|
|
1098
|
+ maxttemp[NR] = HEATER_ ##NR## _MAXTEMP; \
|
|
1099
|
+ while(analog2temp(maxttemp_raw[NR], NR) > HEATER_ ##NR## _MAXTEMP) { \
|
|
1100
|
+ if (HEATER_ ##NR## _RAW_LO_TEMP < HEATER_ ##NR## _RAW_HI_TEMP) \
|
1101
|
1101
|
maxttemp_raw[NR] -= OVERSAMPLENR; \
|
1102
|
1102
|
else \
|
1103
|
1103
|
maxttemp_raw[NR] += OVERSAMPLENR; \
|
|
@@ -1256,7 +1256,7 @@ void Temperature::disable_all_heaters() {
|
1256
|
1256
|
#define DISABLE_HEATER(NR) { \
|
1257
|
1257
|
setTargetHotend(0, NR); \
|
1258
|
1258
|
soft_pwm[NR] = 0; \
|
1259
|
|
- WRITE_HEATER_ ## NR (LOW); \
|
|
1259
|
+ WRITE_HEATER_ ##NR (LOW); \
|
1260
|
1260
|
}
|
1261
|
1261
|
|
1262
|
1262
|
#if HAS_TEMP_HOTEND
|
|
@@ -1477,9 +1477,11 @@ void Temperature::set_current_temp_raw() {
|
1477
|
1477
|
* in OCR0B above (128 or halfway between OVFs).
|
1478
|
1478
|
*
|
1479
|
1479
|
* - Manage PWM to all the heaters and fan
|
1480
|
|
- * - Update the raw temperature values
|
1481
|
|
- * - Check new temperature values for MIN/MAX errors
|
|
1480
|
+ * - Prepare or Measure one of the raw ADC sensor values
|
|
1481
|
+ * - Check new temperature values for MIN/MAX errors (kill on error)
|
1482
|
1482
|
* - Step the babysteps value for each axis towards 0
|
|
1483
|
+ * - For PINS_DEBUGGING, monitor and report endstop pins
|
|
1484
|
+ * - For ENDSTOP_INTERRUPTS_FEATURE check endstops if flagged
|
1483
|
1485
|
*/
|
1484
|
1486
|
ISR(TIMER0_COMPB_vect) { Temperature::isr(); }
|
1485
|
1487
|
|
|
@@ -1535,37 +1537,37 @@ void Temperature::isr() {
|
1535
|
1537
|
*/
|
1536
|
1538
|
if (pwm_count == 0) {
|
1537
|
1539
|
soft_pwm_0 = soft_pwm[0];
|
1538
|
|
- WRITE_HEATER_0(soft_pwm_0 > 0 ? 1 : 0);
|
|
1540
|
+ WRITE_HEATER_0(soft_pwm_0 > 0 ? HIGH : LOW);
|
1539
|
1541
|
#if HOTENDS > 1
|
1540
|
1542
|
soft_pwm_1 = soft_pwm[1];
|
1541
|
|
- WRITE_HEATER_1(soft_pwm_1 > 0 ? 1 : 0);
|
|
1543
|
+ WRITE_HEATER_1(soft_pwm_1 > 0 ? HIGH : LOW);
|
1542
|
1544
|
#if HOTENDS > 2
|
1543
|
1545
|
soft_pwm_2 = soft_pwm[2];
|
1544
|
|
- WRITE_HEATER_2(soft_pwm_2 > 0 ? 1 : 0);
|
|
1546
|
+ WRITE_HEATER_2(soft_pwm_2 > 0 ? HIGH : LOW);
|
1545
|
1547
|
#if HOTENDS > 3
|
1546
|
1548
|
soft_pwm_3 = soft_pwm[3];
|
1547
|
|
- WRITE_HEATER_3(soft_pwm_3 > 0 ? 1 : 0);
|
|
1549
|
+ WRITE_HEATER_3(soft_pwm_3 > 0 ? HIGH : LOW);
|
1548
|
1550
|
#endif
|
1549
|
1551
|
#endif
|
1550
|
1552
|
#endif
|
1551
|
1553
|
|
1552
|
1554
|
#if HAS_HEATER_BED
|
1553
|
1555
|
soft_pwm_BED = soft_pwm_bed;
|
1554
|
|
- WRITE_HEATER_BED(soft_pwm_BED > 0 ? 1 : 0);
|
|
1556
|
+ WRITE_HEATER_BED(soft_pwm_BED > 0 ? HIGH : LOW);
|
1555
|
1557
|
#endif
|
1556
|
1558
|
|
1557
|
1559
|
#if ENABLED(FAN_SOFT_PWM)
|
1558
|
1560
|
#if HAS_FAN0
|
1559
|
1561
|
soft_pwm_fan[0] = fanSpeedSoftPwm[0] >> 1;
|
1560
|
|
- WRITE_FAN(soft_pwm_fan[0] > 0 ? 1 : 0);
|
|
1562
|
+ WRITE_FAN(soft_pwm_fan[0] > 0 ? HIGH : LOW);
|
1561
|
1563
|
#endif
|
1562
|
1564
|
#if HAS_FAN1
|
1563
|
1565
|
soft_pwm_fan[1] = fanSpeedSoftPwm[1] >> 1;
|
1564
|
|
- WRITE_FAN1(soft_pwm_fan[1] > 0 ? 1 : 0);
|
|
1566
|
+ WRITE_FAN1(soft_pwm_fan[1] > 0 ? HIGH : LOW);
|
1565
|
1567
|
#endif
|
1566
|
1568
|
#if HAS_FAN2
|
1567
|
1569
|
soft_pwm_fan[2] = fanSpeedSoftPwm[2] >> 1;
|
1568
|
|
- WRITE_FAN2(soft_pwm_fan[2] > 0 ? 1 : 0);
|
|
1570
|
+ WRITE_FAN2(soft_pwm_fan[2] > 0 ? HIGH : LOW);
|
1569
|
1571
|
#endif
|
1570
|
1572
|
#endif
|
1571
|
1573
|
}
|
|
@@ -1621,29 +1623,29 @@ void Temperature::isr() {
|
1621
|
1623
|
|
1622
|
1624
|
// Macros for Slow PWM timer logic
|
1623
|
1625
|
#define _SLOW_PWM_ROUTINE(NR, src) \
|
1624
|
|
- soft_pwm_ ## NR = src; \
|
1625
|
|
- if (soft_pwm_ ## NR > 0) { \
|
1626
|
|
- if (state_timer_heater_ ## NR == 0) { \
|
1627
|
|
- if (state_heater_ ## NR == 0) state_timer_heater_ ## NR = MIN_STATE_TIME; \
|
1628
|
|
- state_heater_ ## NR = 1; \
|
1629
|
|
- WRITE_HEATER_ ## NR(1); \
|
|
1626
|
+ soft_pwm_ ##NR = src; \
|
|
1627
|
+ if (soft_pwm_ ##NR > 0) { \
|
|
1628
|
+ if (state_timer_heater_ ##NR == 0) { \
|
|
1629
|
+ if (state_heater_ ##NR == 0) state_timer_heater_ ##NR = MIN_STATE_TIME; \
|
|
1630
|
+ state_heater_ ##NR = 1; \
|
|
1631
|
+ WRITE_HEATER_ ##NR(1); \
|
1630
|
1632
|
} \
|
1631
|
1633
|
} \
|
1632
|
1634
|
else { \
|
1633
|
|
- if (state_timer_heater_ ## NR == 0) { \
|
1634
|
|
- if (state_heater_ ## NR == 1) state_timer_heater_ ## NR = MIN_STATE_TIME; \
|
1635
|
|
- state_heater_ ## NR = 0; \
|
1636
|
|
- WRITE_HEATER_ ## NR(0); \
|
|
1635
|
+ if (state_timer_heater_ ##NR == 0) { \
|
|
1636
|
+ if (state_heater_ ##NR == 1) state_timer_heater_ ##NR = MIN_STATE_TIME; \
|
|
1637
|
+ state_heater_ ##NR = 0; \
|
|
1638
|
+ WRITE_HEATER_ ##NR(0); \
|
1637
|
1639
|
} \
|
1638
|
1640
|
}
|
1639
|
1641
|
#define SLOW_PWM_ROUTINE(n) _SLOW_PWM_ROUTINE(n, soft_pwm[n])
|
1640
|
1642
|
|
1641
|
1643
|
#define PWM_OFF_ROUTINE(NR) \
|
1642
|
|
- if (soft_pwm_ ## NR < slow_pwm_count) { \
|
1643
|
|
- if (state_timer_heater_ ## NR == 0) { \
|
1644
|
|
- if (state_heater_ ## NR == 1) state_timer_heater_ ## NR = MIN_STATE_TIME; \
|
1645
|
|
- state_heater_ ## NR = 0; \
|
1646
|
|
- WRITE_HEATER_ ## NR (0); \
|
|
1644
|
+ if (soft_pwm_ ##NR < slow_pwm_count) { \
|
|
1645
|
+ if (state_timer_heater_ ##NR == 0) { \
|
|
1646
|
+ if (state_heater_ ##NR == 1) state_timer_heater_ ##NR = MIN_STATE_TIME; \
|
|
1647
|
+ state_heater_ ##NR = 0; \
|
|
1648
|
+ WRITE_HEATER_ ##NR (0); \
|
1647
|
1649
|
} \
|
1648
|
1650
|
}
|
1649
|
1651
|
|
|
@@ -1683,15 +1685,15 @@ void Temperature::isr() {
|
1683
|
1685
|
if (pwm_count == 0) {
|
1684
|
1686
|
#if HAS_FAN0
|
1685
|
1687
|
soft_pwm_fan[0] = fanSpeedSoftPwm[0] >> 1;
|
1686
|
|
- WRITE_FAN(soft_pwm_fan[0] > 0 ? 1 : 0);
|
|
1688
|
+ WRITE_FAN(soft_pwm_fan[0] > 0 ? HIGH : LOW);
|
1687
|
1689
|
#endif
|
1688
|
1690
|
#if HAS_FAN1
|
1689
|
1691
|
soft_pwm_fan[1] = fanSpeedSoftPwm[1] >> 1;
|
1690
|
|
- WRITE_FAN1(soft_pwm_fan[1] > 0 ? 1 : 0);
|
|
1692
|
+ WRITE_FAN1(soft_pwm_fan[1] > 0 ? HIGH : LOW);
|
1691
|
1693
|
#endif
|
1692
|
1694
|
#if HAS_FAN2
|
1693
|
1695
|
soft_pwm_fan[2] = fanSpeedSoftPwm[2] >> 1;
|
1694
|
|
- WRITE_FAN2(soft_pwm_fan[2] > 0 ? 1 : 0);
|
|
1696
|
+ WRITE_FAN2(soft_pwm_fan[2] > 0 ? HIGH : LOW);
|
1695
|
1697
|
#endif
|
1696
|
1698
|
}
|
1697
|
1699
|
#if HAS_FAN0
|