Also fix the read pin in the atmel and rp2040 ports
This commit is contained in:
parent
b5ad78715c
commit
b69a06b2ed
@ -69,9 +69,13 @@ void common_hal_paralleldisplay_parallelbus_construct(paralleldisplay_parallelbu
|
|||||||
common_hal_digitalio_digitalinout_construct(&self->write, write);
|
common_hal_digitalio_digitalinout_construct(&self->write, write);
|
||||||
common_hal_digitalio_digitalinout_switch_to_output(&self->write, true, DRIVE_MODE_PUSH_PULL);
|
common_hal_digitalio_digitalinout_switch_to_output(&self->write, true, DRIVE_MODE_PUSH_PULL);
|
||||||
|
|
||||||
|
self->read.base.type = &mp_type_NoneType;
|
||||||
|
if (read != NULL) {
|
||||||
self->read.base.type = &digitalio_digitalinout_type;
|
self->read.base.type = &digitalio_digitalinout_type;
|
||||||
common_hal_digitalio_digitalinout_construct(&self->read, read);
|
common_hal_digitalio_digitalinout_construct(&self->read, read);
|
||||||
common_hal_digitalio_digitalinout_switch_to_output(&self->read, true, DRIVE_MODE_PUSH_PULL);
|
common_hal_digitalio_digitalinout_switch_to_output(&self->read, true, DRIVE_MODE_PUSH_PULL);
|
||||||
|
never_reset_pin_number(read->number);
|
||||||
|
}
|
||||||
|
|
||||||
self->data0_pin = data_pin;
|
self->data0_pin = data_pin;
|
||||||
self->write_group = &PORT->Group[write->number / 32];
|
self->write_group = &PORT->Group[write->number / 32];
|
||||||
@ -89,7 +93,6 @@ void common_hal_paralleldisplay_parallelbus_construct(paralleldisplay_parallelbu
|
|||||||
never_reset_pin_number(command->number);
|
never_reset_pin_number(command->number);
|
||||||
never_reset_pin_number(chip_select->number);
|
never_reset_pin_number(chip_select->number);
|
||||||
never_reset_pin_number(write->number);
|
never_reset_pin_number(write->number);
|
||||||
never_reset_pin_number(read->number);
|
|
||||||
for (uint8_t i = 0; i < 8; i++) {
|
for (uint8_t i = 0; i < 8; i++) {
|
||||||
never_reset_pin_number(data_pin + i);
|
never_reset_pin_number(data_pin + i);
|
||||||
}
|
}
|
||||||
|
@ -67,9 +67,13 @@ void common_hal_paralleldisplay_parallelbus_construct(paralleldisplay_parallelbu
|
|||||||
common_hal_digitalio_digitalinout_construct(&self->chip_select, chip_select);
|
common_hal_digitalio_digitalinout_construct(&self->chip_select, chip_select);
|
||||||
common_hal_digitalio_digitalinout_switch_to_output(&self->chip_select, true, DRIVE_MODE_PUSH_PULL);
|
common_hal_digitalio_digitalinout_switch_to_output(&self->chip_select, true, DRIVE_MODE_PUSH_PULL);
|
||||||
|
|
||||||
|
self->read.base.type = &mp_type_NoneType;
|
||||||
|
if (read != NULL) {
|
||||||
self->read.base.type = &digitalio_digitalinout_type;
|
self->read.base.type = &digitalio_digitalinout_type;
|
||||||
common_hal_digitalio_digitalinout_construct(&self->read, read);
|
common_hal_digitalio_digitalinout_construct(&self->read, read);
|
||||||
common_hal_digitalio_digitalinout_switch_to_output(&self->read, true, DRIVE_MODE_PUSH_PULL);
|
common_hal_digitalio_digitalinout_switch_to_output(&self->read, true, DRIVE_MODE_PUSH_PULL);
|
||||||
|
never_reset_pin_number(read->number);
|
||||||
|
}
|
||||||
|
|
||||||
self->data0_pin = data_pin;
|
self->data0_pin = data_pin;
|
||||||
self->write = write_pin;
|
self->write = write_pin;
|
||||||
@ -86,7 +90,6 @@ void common_hal_paralleldisplay_parallelbus_construct(paralleldisplay_parallelbu
|
|||||||
never_reset_pin_number(command->number);
|
never_reset_pin_number(command->number);
|
||||||
never_reset_pin_number(chip_select->number);
|
never_reset_pin_number(chip_select->number);
|
||||||
never_reset_pin_number(write_pin);
|
never_reset_pin_number(write_pin);
|
||||||
never_reset_pin_number(read->number);
|
|
||||||
for (uint8_t i = 0; i < 8; i++) {
|
for (uint8_t i = 0; i < 8; i++) {
|
||||||
never_reset_pin_number(data_pin + i);
|
never_reset_pin_number(data_pin + i);
|
||||||
}
|
}
|
||||||
@ -121,9 +124,13 @@ void common_hal_paralleldisplay_parallelbus_deinit(paralleldisplay_parallelbus_o
|
|||||||
reset_pin_number(self->command.pin->number);
|
reset_pin_number(self->command.pin->number);
|
||||||
reset_pin_number(self->chip_select.pin->number);
|
reset_pin_number(self->chip_select.pin->number);
|
||||||
reset_pin_number(self->write);
|
reset_pin_number(self->write);
|
||||||
|
if (self->read.base.type != &mp_type_NoneType) {
|
||||||
reset_pin_number(self->read.pin->number);
|
reset_pin_number(self->read.pin->number);
|
||||||
|
}
|
||||||
|
if (self->reset.base.type != &mp_type_NoneType) {
|
||||||
reset_pin_number(self->reset.pin->number);
|
reset_pin_number(self->reset.pin->number);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
bool common_hal_paralleldisplay_parallelbus_reset(mp_obj_t obj) {
|
bool common_hal_paralleldisplay_parallelbus_reset(mp_obj_t obj) {
|
||||||
paralleldisplay_parallelbus_obj_t *self = MP_OBJ_TO_PTR(obj);
|
paralleldisplay_parallelbus_obj_t *self = MP_OBJ_TO_PTR(obj);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user