merge finished

This commit is contained in:
Dan Halbert 2018-07-28 13:29:47 -04:00
parent bc760dd341
commit f48b70050e
19 changed files with 66 additions and 68 deletions

View File

@ -29,14 +29,6 @@
#include "py/runtime.h" #include "py/runtime.h"
static void check_not_unicode(const mp_obj_t arg) {
#if MICROPY_CPYTHON_COMPAT
if (MP_OBJ_IS_STR(arg)) {
mp_raise_TypeError("a bytes-like object is required");
}
#endif
}
#if MICROPY_PY_UHASHLIB #if MICROPY_PY_UHASHLIB
#if MICROPY_PY_UHASHLIB_SHA256 #if MICROPY_PY_UHASHLIB_SHA256
@ -102,6 +94,14 @@ STATIC mp_obj_t uhashlib_sha256_digest(mp_obj_t self_in) {
#else #else
static void check_not_unicode(const mp_obj_t arg) {
#if MICROPY_CPYTHON_COMPAT
if (MP_OBJ_IS_STR(arg)) {
mp_raise_TypeError("a bytes-like object is required");
}
#endif
}
STATIC mp_obj_t uhashlib_sha256_make_new(const mp_obj_type_t *type, size_t n_args, size_t n_kw, const mp_obj_t *args) { STATIC mp_obj_t uhashlib_sha256_make_new(const mp_obj_type_t *type, size_t n_args, size_t n_kw, const mp_obj_t *args) {
mp_arg_check_num(n_args, n_kw, 0, 1, false); mp_arg_check_num(n_args, n_kw, 0, 1, false);
mp_obj_hash_t *o = m_new_obj_var(mp_obj_hash_t, char, sizeof(CRYAL_SHA256_CTX)); mp_obj_hash_t *o = m_new_obj_var(mp_obj_hash_t, char, sizeof(CRYAL_SHA256_CTX));

View File

@ -60,15 +60,6 @@ typedef struct _pyb_file_obj_t {
FIL fp; FIL fp;
} pyb_file_obj_t; } pyb_file_obj_t;
// These should be general types (mpy TOOD says so). In micropython, these are defined in
// mpconfigport.h.
////////////#define mp_type_fileio mp_type_vfs_fat_fileio
////////////#define mp_type_textio mp_type_vfs_fat_textio
////////////extern const mp_obj_type_t mp_type_fileio;
////////////extern const mp_obj_type_t mp_type_textio;
extern const byte fresult_to_errno_table[20]; extern const byte fresult_to_errno_table[20];
extern const mp_obj_type_t mp_fat_vfs_type; extern const mp_obj_type_t mp_fat_vfs_type;
extern const mp_obj_type_t mp_type_vfs_fat_fileio; extern const mp_obj_type_t mp_type_vfs_fat_fileio;

View File

@ -75,8 +75,9 @@ DRESULT disk_read (
return RES_ERROR; return RES_ERROR;
} }
} else { } else {
mp_obj_array_t ar = {{&mp_type_bytearray}, BYTEARRAY_TYPECODE, 0, count * SECSIZE(&vfs->fatfs), buff};
vfs->readblocks[2] = MP_OBJ_NEW_SMALL_INT(sector); vfs->readblocks[2] = MP_OBJ_NEW_SMALL_INT(sector);
vfs->readblocks[3] = mp_obj_new_bytearray_by_ref(count * SECSIZE(&vfs->fatfs), buff); vfs->readblocks[3] = MP_OBJ_FROM_PTR(&ar);
nlr_buf_t nlr; nlr_buf_t nlr;
if (nlr_push(&nlr) == 0) { if (nlr_push(&nlr) == 0) {
mp_obj_t ret = mp_call_method_n_kw(2, 0, vfs->readblocks); mp_obj_t ret = mp_call_method_n_kw(2, 0, vfs->readblocks);
@ -120,8 +121,9 @@ DRESULT disk_write (
return RES_ERROR; return RES_ERROR;
} }
} else { } else {
mp_obj_array_t ar = {{&mp_type_bytearray}, BYTEARRAY_TYPECODE, 0, count * SECSIZE(&vfs->fatfs), (void*)buff};
vfs->writeblocks[2] = MP_OBJ_NEW_SMALL_INT(sector); vfs->writeblocks[2] = MP_OBJ_NEW_SMALL_INT(sector);
vfs->writeblocks[3] = mp_obj_new_bytearray_by_ref(count * SECSIZE(&vfs->fatfs), (void*)buff); vfs->writeblocks[3] = MP_OBJ_FROM_PTR(&ar);
nlr_buf_t nlr; nlr_buf_t nlr;
if (nlr_push(&nlr) == 0) { if (nlr_push(&nlr) == 0) {
mp_obj_t ret = mp_call_method_n_kw(2, 0, vfs->writeblocks); mp_obj_t ret = mp_call_method_n_kw(2, 0, vfs->writeblocks);

View File

@ -26,6 +26,8 @@
#ifndef MICROPY_INCLUDED_LIB_MP_READLINE_READLINE_H #ifndef MICROPY_INCLUDED_LIB_MP_READLINE_READLINE_H
#define MICROPY_INCLUDED_LIB_MP_READLINE_READLINE_H #define MICROPY_INCLUDED_LIB_MP_READLINE_READLINE_H
#include "py/misc.h"
#define CHAR_CTRL_A (1) #define CHAR_CTRL_A (1)
#define CHAR_CTRL_B (2) #define CHAR_CTRL_B (2)
#define CHAR_CTRL_C (3) #define CHAR_CTRL_C (3)

View File

@ -123,6 +123,9 @@ typedef long mp_off_t;
#define MP_PLAT_PRINT_STRN(str, len) mp_hal_stdout_tx_strn_cooked(str, len) #define MP_PLAT_PRINT_STRN(str, len) mp_hal_stdout_tx_strn_cooked(str, len)
#define mp_type_fileio mp_type_vfs_fat_fileio
#define mp_type_textio mp_type_vfs_fat_textio
#define mp_import_stat mp_vfs_import_stat #define mp_import_stat mp_vfs_import_stat
#define mp_builtin_open_obj mp_vfs_open_obj #define mp_builtin_open_obj mp_vfs_open_obj

View File

@ -29,5 +29,5 @@
#include "espneopixel.h" #include "espneopixel.h"
void common_hal_neopixel_write(const digitalio_digitalinout_obj_t* digitalinout, uint8_t *pixels, uint32_t numBytes) { void common_hal_neopixel_write(const digitalio_digitalinout_obj_t* digitalinout, uint8_t *pixels, uint32_t numBytes) {
esp_neopixel_write(digitalinout->pin->gpio_number, pixels, numBytes); esp_neopixel_write(digitalinout->pin->gpio_number, pixels, numBytes, true /*800 kHz*/);
} }

View File

@ -35,18 +35,15 @@
#include "extmod/misc.h" #include "extmod/misc.h"
#include "lib/utils/pyexec.h" #include "lib/utils/pyexec.h"
STATIC byte stdin_ringbuf_array[256]; STATIC byte input_buf_array[256];
ringbuf_t stdin_ringbuf = {stdin_ringbuf_array, sizeof(stdin_ringbuf_array), 0, 0}; ringbuf_t stdin_ringbuf = {input_buf_array, sizeof(input_buf_array)};
void mp_hal_debug_tx_strn_cooked(void *env, const char *str, uint32_t len); void mp_hal_debug_tx_strn_cooked(void *env, const char *str, uint32_t len);
const mp_print_t mp_debug_print = {NULL, mp_hal_debug_tx_strn_cooked}; const mp_print_t mp_debug_print = {NULL, mp_hal_debug_tx_strn_cooked};
int uart_attached_to_dupterm;
void mp_hal_init(void) { void mp_hal_init(void) {
//ets_wdt_disable(); // it's a pain while developing //ets_wdt_disable(); // it's a pain while developing
mp_hal_rtc_init(); mp_hal_rtc_init();
uart_init(UART_BIT_RATE_115200, UART_BIT_RATE_115200); uart_init(UART_BIT_RATE_115200, UART_BIT_RATE_115200);
uart_attached_to_dupterm = 0;
} }
void mp_hal_delay_us(uint32_t us) { void mp_hal_delay_us(uint32_t us) {
@ -87,11 +84,19 @@ void mp_hal_debug_str(const char *str) {
#endif #endif
void mp_hal_stdout_tx_str(const char *str) { void mp_hal_stdout_tx_str(const char *str) {
mp_uos_dupterm_tx_strn(str, strlen(str)); const char *last = str;
while (*str) {
uart_tx_one_char(UART0, *str++);
}
mp_uos_dupterm_tx_strn(last, str - last);
} }
void mp_hal_stdout_tx_strn(const char *str, uint32_t len) { void mp_hal_stdout_tx_strn(const char *str, uint32_t len) {
mp_uos_dupterm_tx_strn(str, len); const char *last = str;
while (len--) {
uart_tx_one_char(UART0, *str++);
}
mp_uos_dupterm_tx_strn(last, str - last);
} }
void mp_hal_stdout_tx_strn_cooked(const char *str, uint32_t len) { void mp_hal_stdout_tx_strn_cooked(const char *str, uint32_t len) {
@ -101,11 +106,13 @@ void mp_hal_stdout_tx_strn_cooked(const char *str, uint32_t len) {
if (str > last) { if (str > last) {
mp_uos_dupterm_tx_strn(last, str - last); mp_uos_dupterm_tx_strn(last, str - last);
} }
uart_tx_one_char(UART0, '\r');
uart_tx_one_char(UART0, '\n');
mp_uos_dupterm_tx_strn("\r\n", 2); mp_uos_dupterm_tx_strn("\r\n", 2);
++str; ++str;
last = str; last = str;
} else { } else {
++str; uart_tx_one_char(UART0, *str++);
} }
} }
if (str > last) { if (str > last) {

View File

@ -40,9 +40,6 @@ void mp_hal_signal_input(void);
// Call this when data is available in dupterm object // Call this when data is available in dupterm object
void mp_hal_signal_dupterm_input(void); void mp_hal_signal_dupterm_input(void);
// This variable counts how many times the UART is attached to dupterm
extern int uart_attached_to_dupterm;
void mp_hal_init(void); void mp_hal_init(void);
void mp_hal_rtc_init(void); void mp_hal_rtc_init(void);

View File

@ -34,11 +34,6 @@ static int uart_os = UART_OS;
static os_event_t uart_evt_queue[16]; static os_event_t uart_evt_queue[16];
#endif #endif
// A small, static ring buffer for incoming chars
// This will only be populated if the UART is not attached to dupterm
static byte uart_ringbuf_array[16];
static ringbuf_t uart_ringbuf = {uart_ringbuf_array, sizeof(uart_ringbuf_array), 0, 0};
static void uart0_rx_intr_handler(void *para); static void uart0_rx_intr_handler(void *para);
void soft_reset(void); void soft_reset(void);
@ -175,26 +170,18 @@ static void uart0_rx_intr_handler(void *para) {
while (READ_PERI_REG(UART_STATUS(uart_no)) & (UART_RXFIFO_CNT << UART_RXFIFO_CNT_S)) { while (READ_PERI_REG(UART_STATUS(uart_no)) & (UART_RXFIFO_CNT << UART_RXFIFO_CNT_S)) {
uint8 RcvChar = READ_PERI_REG(UART_FIFO(uart_no)) & 0xff; uint8 RcvChar = READ_PERI_REG(UART_FIFO(uart_no)) & 0xff;
// For efficiency, when connected to dupterm we put incoming chars if (RcvChar == mp_interrupt_char) {
// directly on stdin_ringbuf, rather than going via uart_ringbuf mp_keyboard_interrupt();
if (uart_attached_to_dupterm) {
if (RcvChar == mp_interrupt_char) {
mp_keyboard_interrupt();
} else {
ringbuf_put(&stdin_ringbuf, RcvChar);
}
} else { } else {
ringbuf_put(&uart_ringbuf, RcvChar); ringbuf_put(&stdin_ringbuf, RcvChar);
} }
} }
mp_hal_signal_input();
// Clear pending FIFO interrupts // Clear pending FIFO interrupts
WRITE_PERI_REG(UART_INT_CLR(UART_REPL), UART_RXFIFO_TOUT_INT_CLR | UART_RXFIFO_FULL_INT_ST); WRITE_PERI_REG(UART_INT_CLR(UART_REPL), UART_RXFIFO_TOUT_INT_CLR | UART_RXFIFO_FULL_INT_ST);
ETS_UART_INTR_ENABLE(); ETS_UART_INTR_ENABLE();
if (uart_attached_to_dupterm) {
mp_hal_signal_input();
}
} }
} }
@ -203,7 +190,7 @@ static void uart0_rx_intr_handler(void *para) {
bool uart_rx_wait(uint32_t timeout_us) { bool uart_rx_wait(uint32_t timeout_us) {
uint32_t start = system_get_time(); uint32_t start = system_get_time();
for (;;) { for (;;) {
if (uart_ringbuf.iget != uart_ringbuf.iput) { if (stdin_ringbuf.iget != stdin_ringbuf.iput) {
return true; // have at least 1 char ready for reading return true; // have at least 1 char ready for reading
} }
if (system_get_time() - start >= timeout_us) { if (system_get_time() - start >= timeout_us) {
@ -214,7 +201,7 @@ bool uart_rx_wait(uint32_t timeout_us) {
} }
int uart_rx_any(uint8 uart) { int uart_rx_any(uint8 uart) {
if (uart_ringbuf.iget != uart_ringbuf.iput) { if (stdin_ringbuf.iget != stdin_ringbuf.iput) {
return true; // have at least 1 char ready for reading return true; // have at least 1 char ready for reading
} }
return false; return false;
@ -230,7 +217,7 @@ int uart_tx_any_room(uint8 uart) {
// Returns char from the input buffer, else -1 if buffer is empty. // Returns char from the input buffer, else -1 if buffer is empty.
int uart_rx_char(void) { int uart_rx_char(void) {
return ringbuf_get(&uart_ringbuf); return ringbuf_get(&stdin_ringbuf);
} }
int uart_rx_one_char(uint8 uart_no) { int uart_rx_one_char(uint8 uart_no) {
@ -288,7 +275,7 @@ void uart_task_handler(os_event_t *evt) {
} }
int c, ret = 0; int c, ret = 0;
while ((c = ringbuf_get(&input_buf)) >= 0) { while ((c = ringbuf_get(&stdin_ringbuf)) >= 0) {
if (c == mp_interrupt_char) { if (c == mp_interrupt_char) {
mp_keyboard_interrupt(); mp_keyboard_interrupt();
} }

View File

@ -109,7 +109,7 @@ STATIC mp_obj_t scan_entry_get_scan_data(mp_obj_t self_in) {
vstr_t vstr; vstr_t vstr;
vstr_init(&vstr, len); vstr_init(&vstr, len);
vstr_printf(&vstr, "%s", text); vstr_printf(&vstr, "%s", text);
description = mp_obj_new_str(vstr.buf, vstr.len, false); description = mp_obj_new_str(vstr.buf, vstr.len);
vstr_clear(&vstr); vstr_clear(&vstr);
} }
} }

View File

@ -49,7 +49,7 @@ STATIC void adv_event_handler(mp_obj_t self_in, uint16_t event_id, ble_drv_adv_d
data->p_peer_addr[5], data->p_peer_addr[4], data->p_peer_addr[3], data->p_peer_addr[5], data->p_peer_addr[4], data->p_peer_addr[3],
data->p_peer_addr[2], data->p_peer_addr[1], data->p_peer_addr[0]); data->p_peer_addr[2], data->p_peer_addr[1], data->p_peer_addr[0]);
item->addr = mp_obj_new_str(vstr.buf, vstr.len, false); item->addr = mp_obj_new_str(vstr.buf, vstr.len);
vstr_clear(&vstr); vstr_clear(&vstr);

View File

@ -261,6 +261,9 @@ coverage_test: coverage
gcov -o build-coverage/py $(TOP)/py/*.c gcov -o build-coverage/py $(TOP)/py/*.c
gcov -o build-coverage/extmod $(TOP)/extmod/*.c gcov -o build-coverage/extmod $(TOP)/extmod/*.c
coverage_clean:
$(MAKE) V=2 BUILD=build-coverage PROG=micropython_coverage clean
# Value of configure's --host= option (required for cross-compilation). # Value of configure's --host= option (required for cross-compilation).
# Deduce it from CROSS_COMPILE by default, but can be overridden. # Deduce it from CROSS_COMPILE by default, but can be overridden.
ifneq ($(CROSS_COMPILE),) ifneq ($(CROSS_COMPILE),)

View File

@ -173,7 +173,7 @@ STATIC mp_obj_t extra_coverage(void) {
gc_unlock(); gc_unlock();
// using gc_realloc to resize to 0, which means free the memory // using gc_realloc to resize to 0, which means free the memory
void *p = gc_alloc(4, false); void *p = gc_alloc(4, false, false);
mp_printf(&mp_plat_print, "%p\n", gc_realloc(p, 0, false)); mp_printf(&mp_plat_print, "%p\n", gc_realloc(p, 0, false));
// calling gc_nbytes with a non-heap pointer // calling gc_nbytes with a non-heap pointer

View File

@ -148,7 +148,7 @@ mp_obj_t mp_binary_get_val_array(char typecode, void *p, mp_uint_t index) {
#endif #endif
#if MICROPY_PY_BUILTINS_FLOAT #if MICROPY_PY_BUILTINS_FLOAT
case 'f': case 'f':
return mp_obj_new_float((mp_float_t)((float*)p)[index]); return mp_obj_new_float(((float*)p)[index]);
case 'd': case 'd':
return mp_obj_new_float(((double*)p)[index]); return mp_obj_new_float(((double*)p)[index]);
#endif #endif
@ -213,7 +213,7 @@ mp_obj_t mp_binary_get_val(char struct_type, char val_type, byte **ptr) {
#if MICROPY_NONSTANDARD_TYPECODES #if MICROPY_NONSTANDARD_TYPECODES
} else if (val_type == 'S') { } else if (val_type == 'S') {
const char *s_val = (const char*)(uintptr_t)(mp_uint_t)val; const char *s_val = (const char*)(uintptr_t)(mp_uint_t)val;
return mp_obj_new_str(s_val, strlen(s_val), false); return mp_obj_new_str(s_val, strlen(s_val));
#endif #endif
#if MICROPY_PY_BUILTINS_FLOAT #if MICROPY_PY_BUILTINS_FLOAT
} else if (val_type == 'f') { } else if (val_type == 'f') {

View File

@ -43,8 +43,14 @@ extern const char mp_frozen_str_names[];
extern const uint32_t mp_frozen_str_sizes[]; extern const uint32_t mp_frozen_str_sizes[];
extern const char mp_frozen_str_content[]; extern const char mp_frozen_str_content[];
// On input, *len contains size of name, on output - size of content // str_len is length of str. *len is set on on output to size of content
const char *mp_find_frozen_str(const char *str, size_t str_len, size_t *len) { const char *mp_find_frozen_str(const char *str, size_t str_len, size_t *len) {
// If the frozen module pseudo dir (e.g., ".frozen/") is a prefix of str, remove it.
if (strncmp(str, MP_FROZEN_FAKE_DIR_SLASH, MP_FROZEN_FAKE_DIR_SLASH_LENGTH) == 0) {
str = str + MP_FROZEN_FAKE_DIR_SLASH_LENGTH;
str_len = str_len - MP_FROZEN_FAKE_DIR_SLASH_LENGTH;
}
const char *name = mp_frozen_str_names; const char *name = mp_frozen_str_names;
size_t offset = 0; size_t offset = 0;

View File

@ -39,7 +39,7 @@
typedef struct _mp_obj_namedtuple_type_t { typedef struct _mp_obj_namedtuple_type_t {
mp_obj_type_t base; mp_obj_type_t base;
mp_uint_t n_fields; size_t n_fields;
qstr fields[]; qstr fields[];
} mp_obj_namedtuple_type_t; } mp_obj_namedtuple_type_t;
@ -48,9 +48,9 @@ typedef struct _mp_obj_namedtuple_t {
} mp_obj_namedtuple_t; } mp_obj_namedtuple_t;
void namedtuple_print(const mp_print_t *print, mp_obj_t o_in, mp_print_kind_t kind); void namedtuple_print(const mp_print_t *print, mp_obj_t o_in, mp_print_kind_t kind);
size_t mp_obj_namedtuple_find_field(const mp_obj_namedtuple_type_t *type, qstr name);
void namedtuple_attr(mp_obj_t self_in, qstr attr, mp_obj_t *dest); void namedtuple_attr(mp_obj_t self_in, qstr attr, mp_obj_t *dest);
mp_obj_namedtuple_type_t *mp_obj_new_namedtuple_base(size_t n_fields, mp_obj_t *fields);
mp_obj_t namedtuple_make_new(const mp_obj_type_t *type_in, size_t n_args, size_t n_kw, const mp_obj_t *args); mp_obj_t namedtuple_make_new(const mp_obj_type_t *type_in, size_t n_args, size_t n_kw, const mp_obj_t *args);
#endif // MICROPY_PY_COLLECTIONS #endif // MICROPY_PY_COLLECTIONS

View File

@ -86,7 +86,7 @@ STATIC mp_obj_t bleio_adapter_get_address(mp_obj_t self) {
common_hal_bleio_adapter_get_address(&vstr); common_hal_bleio_adapter_get_address(&vstr);
const mp_obj_t mac_str = mp_obj_new_str(vstr.buf, vstr.len, false); const mp_obj_t mac_str = mp_obj_new_str(vstr.buf, vstr.len);
vstr_clear(&vstr); vstr_clear(&vstr);

View File

@ -1,3 +1,3 @@
mod0 ValueError incompatible .mpy file mod0 ValueError Incompatible .mpy file. Please update all .mpy files. See http://adafru.it/mpy-update for more info.
mod1 ValueError incompatible .mpy file mod1 ValueError Incompatible .mpy file. Please update all .mpy files. See http://adafru.it/mpy-update for more info.
mod2 ValueError incompatible .mpy file mod2 ValueError Incompatible .mpy file. Please update all .mpy files. See http://adafru.it/mpy-update for more info.

View File

@ -396,7 +396,7 @@ def run_tests(pyb, tests, args, base_path=".", num_threads=1):
if pat.search(test_file): if pat.search(test_file):
verdict = action verdict = action
if verdict == "exclude": if verdict == "exclude":
continue return
test_basename = os.path.basename(test_file) test_basename = os.path.basename(test_file)
test_name = os.path.splitext(test_basename)[0] test_name = os.path.splitext(test_basename)[0]
@ -419,7 +419,7 @@ def run_tests(pyb, tests, args, base_path=".", num_threads=1):
if args.list_tests: if args.list_tests:
if not skip_it: if not skip_it:
print(test_file) print(test_file)
continue return
if skip_it: if skip_it:
print("skip ", test_file) print("skip ", test_file)