Sfoglia il codice sorgente

msp430x5xx: Add fix for possible bug in msp430-elf-gcc 9.3.0.

William D. Jones 3 anni fa
parent
commit
731ac3d3d6
1 ha cambiato i file con 12 aggiunte e 1 eliminazioni
  1. 12 1
      src/portable/ti/msp430x5xx/dcd_msp430x5xx.c

+ 12 - 1
src/portable/ti/msp430x5xx/dcd_msp430x5xx.c

@@ -623,7 +623,18 @@ void dcd_int_handler(uint8_t rhport)
     handle_setup_packet();
   }
 
-  uint16_t curr_vector = USBVECINT;
+  // Workaround possible bug in MSP430 GCC 9.3.0 where volatile variable
+  // USBVECINT is read from twice when only once is intended. The second
+  // (garbage) read seems to be triggered by certain switch statement
+  // configurations.
+  uint16_t curr_vector;
+  #if __GNUC__ > 9 || (__GNUC__ == 9 && __GNUC_MINOR__ > 2)
+    asm volatile ("mov %1, %0"
+                  : "=r" (curr_vector)
+                  : "m" (USBVECINT));
+  #else
+    curr_vector = USBVECINT;
+  #endif
 
   switch(curr_vector)
   {