summaryrefslogtreecommitdiffstatshomepage
path: root/esp8266
diff options
context:
space:
mode:
authorPaul Sokolovsky <pfalcon@users.sourceforge.net>2016-03-27 15:34:35 +0300
committerPaul Sokolovsky <pfalcon@users.sourceforge.net>2016-03-27 15:34:35 +0300
commitbbc65d4eda1c0e11a1352227baf574ef981b2dda (patch)
tree314637308580389449d80595aabf5c1e3504aaf4 /esp8266
parentfd86bf591762abe8b9167494667f87928f105473 (diff)
downloadmicropython-bbc65d4eda1c0e11a1352227baf574ef981b2dda.tar.gz
micropython-bbc65d4eda1c0e11a1352227baf574ef981b2dda.zip
esp8266/modesp: flash_read(): Accept buffer to read to as a second argument.
Diffstat (limited to 'esp8266')
-rw-r--r--esp8266/modesp.c28
1 files changed, 23 insertions, 5 deletions
diff --git a/esp8266/modesp.c b/esp8266/modesp.c
index 29b18d862d..442f656bf4 100644
--- a/esp8266/modesp.c
+++ b/esp8266/modesp.c
@@ -535,16 +535,34 @@ STATIC mp_obj_t esp_flash_id() {
}
STATIC MP_DEFINE_CONST_FUN_OBJ_0(esp_flash_id_obj, esp_flash_id);
-STATIC mp_obj_t esp_flash_read(mp_obj_t offset_in, mp_obj_t len_in) {
+STATIC mp_obj_t esp_flash_read(mp_obj_t offset_in, mp_obj_t len_or_buf_in) {
mp_int_t offset = mp_obj_get_int(offset_in);
- mp_int_t len = mp_obj_get_int(len_in);
- byte *buf = m_new(byte, len);
+
+ mp_int_t len;
+ byte *buf;
+ bool alloc_buf = MP_OBJ_IS_INT(len_or_buf_in);
+
+ if (alloc_buf) {
+ len = mp_obj_get_int(len_or_buf_in);
+ buf = m_new(byte, len);
+ } else {
+ mp_buffer_info_t bufinfo;
+ mp_get_buffer_raise(len_or_buf_in, &bufinfo, MP_BUFFER_WRITE);
+ len = bufinfo.len;
+ buf = bufinfo.buf;
+ }
+
// We know that allocation will be 4-byte aligned for sure
SpiFlashOpResult res = spi_flash_read(offset, (uint32_t*)buf, len);
if (res == SPI_FLASH_RESULT_OK) {
- return mp_obj_new_bytes(buf, len);
+ if (alloc_buf) {
+ return mp_obj_new_bytes(buf, len);
+ }
+ return mp_const_none;
+ }
+ if (alloc_buf) {
+ m_del(byte, buf, len);
}
- m_del(byte, buf, len);
nlr_raise(mp_obj_new_exception_arg1(&mp_type_OSError, MP_OBJ_NEW_SMALL_INT(res == SPI_FLASH_RESULT_TIMEOUT ? ETIMEDOUT : EIO)));
}
STATIC MP_DEFINE_CONST_FUN_OBJ_2(esp_flash_read_obj, esp_flash_read);