- 24 Apr, 2024 1 commit
-
-
Damien George authored
In modularize mode, the `_createMicroPythonModule()` constructor must be await'ed on, before `Module` is ready to use. Signed-off-by: Damien George <damien@micropython.org>
-
- 22 Apr, 2024 7 commits
-
-
Damien George authored
To get more insight to firmware size changes when code changes. Signed-off-by: Damien George <damien@micropython.org>
-
Angus Gratton authored
This a stop-gap until there is a proper fix for this. This work was funded through GitHub Sponsors. Signed-off-by: Angus Gratton <angus@redyak.com.au>
-
Angus Gratton authored
Two cases, one assigning to a slice. Closes https://github.com/micropython/micropython/issues/13283 Second is extending a slice from itself, similar logic. In both cases the problem occurs when m_renew causes realloc to move the buffer, leaving a dangling pointer behind. There are more complex and hard to fix cases when either argument is a memoryview into the buffer, currently resizing to a new address breaks memoryviews into that object. Reproducing this bug and confirming the fix was done by running the unix port under valgrind with GC-aware extensions. Note in default configurations with GIL this bug exists but has no impact (the free buffer won't be reused while the function is still executing, and is no longer referenced after it returns). Signed-off-by: Angus Gratton <angus@redyak.com.au>
-
Vonasmic authored
This commit swaps the order of the `flags` and `name` struct initialisers for `mp_obj_type_t`, to fix an incompatibility with C++. The original order of the initialiser didn't match the definition of the type, and although that's still legal C, it's not legal C++. Signed-off-by: Vonasmic <kasarkal123@gmail.com>
-
stijn authored
Explicit casts are needed. Fixes recent changes from 648a7578 and 94002297. Signed-off-by: stijn <stijn@ignitron.net>
-
Michiel W. Beijen authored
Signed-off-by: Michiel W. Beijen <mb@x14.nl>
-
Simon Wood authored
When `lightsleep()` is called from within a thread the interrupts may not be enabled on current core, and thus the call to `lightsleep()` never completes. Fixes issue #14092. Signed-off-by: Simon Wood <simon@mungewell.org>
-
- 20 Apr, 2024 1 commit
-
-
J. Neuschäfer authored
Fixes: https://github.com/micropython/micropython/issues/14340Signed-off-by: J. Neuschäfer <j.ne@posteo.net>
-
- 17 Apr, 2024 1 commit
-
-
Angus Gratton authored
In the case where an OUT control transfer triggers with wLength==0 (i.e. all data sent in the SETUP phase, and no additional data phase) the callbacks were previously implemented to return b"" (i.e. an empty buffer for the data phase). However this didn't actually work as intended because b"" can't provide a RW buffer (needed for OUT transfers with a data phase to write data into), so actually the endpoint would stall. The symptom was often that the device process the request (if processing it in the SETUP phase when all information was already available), but the host sees the endpoint stall and eventually returns an error. This commit changes the behaviour so returning True from the SETUP phase of a control transfer queues a zero length status response. Signed-off-by: Angus Gratton <angus@redyak.com.au>
-
- 11 Apr, 2024 1 commit
-
-
iabdalkader authored
Signed-off-by: iabdalkader <i.abdalkader@gmail.com>
-
- 30 Mar, 2024 3 commits
-
-
Damien George authored
This optimises the case where a Python function is, for example, stored to a JavaScript attribute and then later retrieved from Python. The Python function no longer needs to be a proxy with double proxying needed for the call from Python -> JavaScript -> Python. Signed-off-by: Damien George <damien@micropython.org>
-
Damien George authored
Signed-off-by: Damien George <damien@micropython.org>
-
Damien George authored
Signed-off-by: Damien George <damien@micropython.org>
-
- 29 Mar, 2024 5 commits
-
-
iabdalkader authored
Signed-off-by: iabdalkader <i.abdalkader@gmail.com>
-
iabdalkader authored
Signed-off-by: iabdalkader <i.abdalkader@gmail.com>
-
iabdalkader authored
Signed-off-by: iabdalkader <i.abdalkader@gmail.com>
-
iabdalkader authored
Use the existing metal log handling mechanism instead of overriding the metal_log, which causes build issues when logging is enabled. Signed-off-by: iabdalkader <i.abdalkader@gmail.com>
-
Damien George authored
Signed-off-by: Damien George <damien@micropython.org>
-
- 28 Mar, 2024 17 commits
-
-
Damien George authored
Ports that use axtls cannot run the `test_tls_sites.py` test because the sites it connects to use advanced ciphers. So skip this test on such ports, and add a new, simpler test that doesn't require certificate verification and works with axtls. Signed-off-by: Damien George <damien@micropython.org>
-
Damien George authored
Supporting `verify_mode` and `CERT_NONE` is required for the new `ssl.py` code, as well as `requests` to work. Signed-off-by: Damien George <damien@micropython.org>
-
Damien George authored
Signed-off-by: Damien George <damien@micropython.org>
-
Damien George authored
This is required because the .mpy native ABI was changed by the introduction of `mp_proto_fun_t`, see commits: - 416465d8 - 5e3006f1 - e2ff00e8 And three `mp_binary` functions were added to `mp_fun_table` in commit d2276f0d. Signed-off-by: Damien George <damien@micropython.org>
-
Damien George authored
Signed-off-by: Damien George <damien@micropython.org>
-
Damien George authored
These are needed to read/write array.array objects, which is useful in native code to provide fast extensions that work with big arrays of data. Signed-off-by: Damien George <damien@micropython.org>
-
robert-hh authored
Confirguration provided by by @ironss-iotec. Signed-off-by: robert-hh <robert@hammelrath.com>
-
robert-hh authored
Change provided by @ironss-iotec. Tested with Adafruit, SEEED and MiniFig boards for non-interference. Fixes issue #14190. Signed-off-by: robert-hh <robert@hammelrath.com>
-
robert-hh authored
Using a define for MICROPY_HW_SPIFLASH_BAUDRATE in mpconfigboard.h. If not defined the default is 24MHz. Signed-off-by: robert-hh <robert@hammelrath.com>
-
robert-hh authored
For all MCUs: run the test for USB clock recovery mode fallback after USB has been started. For samd21: change DFLL48 config from the open loop mode variant to sync with the XOSC32KULP. Matches better the 48MHz value. Signed-off-by: robert-hh <robert@hammelrath.com>
-
robert-hh authored
For the boards ADAFRUIT_TRINKET_M0 and MINISAM_M4. Signed-off-by: robert-hh <robert@hammelrath.com>
-
robert-hh authored
At a single place, STM32 was used instead of SAMD. Signed-off-by: robert-hh <robert@hammelrath.com>
-
iabdalkader authored
Following the same change to extmod network interfaces. Signed-off-by: iabdalkader <i.abdalkader@gmail.com>
-
iabdalkader authored
Following the same change to extmod network interfaces. Signed-off-by: iabdalkader <i.abdalkader@gmail.com>
-
iabdalkader authored
Other constants such as `machine.Pin.OUT` are defined on the class that uses them, rather than at the module level. This commit makes that the case for WLAN network interfaces, adding IF_xxx and SEC_xxx constants. The SEC_xxx constants are named as such to match the `security` keyword that they are used with. And the IF_xxx constants have IF as a prefix so they are grouped together as names. This scheme of putting constants on the class means that only the available features (eg security configurations) are made available as constants. It also means that different network interfaces (eg WLAN vs LAN) can keep their own specific constants within their class, such as PHY_xxx for LAN. Signed-off-by: iabdalkader <i.abdalkader@gmail.com>
-
iabdalkader authored
The default CYW43 WiFi AP settings were missing the security mode, leaving the AP in open mode by default. That's changed by this commit to use WPA/WPA2 by default. Signed-off-by: iabdalkader <i.abdalkader@gmail.com>
-
Matt Trentini authored
Signed-off-by: Matt Trentini <matt.trentini@gmail.com>
-
- 27 Mar, 2024 4 commits
-
-
Damien George authored
When defining custom USB devices, longer strings may be needed. Eventually the memory for string descriptors can be allocated on demand, but for now this bigger value should be reasonable. Signed-off-by: Damien George <damien@micropython.org>
-
Angus Gratton authored
Updates a few code comments that were out of date or poorly worded. No code changes. This work was funded through GitHub Sponsors. Signed-off-by: Angus Gratton <angus@redyak.com.au>
-
Angus Gratton authored
Previously, constructing the singleton USBDevice object was enough to trigger a USB disconnect on soft reset. Now it also has to be active. The only case where this changes the behaviour is if the USBDevice object has been constructed but never set to active (no more disconnect in this case). Otherwise, behaviour is the same. This change was requested by hippy on the raspberrypi forums. This work was funded through GitHub Sponsors. Signed-off-by: Angus Gratton <angus@redyak.com.au>
-
Damien George authored
Enabling this optimisation increases the RPI_PICO firmware by +3344 bytes. Performace change is: diff of scores (higher is better) N=100 M=100 rpi-base -> rpi-opt diff diff% (error%) bm_chaos.py 196.56 -> 215.26 : +18.70 = +9.514% (+/-0.05%) bm_fannkuch.py 52.47 -> 54.37 : +1.90 = +3.621% (+/-0.05%) bm_fft.py 1476.74 -> 1530.06 : +53.32 = +3.611% (+/-0.01%) bm_float.py 2305.65 -> 2444.11 : +138.46 = +6.005% (+/-0.08%) bm_hexiom.py 32.83 -> 35.09 : +2.26 = +6.884% (+/-0.05%) bm_nqueens.py 2335.85 -> 2259.78 : -76.07 = -3.257% (+/-0.06%) bm_pidigits.py 366.23 -> 465.81 : +99.58 = +27.191% (+/-0.04%) bm_wordcount.py 41.20 -> 41.87 : +0.67 = +1.626% (+/-0.01%) core_import_mpy_multi.py 327.44 -> 335.24 : +7.80 = +2.382% (+/-0.08%) core_import_mpy_single.py 63.41 -> 64.98 : +1.57 = +2.476% (+/-0.21%) core_locals.py 27.24 -> 29.19 : +1.95 = +7.159% (+/-0.01%) core_qstr.py 137.31 -> 140.84 : +3.53 = +2.571% (+/-0.03%) core_str.py 18.44 -> 18.10 : -0.34 = -1.844% (+/-0.03%) core_yield_from.py 221.69 -> 211.72 : -9.97 = -4.497% (+/-0.01%) misc_aes.py 303.38 -> 308.72 : +5.34 = +1.760% (+/-0.02%) misc_mandel.py 1501.00 -> 1746.60 : +245.60 = +16.362% (+/-0.04%) misc_pystone.py 1348.22 -> 1456.75 : +108.53 = +8.050% (+/-0.07%) misc_raytrace.py 223.81 -> 246.16 : +22.35 = +9.986% (+/-0.07%) viper_call0.py 331.05 -> 331.10 : +0.05 = +0.015% (+/-0.00%) viper_call1a.py 323.34 -> 323.39 : +0.05 = +0.015% (+/-0.00%) viper_call1b.py 241.01 -> 241.04 : +0.03 = +0.012% (+/-0.00%) viper_call1c.py 242.88 -> 242.92 : +0.04 = +0.016% (+/-0.00%) viper_call2a.py 318.41 -> 318.46 : +0.05 = +0.016% (+/-0.00%) viper_call2b.py 211.27 -> 211.30 : +0.03 = +0.014% (+/-0.00%) And the test `tests/basics/builtin_pow3_intbig.py` now passes (it uses a lot of mpz code and previously took longer than 10 seconds to run on RPI_PICO, which would lead to a timeout in the test runner). Signed-off-by: Damien George <damien@micropython.org>
-