commit
359d8e5773
@ -108,6 +108,7 @@ STATIC void reset_single_pwmout(uint8_t i) {
|
|||||||
|
|
||||||
for (int ch = 0; ch < CHANNELS_PER_PWM; ch++) {
|
for (int ch = 0; ch < CHANNELS_PER_PWM; ch++) {
|
||||||
pwm_seq[i][ch] = (1 << 15); // polarity = 0
|
pwm_seq[i][ch] = (1 << 15); // polarity = 0
|
||||||
|
pwm->PSEL.OUT[ch] = 0xFFFFFFFF; // disconnnect from I/O
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -85,7 +85,7 @@ static void shared_callback(busio_uart_obj_t *self) {
|
|||||||
_copy_into_ringbuf(&self->ringbuf, self->uart);
|
_copy_into_ringbuf(&self->ringbuf, self->uart);
|
||||||
// We always clear the interrupt so it doesn't continue to fire because we
|
// We always clear the interrupt so it doesn't continue to fire because we
|
||||||
// may not have read everything available.
|
// may not have read everything available.
|
||||||
uart_get_hw(self->uart)->icr = UART_UARTICR_RXIC_BITS;
|
uart_get_hw(self->uart)->icr = UART_UARTICR_RXIC_BITS | UART_UARTICR_RTIC_BITS;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void uart0_callback(void) {
|
static void uart0_callback(void) {
|
||||||
|
@ -28,7 +28,6 @@
|
|||||||
#include "ringbuf.h"
|
#include "ringbuf.h"
|
||||||
|
|
||||||
bool ringbuf_init(ringbuf_t *r, uint8_t *buf, size_t capacity) {
|
bool ringbuf_init(ringbuf_t *r, uint8_t *buf, size_t capacity) {
|
||||||
r->heap = false;
|
|
||||||
r->buf = buf;
|
r->buf = buf;
|
||||||
r->size = capacity;
|
r->size = capacity;
|
||||||
r->iget = r->iput = 0;
|
r->iget = r->iput = 0;
|
||||||
@ -40,7 +39,6 @@ bool ringbuf_init(ringbuf_t *r, uint8_t *buf, size_t capacity) {
|
|||||||
// size of the buffer is one greater than that, due to how the buffer
|
// size of the buffer is one greater than that, due to how the buffer
|
||||||
// handles empty and full statuses.
|
// handles empty and full statuses.
|
||||||
bool ringbuf_alloc(ringbuf_t *r, size_t capacity, bool long_lived) {
|
bool ringbuf_alloc(ringbuf_t *r, size_t capacity, bool long_lived) {
|
||||||
r->heap = true;
|
|
||||||
r->buf = gc_alloc(capacity + 1, false, long_lived);
|
r->buf = gc_alloc(capacity + 1, false, long_lived);
|
||||||
r->size = capacity + 1;
|
r->size = capacity + 1;
|
||||||
r->iget = r->iput = 0;
|
r->iget = r->iput = 0;
|
||||||
@ -48,9 +46,8 @@ bool ringbuf_alloc(ringbuf_t *r, size_t capacity, bool long_lived) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void ringbuf_free(ringbuf_t *r) {
|
void ringbuf_free(ringbuf_t *r) {
|
||||||
if (r->heap) {
|
// Free buf by letting gc take care of it. If the VM has finished already,
|
||||||
gc_free(r->buf);
|
// this will be safe.
|
||||||
}
|
|
||||||
r->buf = (uint8_t *)NULL;
|
r->buf = (uint8_t *)NULL;
|
||||||
r->size = 0;
|
r->size = 0;
|
||||||
ringbuf_clear(r);
|
ringbuf_clear(r);
|
||||||
|
@ -37,7 +37,6 @@ typedef struct _ringbuf_t {
|
|||||||
uint32_t size;
|
uint32_t size;
|
||||||
uint32_t iget;
|
uint32_t iget;
|
||||||
uint32_t iput;
|
uint32_t iput;
|
||||||
bool heap;
|
|
||||||
} ringbuf_t;
|
} ringbuf_t;
|
||||||
|
|
||||||
// Note that the capacity of the buffer is N-1!
|
// Note that the capacity of the buffer is N-1!
|
||||||
|
8
py/vm.c
8
py/vm.c
@ -739,8 +739,8 @@ unwind_jump:;
|
|||||||
obj = mp_getiter(obj, iter_buf);
|
obj = mp_getiter(obj, iter_buf);
|
||||||
if (obj != MP_OBJ_FROM_PTR(iter_buf)) {
|
if (obj != MP_OBJ_FROM_PTR(iter_buf)) {
|
||||||
// Iterator didn't use the stack so indicate that with MP_OBJ_NULL.
|
// Iterator didn't use the stack so indicate that with MP_OBJ_NULL.
|
||||||
sp[-MP_OBJ_ITER_BUF_NSLOTS + 1] = MP_OBJ_NULL;
|
*(sp - MP_OBJ_ITER_BUF_NSLOTS + 1) = MP_OBJ_NULL;
|
||||||
sp[-MP_OBJ_ITER_BUF_NSLOTS + 2] = obj;
|
*(sp - MP_OBJ_ITER_BUF_NSLOTS + 2) = obj;
|
||||||
}
|
}
|
||||||
DISPATCH();
|
DISPATCH();
|
||||||
}
|
}
|
||||||
@ -751,8 +751,8 @@ unwind_jump:;
|
|||||||
DECODE_ULABEL; // the jump offset if iteration finishes; for labels are always forward
|
DECODE_ULABEL; // the jump offset if iteration finishes; for labels are always forward
|
||||||
code_state->sp = sp;
|
code_state->sp = sp;
|
||||||
mp_obj_t obj;
|
mp_obj_t obj;
|
||||||
if (sp[-MP_OBJ_ITER_BUF_NSLOTS + 1] == MP_OBJ_NULL) {
|
if (*(sp - MP_OBJ_ITER_BUF_NSLOTS + 1) == MP_OBJ_NULL) {
|
||||||
obj = sp[-MP_OBJ_ITER_BUF_NSLOTS + 2];
|
obj = *(sp - MP_OBJ_ITER_BUF_NSLOTS + 2);
|
||||||
} else {
|
} else {
|
||||||
obj = MP_OBJ_FROM_PTR(&sp[-MP_OBJ_ITER_BUF_NSLOTS + 1]);
|
obj = MP_OBJ_FROM_PTR(&sp[-MP_OBJ_ITER_BUF_NSLOTS + 1]);
|
||||||
}
|
}
|
||||||
|
@ -4,10 +4,12 @@ huffman
|
|||||||
# For nvm.toml
|
# For nvm.toml
|
||||||
cascadetoml
|
cascadetoml
|
||||||
jinja2
|
jinja2
|
||||||
typer
|
# Undo this pin when click and typer are again compatible.
|
||||||
|
typer==0.4.0
|
||||||
|
|
||||||
sh
|
sh
|
||||||
click
|
# Undo this pin when click and typer are again compatible.
|
||||||
|
click==8.0.4
|
||||||
cpp-coveralls
|
cpp-coveralls
|
||||||
requests
|
requests
|
||||||
requests-cache
|
requests-cache
|
||||||
|
@ -364,7 +364,7 @@ audioio_get_buffer_result_t audiomp3_mp3file_get_buffer(audiomp3_mp3file_obj_t *
|
|||||||
}
|
}
|
||||||
|
|
||||||
self->samples_decoded += *buffer_length / sizeof(int16_t);
|
self->samples_decoded += *buffer_length / sizeof(int16_t);
|
||||||
return GET_BUFFER_MORE_DATA;
|
return mp3file_find_sync_word(self) ? GET_BUFFER_MORE_DATA : GET_BUFFER_DONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
void audiomp3_mp3file_get_buffer_structure(audiomp3_mp3file_obj_t *self, bool single_channel_output,
|
void audiomp3_mp3file_get_buffer_structure(audiomp3_mp3file_obj_t *self, bool single_channel_output,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user