Skip to content
Snippets Groups Projects
  1. Sep 20, 2018
  2. Sep 18, 2018
  3. Sep 16, 2018
  4. Sep 15, 2018
  5. Sep 14, 2018
  6. Sep 13, 2018
    • Damien George's avatar
      py: Fix native functions so they run with their correct globals context. · 4f3d9429
      Damien George authored
      Prior to this commit a function compiled with the native decorator
      @micropython.native would not work correctly when accessing global
      variables, because the globals dict was not being set upon function entry.
      
      This commit fixes this problem by, upon function entry, setting as the
      current globals dict the globals dict context the function was defined
      within, as per normal Python semantics, and as bytecode does.  Upon
      function exit the original globals dict is restored.
      
      In order to restore the globals dict when an exception is raised the native
      function must guard its internals with an nlr_push/nlr_pop pair.  Because
      this push/pop is relatively expensive, in both C stack usage for the
      nlr_buf_t and CPU execution time, the implementation here optimises things
      as much as possible.  First, the compiler keeps track of whether a function
      even needs to access global variables.  Using this information the native
      emitter then generates three different kinds of code:
      
      1. no globals used, no exception handlers: no nlr handling code and no
         setting of the globals dict.
      
      2. globals used, no exception handlers: an nlr_buf_t is allocated on the
         C stack but it is not used if the globals dict is unchanged, saving
         execution time because nlr_push/nlr_pop don't need to run.
      
      3. function has exception handlers, may use globals: an nlr_buf_t is
         allocated and nlr_push/nlr_pop are always called.
      
      In the end, native functions that don't access globals and don't have
      exception handlers will run more efficiently than those that do.
      
      Fixes issue #1573.
      4f3d9429
  7. Sep 12, 2018
    • Damien George's avatar
      stm32/sdcard: Fully reset SDMMC periph before calling HAL DMA functions. · 9fb1f18c
      Damien George authored
      The HAL DMA functions enable SDMMC interrupts before fully resetting the
      peripheral, and this can lead to a DTIMEOUT IRQ during the initialisation
      of the DMA transfer, which then clears out the DMA state and leads to the
      read/write not working at all.  The DTIMEOUT is there from previous SDMMC
      DMA transfers, even those that succeeded, and is of duration ~180 seconds,
      which is 0xffffffff / 24MHz (default DTIMER value, and clock of
      peripheral).
      
      To work around this issue, fully reset the SDMMC peripheral before calling
      the HAL SD DMA functions.
      
      Fixes issue #4110.
      9fb1f18c
    • Damien George's avatar
      e6a6ded7
    • Damien George's avatar
    • Damien George's avatar
      extmod/moduhashlib: Use newer message digest API for mbedtls >=2.7.0. · 87d45f4d
      Damien George authored
      Since mbedtls 2.7.0 new digest functions were introduced with a "_ret"
      suffix to allow the functions to return an error message (eg, if the
      underlying hardware acceleration failed).  These new functions must be used
      instead of the old ones to prevent deprecation warnings, or link errors for
      missing functions, depending on the mbedtls configuration.
      87d45f4d
    • Damien George's avatar
    • Damien George's avatar
      stm32: Change flash IRQ priority from 2 to 6 to prevent preemption. · 0941a467
      Damien George authored
      The flash-IRQ handler is used to flush the storage cache, ie write
      outstanding block data from RAM to flash.  This is triggered by a timeout,
      or by a direct call to flush all storage caches.
      
      Prior to this commit, a timeout could trigger the cache flushing to occur
      during the execution of a read/write to external SPI flash storage.  In
      such a case the storage subsystem would break down.
      
      SPI storage transfers are already protected against USB IRQs, so by
      changing the priority of the flash IRQ to that of the USB IRQ (what is
      done in this commit) the SPI transfers can be protected against any
      timeouts triggering a cache flush (the cache flush would be postponed until
      after the transfer finished, but note that in the case of SPI writes the
      timeout is rescheduled after the transfer finishes).
      
      The handling of internal flash sync'ing needs to be changed to directly
      call flash_bdev_irq_handler() sync may be called with the IRQ priority
      already raised (eg when called from a USB MSC IRQ handler).
      0941a467
  8. Sep 11, 2018
Loading