1. 06 May, 2019 3 commits
  2. 03 May, 2019 3 commits
  3. 02 May, 2019 5 commits
    • Nguyen Hoan Hoang's avatar
      nrf/boards: Add support for BLYST Nano module based boards. · 9a6f6fd6
      Nguyen Hoan Hoang authored
      - IBK-BLYST-NANO: Breakout board
      - IDK-BLYST-NANO: DevKit board with builtin IDAP-M CMSIS-DAP Debug JTAG,
        RGB led
      - BLUEIO-TAG-EVIM: Sensor tag board (environmental sensor
        (T, H, P, Air quality) + 9 axis motion sensor)
      
      Also, the LED module has been updated to support individual base level
      configuration of each LED. If set, this will be used instead of the
      common configuration, MICROPY_HW_LED_PULLUP. The new configuration,
      MICROPY_HW_LEDX_LEVEL, where X is the LED number can be used to set
      the base level of the specific LED.
      9a6f6fd6
    • Chris Mason's avatar
      stm32/boards: Add NUCLEO_F413ZH board configuration. · 2a791170
      Chris Mason authored
      The alternate function pin allocations are different to other NUCLEO-144
      boards.  This is because the STM32F413 has a very high peripheral count:
      10x UART, 5x SPI, 3x I2C, 3x CAN.  The pinout was chosen to expose all
      these devices on separate pins except CAN3 which shares a pin with UART1
      and SPI1 which shares pins with DAC.
      2a791170
    • Chris Mason's avatar
      stm32: Add support for F413 MCUs. · 1b956ec8
      Chris Mason authored
      Includes:
      - Support for CAN3.
      - Support for UART9 and UART10.
      - stm32f413xg.ld and stm32f413xh.ld linker scripts.
      - stm32f413_af.csv alternate function mapping.
      - startup_stm32f413xx.s because F413 has different interrupt vector table.
      - Memory configuration with: 240K filesystem, 240K heap, 16K stack.
      1b956ec8
    • Damien George's avatar
    • Damien George's avatar
      stm32/powerctrl: Support changing frequency when HSI is clock source. · 3fbf32b9
      Damien George authored
      This patch makes pllvalues.py generate two tables: one for when HSI is used
      and one for when HSE is used.  The correct table is then selected at
      compile time via the existing MICROPY_HW_CLK_USE_HSI.
      3fbf32b9
  4. 01 May, 2019 7 commits
  5. 30 Apr, 2019 4 commits
    • Paul Sokolovsky's avatar
      tests/ussl_basic: Disable setblocking() calls. · 7b540013
      Paul Sokolovsky authored
      Now that setblocking() is implemented in modussl_axtls, it calls into the
      underlying stream object, and io.BytesIO doesn't have setblocking().
      7b540013
    • Paul Sokolovsky's avatar
      extmod/modussl_axtls: Add non-blocking mode support. · c7644531
      Paul Sokolovsky authored
      It consists of:
      
      1. "do_handhake" param (default True) to wrap_socket(). If it's False,
      handshake won't be performed by wrap_socket(), as it would be done in
      blocking way normally. Instead, SSL socket can be set to non-blocking mode,
      and handshake would be performed before the first read/write request (by
      just returning EAGAIN to these requests, while instead reading/writing/
      processing handshake over the connection). Unfortunately, axTLS doesn't
      really support non-blocking handshake correctly. So, while framework for
      this is implemented on MicroPython's module side, in case of axTLS, it
      won't work reliably.
      
      2. Implementation of .setblocking() method. It must be called on SSL socket
      for blocking vs non-blocking operation to be handled correctly (for
      example, it's not enough to wrap non-blocking socket with wrap_socket()
      call - resulting SSL socket won't be itself non-blocking).  Note that
      .setblocking() propagates call to the underlying socket object, as
      expected.
      c7644531
    • Paul Sokolovsky's avatar
      extmod/modussl_mbedtls: Support non-blocking handshake. · 9c7c0823
      Paul Sokolovsky authored
      For this, add wrap_socket(do_handshake=False) param. CPython doesn't have
      such a param at a module's global function, and at SSLContext.wrap_socket()
      it has do_handshake_on_connect param, but that uselessly long.
      
      Beyond that, make write() handle not just MBEDTLS_ERR_SSL_WANT_WRITE, but
      also MBEDTLS_ERR_SSL_WANT_READ, as during handshake, write call may be
      actually preempted by need to read next handshake message from peer.
      Likewise, for read(). And even after the initial negotiation, situations
      like that may happen e.g. with renegotiation. Both
      MBEDTLS_ERR_SSL_WANT_READ and MBEDTLS_ERR_SSL_WANT_WRITE are however mapped
      to the same None return code. The idea is that if the same read()/write()
      method is called repeatedly, the progress will be made step by step anyway.
      The caveat is if user wants to add the underlying socket to uselect.poll().
      To be reliable, in this case, the socket should be polled for both POLL_IN
      and POLL_OUT, as we don't know the actual expected direction. But that's
      actually problematic. Consider for example that write() ends with
      MBEDTLS_ERR_SSL_WANT_READ, but gets converted to None. We put the
      underlying socket on pull using POLL_IN|POLL_OUT but that probably returns
      immediately with POLL_OUT, as underlyings socket is writable. We call the
      same ussl write() again, which again results in MBEDTLS_ERR_SSL_WANT_READ,
      etc. We thus go into busy-loop.
      
      So, the handling in this patch is temporary and needs fixing. But exact way
      to fix it is not clear. One way is to provide explicit function for
      handshake (CPython has do_handshake()), and let *that* return distinct
      codes like WANT_READ/WANT_WRITE. But as mentioned above, past the initial
      handshake, such situation may happen again with at least renegotiation. So
      apparently, the only robust solution is to return "out of bound" special
      sentinels like WANT_READ/WANT_WRITE from read()/write() directly. CPython
      throws exceptions for these, but those are expensive to adopt that way for
      efficiency-conscious implementation like MicroPython.
      9c7c0823
    • Krono's avatar
      esp32/machine_wdt: Add timeout arg to select interval, make WDT panic. · fbd4e61e
      Krono authored
      The machine.WDT() now accepts the "timeout" keyword argument to select the
      WDT interval.  And the WDT is changed to panic mode which means it will
      reset the device if the interval expires (instead of just printing an error
      message).
      fbd4e61e
  6. 29 Apr, 2019 1 commit
    • Damien George's avatar
      stm32/powerctrl: Deselect PLLSAI as 48MHz src before turning off PLLSAI. · 8031b7a2
      Damien George authored
      On the STM32F722 (at least, but STM32F767 is not affected) the CK48MSEL bit
      must be deselected before PLLSAION is turned off, or else the 48MHz
      peripherals (RNG, SDMMC, USB) may get stuck without a clock source.
      
      In such "lock up" cases it seems that these peripherals are still being
      clocked from the PLLSAI even though the CK48MSEL bit is turned off.  A hard
      reset does not get them out of this stuck state.  Enabling the PLLSAI and
      then disabling it does get them out.  A test case to see this is:
      
          import machine, pyb
          for i in range(100):
              machine.freq(122_000000)
              machine.freq(120_000000)
              print(i, [pyb.rng() for _ in range(4)])
      
      On occasion the RNG will just return 0's, but will get fixed again on the
      next loop (when PLLSAI is enabled by the change to a SYSCLK of 122MHz).
      
      Fixes issue #4696.
      8031b7a2
  7. 28 Apr, 2019 6 commits
  8. 26 Apr, 2019 4 commits
  9. 25 Apr, 2019 1 commit
    • Damien George's avatar
      tools/pyboard.py: Don't accumulate output data if data_consumer used. · 56f6ceba
      Damien George authored
      Prior to this patch, when a lot of data was output by a running script
      pyboard.py would try to capture all of this output into the "data"
      variable, which would gradually slow down pyboard.py to the point where it
      would have large CPU and memory usage (on the host) and potentially lose
      data.
      
      This patch fixes this problem by not accumulating the data in the case that
      the data is not needed, which is when "data_consumer" is used.
      56f6ceba
  10. 24 Apr, 2019 1 commit
    • Damien George's avatar
      stm32/dac: Rework DAC driver to use direct register access. · aa7b32c8
      Damien George authored
      This patch makes the DAC driver simpler and removes the need for the ST
      HAL.  As part of it, new helper functions are added to the DMA driver,
      which also use direct register access instead of the ST HAL.
      
      Main changes to the DAC interface are:
      
      - The DAC uPy object is no longer allocated dynamically on the heap,
        rather it's statically allocated and the same object is retrieved for
        subsequent uses of pyb.DAC(<id>).  This allows to access the DAC objects
        without resetting the DAC peripheral.  It also means that the DAC is only
        reset if explicitly passed initialisation parameters, like "bits" or
        "buffering".
      
      - The DAC.noise() and DAC.triangle() methods now output a signal which is
        full scale (previously it was a fraction of the full output voltage).
      
      - The DAC.write_timed() method is fixed so that it continues in the
        background when another peripheral (eg SPI) uses the DMA (previously the
        DAC would stop if another peripheral finished with the DMA and shut the
        DMA peripheral off completely).
      
      Based on the above, the following backwards incompatibilities are
      introduced:
      
      - pyb.DAC(id) will now only reset the DAC the first time it is called,
        whereas previously each call to create a DAC object would reset the DAC.
        To get the old behaviour pass the bits parameter like: pyb.DAC(id, bits).
      
      - DAC.noise() and DAC.triangle() are now full scale.  To get previous
        behaviour (to change the amplitude and offset) write to the DAC_CR (MAMP
        bits) and DAC_DHR12Rx registers manually.
      aa7b32c8
  11. 23 Apr, 2019 1 commit
  12. 18 Apr, 2019 4 commits