diff --git a/stm/lcd.c b/stm/lcd.c index 0f645eb9302794f3ab6842ddbdf853b06b4f4efd..ee4f4da4e0431e54de841db066a00ee65ccaa350 100644 --- a/stm/lcd.c +++ b/stm/lcd.c @@ -198,8 +198,8 @@ void lcd_print_strn(const char *str, unsigned int len) { chr = 127; } const uint8_t *chr_data = &font_petme128_8x8[(chr - 32) * 8]; - for (int i = 0; i < 8; i++) { - lcd_out(LCD_DATA, chr_data[i]); + for (int j = 0; j < 8; j++) { + lcd_out(LCD_DATA, chr_data[j]); } } @@ -207,3 +207,14 @@ void lcd_print_strn(const char *str, unsigned int len) { sys_tick_delay_ms(200); } } + +// writes 8 vertical pixels +// pos 0 is upper left, pos 1 is 8 pixels to right of that, pos 128 is 8 pixels below that +void lcd_draw_pixel_8(int pos, int val) { + int page = pos / 128; + int offset = pos - (page * 128); + lcd_out(LCD_INSTR, 0xb0 | page); // page address set + lcd_out(LCD_INSTR, 0x10 | ((offset >> 4) & 0x0f)); // column address set upper + lcd_out(LCD_INSTR, 0x00 | (offset & 0x0f)); // column address set lower + lcd_out(LCD_DATA, val); // write data +} diff --git a/stm/lcd.h b/stm/lcd.h index 7b243ee7e302b7d5a6971a8e6a2d8613e34af460..56c541698ea5527859c2c0bf9dea9765b625927b 100644 --- a/stm/lcd.h +++ b/stm/lcd.h @@ -1,3 +1,4 @@ void lcd_init(void); void lcd_print_str(const char *str); void lcd_print_strn(const char *str, unsigned int len); +void lcd_draw_pixel_8(int pos, int val); diff --git a/stm/main.c b/stm/main.c index 0837f1972f49a0cafaea40b4501eb0804ca1f499..96b923ad1a265c07e7ed1065f316a5c30f2f72d9 100644 --- a/stm/main.c +++ b/stm/main.c @@ -603,6 +603,13 @@ py_obj_t pyb_rtc_read(void) { return py_const_none; } +py_obj_t pyb_lcd8(py_obj_t pos, py_obj_t val) { + int pos_val = py_get_int(pos); + int val_val = py_get_int(val); + lcd_draw_pixel_8(pos_val, val_val); + return py_const_none; +} + int main(void) { // TODO disable JTAG @@ -673,6 +680,7 @@ soft_reset: rt_store_attr(m, qstr_from_str_static("uout"), rt_make_function_1(pyb_usart_send)); rt_store_attr(m, qstr_from_str_static("uin"), rt_make_function_0(pyb_usart_receive)); rt_store_attr(m, qstr_from_str_static("ustat"), rt_make_function_0(pyb_usart_status)); + rt_store_attr(m, qstr_from_str_static("lcd8"), rt_make_function_2(pyb_lcd8)); rt_store_name(qstr_from_str_static("pyb"), m); } @@ -1027,3 +1035,8 @@ soft_reset: printf("PYB: soft reboot\n"); goto soft_reset; } + +double __aeabi_f2d(float x) { + // TODO + return 0.0; +} diff --git a/stm/mpyconfig.h b/stm/mpyconfig.h index 388ad1cc4d9f5cd2add9cb9b1fb9a0bde5f2e619..06a4bd8e022f513bd30eb45a093261fc098fb065 100644 --- a/stm/mpyconfig.h +++ b/stm/mpyconfig.h @@ -1,6 +1,6 @@ // options to control how Micro Python is built -#define MICROPY_ENABLE_FLOAT (0) +#define MICROPY_ENABLE_FLOAT (1) #define MICROPY_EMIT_CPYTHON (0) #define MICROPY_EMIT_X64 (0) #define MICROPY_EMIT_THUMB (1)