Fixed I2CDisplay reset issue
This commit is contained in:
parent
91156670e9
commit
39b38256fd
|
@ -42,20 +42,7 @@
|
|||
void common_hal_displayio_i2cdisplay_construct(displayio_i2cdisplay_obj_t* self,
|
||||
busio_i2c_obj_t* i2c, uint16_t device_address, const mcu_pin_obj_t* reset) {
|
||||
|
||||
// Probe the bus to see if a device acknowledges the given address.
|
||||
if (!common_hal_busio_i2c_probe(i2c, device_address)) {
|
||||
mp_raise_ValueError_varg(translate("Unable to find I2C Display at %x"), device_address);
|
||||
}
|
||||
|
||||
// Write to the device and return 0 on success or an appropriate error code from mperrno.h
|
||||
self->bus = i2c;
|
||||
common_hal_busio_i2c_never_reset(self->bus);
|
||||
// Our object is statically allocated off the heap so make sure the bus object lives to the end
|
||||
// of the heap as well.
|
||||
gc_never_free(self->bus);
|
||||
|
||||
self->address = device_address;
|
||||
|
||||
// Reset the display before probing
|
||||
self->reset.base.type = &mp_type_NoneType;
|
||||
if (reset != NULL) {
|
||||
self->reset.base.type = &digitalio_digitalinout_type;
|
||||
|
@ -64,6 +51,20 @@ void common_hal_displayio_i2cdisplay_construct(displayio_i2cdisplay_obj_t* self,
|
|||
never_reset_pin_number(reset->number);
|
||||
common_hal_displayio_i2cdisplay_reset(self);
|
||||
}
|
||||
|
||||
// Probe the bus to see if a device acknowledges the given address.
|
||||
if (!common_hal_busio_i2c_probe(i2c, device_address)) {
|
||||
mp_raise_ValueError_varg(translate("Unable to find I2C Display at %x"), device_address);
|
||||
}
|
||||
|
||||
// Write to the device and return 0 on success or an appropriate error code from mperrno.h
|
||||
self->bus = i2c;
|
||||
common_hal_busio_i2c_never_reset(self->bus);
|
||||
// Our object is statically allocated off the heap so make sure the bus object lives to the end
|
||||
// of the heap as well.
|
||||
gc_never_free(self->bus);
|
||||
|
||||
self->address = device_address;
|
||||
}
|
||||
|
||||
void common_hal_displayio_i2cdisplay_deinit(displayio_i2cdisplay_obj_t* self) {
|
||||
|
|
Loading…
Reference in New Issue