Suspend Servos for STM32+NeoPixel (#19963)
This commit is contained in:
		| @@ -29,6 +29,7 @@ | ||||
| #include "../shared/math_32bit.h" | ||||
| #include "../shared/HAL_SPI.h" | ||||
| #include "fastio.h" | ||||
| #include "Servo.h" | ||||
| #include "watchdog.h" | ||||
| #include "MarlinSerial.h" | ||||
|  | ||||
| @@ -110,6 +111,8 @@ | ||||
| typedef int16_t pin_t; | ||||
|  | ||||
| #define HAL_SERVO_LIB libServo | ||||
| #define PAUSE_SERVO_OUTPUT() libServo::pause_all_servos() | ||||
| #define RESUME_SERVO_OUTPUT() libServo::resume_all_servos() | ||||
|  | ||||
| // ------------------------ | ||||
| // Public Variables | ||||
|   | ||||
| @@ -28,15 +28,6 @@ | ||||
|  | ||||
| #include "../shared/eeprom_api.h" | ||||
|  | ||||
| #if HAS_SERVOS | ||||
|   #include "Servo.h" | ||||
|   #define PAUSE_SERVO_OUTPUT() libServo::pause_all_servos() | ||||
|   #define RESUME_SERVO_OUTPUT() libServo::resume_all_servos() | ||||
| #else | ||||
|   #define PAUSE_SERVO_OUTPUT() | ||||
|   #define RESUME_SERVO_OUTPUT() | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * The STM32 HAL supports chips that deal with "pages" and some with "sectors" and some that | ||||
|  * even have multiple "banks" of flash. | ||||
| @@ -172,11 +163,11 @@ bool PersistentStore::access_finish() { | ||||
|         current_slot = EEPROM_SLOTS - 1; | ||||
|         UNLOCK_FLASH(); | ||||
|  | ||||
|         PAUSE_SERVO_OUTPUT(); | ||||
|         TERN_(HAS_PAUSE_SERVO_OUTPUT, PAUSE_SERVO_OUTPUT()); | ||||
|         DISABLE_ISRS(); | ||||
|         status = HAL_FLASHEx_Erase(&EraseInitStruct, &SectorError); | ||||
|         ENABLE_ISRS(); | ||||
|         RESUME_SERVO_OUTPUT(); | ||||
|         TERN_(HAS_PAUSE_SERVO_OUTPUT, RESUME_SERVO_OUTPUT()); | ||||
|         if (status != HAL_OK) { | ||||
|           DEBUG_ECHOLNPAIR("HAL_FLASHEx_Erase=", status); | ||||
|           DEBUG_ECHOLNPAIR("GetError=", HAL_FLASH_GetError()); | ||||
| @@ -227,11 +218,11 @@ bool PersistentStore::access_finish() { | ||||
|       // Interrupts during this time can have unpredictable results, such as killing Servo | ||||
|       // output. Servo output still glitches with interrupts disabled, but recovers after the | ||||
|       // erase. | ||||
|       PAUSE_SERVO_OUTPUT(); | ||||
|       TERN_(HAS_PAUSE_SERVO_OUTPUT, PAUSE_SERVO_OUTPUT()); | ||||
|       DISABLE_ISRS(); | ||||
|       eeprom_buffer_flush(); | ||||
|       ENABLE_ISRS(); | ||||
|       RESUME_SERVO_OUTPUT(); | ||||
|       TERN_(HAS_PAUSE_SERVO_OUTPUT, RESUME_SERVO_OUTPUT()); | ||||
|  | ||||
|       eeprom_data_written = false; | ||||
|     #endif | ||||
|   | ||||
| @@ -105,6 +105,8 @@ public: | ||||
|   } | ||||
|  | ||||
|   static inline void show() { | ||||
|     // Some platforms cannot maintain PWM output when NeoPixel disables interrupts for long durations. | ||||
|     TERN_(HAS_PAUSE_SERVO_OUTPUT, PAUSE_SERVO_OUTPUT()); | ||||
|     adaneo1.show(); | ||||
|     #if PIN_EXISTS(NEOPIXEL2) | ||||
|       #if CONJOINED_NEOPIXEL | ||||
| @@ -115,6 +117,7 @@ public: | ||||
|         adaneo1.setPin(NEOPIXEL_PIN); | ||||
|       #endif | ||||
|     #endif | ||||
|     TERN_(HAS_PAUSE_SERVO_OUTPUT, RESUME_SERVO_OUTPUT()); | ||||
|   } | ||||
|  | ||||
|   #if 0 | ||||
|   | ||||
| @@ -1997,6 +1997,9 @@ | ||||
| #if NUM_SERVOS > 0 | ||||
|   #define HAS_SERVOS 1 | ||||
| #endif | ||||
| #if HAS_SERVOS && defined(PAUSE_SERVO_OUTPUT) && defined(RESUME_SERVO_OUTPUT) | ||||
|   #define HAS_PAUSE_SERVO_OUTPUT 1 | ||||
| #endif | ||||
|  | ||||
| // Sensors | ||||
| #if PIN_EXISTS(FILWIDTH) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user