Browse Source

STM32F1 EP with USB_COMPOSITE (#19281)

vanilla_fb_2.0.x
Victor Oliveira 4 years ago
committed by Scott Lahteine
parent
commit
643f192515
  1. 18
      Marlin/src/HAL/STM32F1/msc_sd.cpp
  2. 20
      Marlin/src/HAL/STM32F1/msc_sd.h

18
Marlin/src/HAL/STM32F1/msc_sd.cpp

@ -21,7 +21,7 @@
#define PRODUCT_ID 0x29 #define PRODUCT_ID 0x29
USBMassStorage MarlinMSC; USBMassStorage MarlinMSC;
USBCompositeSerial MarlinCompositeSerial; MarlinUSBCompositeSerial MarlinCompositeSerial;
#include "../../inc/MarlinConfig.h" #include "../../inc/MarlinConfig.h"
@ -38,6 +38,17 @@ USBCompositeSerial MarlinCompositeSerial;
#endif #endif
#if ENABLED(EMERGENCY_PARSER)
void (*real_rx_callback)(void);
void my_rx_callback(void) {
real_rx_callback();
int len = MarlinCompositeSerial.available();
while (len-- > 0) // >0 because available() may return a negative value
emergency_parser.update(MarlinCompositeSerial.emergency_state, MarlinCompositeSerial.peek());
}
#endif
void MSC_SD_init() { void MSC_SD_init() {
USBComposite.setProductId(PRODUCT_ID); USBComposite.setProductId(PRODUCT_ID);
// Just set MarlinCompositeSerial enabled to true // Just set MarlinCompositeSerial enabled to true
@ -59,6 +70,11 @@ void MSC_SD_init() {
// Register composite Serial // Register composite Serial
MarlinCompositeSerial.registerComponent(); MarlinCompositeSerial.registerComponent();
USBComposite.begin(); USBComposite.begin();
#if ENABLED(EMERGENCY_PARSER)
//rx is usbSerialPart.endpoints[2]
real_rx_callback = usbSerialPart.endpoints[2].callback;
usbSerialPart.endpoints[2].callback = my_rx_callback;
#endif
} }
#endif // USE_USB_COMPOSITE #endif // USE_USB_COMPOSITE

20
Marlin/src/HAL/STM32F1/msc_sd.h

@ -17,7 +17,25 @@
#include <USBComposite.h> #include <USBComposite.h>
#include "../../inc/MarlinConfigPre.h"
#if ENABLED(EMERGENCY_PARSER)
#include "../../feature/e_parser.h"
#endif
class MarlinUSBCompositeSerial : public USBCompositeSerial {
public:
MarlinUSBCompositeSerial() : USBCompositeSerial()
#if ENABLED(EMERGENCY_PARSER)
, emergency_state(EmergencyParser::State::EP_RESET)
#endif
{ }
#if ENABLED(EMERGENCY_PARSER)
EmergencyParser::State emergency_state;
#endif
};
extern USBMassStorage MarlinMSC; extern USBMassStorage MarlinMSC;
extern USBCompositeSerial MarlinCompositeSerial; extern MarlinUSBCompositeSerial MarlinCompositeSerial;
void MSC_SD_init(); void MSC_SD_init();

Loading…
Cancel
Save