Scott Lahteine пре 8 година
родитељ
комит
3752d9aca8
2 измењених фајлова са 39 додато и 10 уклоњено
  1. 19
    5
      Marlin/stepper.cpp
  2. 20
    5
      Marlin/temperature.cpp

+ 19
- 5
Marlin/stepper.cpp Прегледај датотеку

@@ -311,8 +311,20 @@ void Stepper::set_directions() {
311 311
   #endif // !ADVANCE && !LIN_ADVANCE
312 312
 }
313 313
 
314
-// "The Stepper Driver Interrupt" - This timer interrupt is the workhorse.
315
-// It pops blocks from the block_buffer and executes them by pulsing the stepper pins appropriately.
314
+/**
315
+ * Stepper Driver Interrupt
316
+ *
317
+ * Directly pulses the stepper motors at high frequency.
318
+ * Timer 1 runs at a base frequency of 2MHz, with this ISR using OCR1A compare mode.
319
+ *
320
+ * OCR1A   Frequency
321
+ *     1     2 MHz
322
+ *    50    40 KHz
323
+ *   100    20 KHz - capped max rate
324
+ *   200    10 KHz - nominal max rate
325
+ *  2000     1 KHz - sleep rate
326
+ *  4000   500  Hz - init rate
327
+ */
316 328
 ISR(TIMER1_COMPA_vect) { Stepper::isr(); }
317 329
 
318 330
 void Stepper::isr() {
@@ -323,7 +335,7 @@ void Stepper::isr() {
323 335
       if ((cleaning_buffer_counter == 1) && (SD_FINISHED_STEPPERRELEASE)) enqueue_and_echo_commands_P(PSTR(SD_FINISHED_RELEASECOMMAND));
324 336
     #endif
325 337
     cleaning_buffer_counter--;
326
-    OCR1A = 200;
338
+    OCR1A = 200; // Run at max speed - 10 KHz
327 339
     return;
328 340
   }
329 341
 
@@ -348,7 +360,7 @@ void Stepper::isr() {
348 360
       #if ENABLED(Z_LATE_ENABLE)
349 361
         if (current_block->steps[Z_AXIS] > 0) {
350 362
           enable_z();
351
-          OCR1A = 2000; //1ms wait
363
+          OCR1A = 2000; // Run at slow speed - 1 KHz
352 364
           return;
353 365
         }
354 366
       #endif
@@ -358,7 +370,7 @@ void Stepper::isr() {
358 370
       // #endif
359 371
     }
360 372
     else {
361
-      OCR1A = 2000; // 1kHz.
373
+      OCR1A = 2000; // Run at slow speed - 1 KHz
362 374
       return;
363 375
     }
364 376
   }
@@ -903,6 +915,7 @@ void Stepper::init() {
903 915
   // output mode = 00 (disconnected)
904 916
   TCCR1A &= ~(3 << COM1A0);
905 917
   TCCR1A &= ~(3 << COM1B0);
918
+
906 919
   // Set the timer pre-scaler
907 920
   // Generally we use a divider of 8, resulting in a 2MHz timer
908 921
   // frequency on a 16MHz MCU. If you are going to change this, be
@@ -910,6 +923,7 @@ void Stepper::init() {
910 923
   // create_speed_lookuptable.py
911 924
   TCCR1B = (TCCR1B & ~(0x07 << CS10)) | (2 << CS10);
912 925
 
926
+  // Init Stepper ISR to 122 Hz for quick starting
913 927
   OCR1A = 0x4000;
914 928
   TCNT1 = 0;
915 929
   ENABLE_STEPPER_DRIVER_INTERRUPT();

+ 20
- 5
Marlin/temperature.cpp Прегледај датотеку

@@ -1371,7 +1371,7 @@ void Temperature::set_current_temp_raw() {
1371 1371
  * Timer 0 is shared with millies so don't change the prescaler.
1372 1372
  *
1373 1373
  * This ISR uses the compare method so it runs at the base
1374
- * frequency (16 MHz / 256 = 62500 Hz), but at the TCNT0 set
1374
+ * frequency (16 MHz / 64 / 256 = 976.5625 Hz), but at the TCNT0 set
1375 1375
  * in OCR0B above (128 or halfway between OVFs).
1376 1376
  *
1377 1377
  *  - Manage PWM to all the heaters and fan
@@ -1485,9 +1485,16 @@ void Temperature::isr() {
1485 1485
       #endif
1486 1486
     #endif
1487 1487
 
1488
-    // 488.28 Hz (or 1:976.56, 2:1953.12, 3:3906.25, 4:7812.5, 5:7812.5 6:15625, 6:15625 7:31250)
1488
+    // SOFT_PWM_SCALE to frequency:
1489
+    //
1490
+    // 0: 16000000/64/256/128 =   7.6294 Hz
1491
+    // 1:                / 64 =  15.2588 Hz
1492
+    // 2:                / 32 =  30.5176 Hz
1493
+    // 3:                / 16 =  61.0352 Hz
1494
+    // 4:                /  8 = 122.0703 Hz
1495
+    // 5:                /  4 = 244.1406 Hz
1489 1496
     pwm_count += _BV(SOFT_PWM_SCALE);
1490
-    pwm_count &= 0x7f;
1497
+    pwm_count &= 0x7F;
1491 1498
 
1492 1499
   #else // SLOW_PWM_HEATERS
1493 1500
 
@@ -1586,10 +1593,18 @@ void Temperature::isr() {
1586 1593
       #endif
1587 1594
     #endif //FAN_SOFT_PWM
1588 1595
 
1596
+    // SOFT_PWM_SCALE to frequency:
1597
+    //
1598
+    // 0: 16000000/64/256/128 =   7.6294 Hz
1599
+    // 1:                / 64 =  15.2588 Hz
1600
+    // 2:                / 32 =  30.5176 Hz
1601
+    // 3:                / 16 =  61.0352 Hz
1602
+    // 4:                /  8 = 122.0703 Hz
1603
+    // 5:                /  4 = 244.1406 Hz
1589 1604
     pwm_count += _BV(SOFT_PWM_SCALE);
1590
-    pwm_count &= 0x7f;
1605
+    pwm_count &= 0x7F;
1591 1606
 
1592
-    // increment slow_pwm_count only every 64 pwm_count circa 65.5ms
1607
+    // increment slow_pwm_count only every 64 pwm_count (e.g., every 8s)
1593 1608
     if ((pwm_count % 64) == 0) {
1594 1609
       slow_pwm_count++;
1595 1610
       slow_pwm_count &= 0x7f;

Loading…
Откажи
Сачувај