mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-04 00:03:54 -06:00
misc/pca9552: Fix inverted input status
The pca9552 INPUT0 and INPUT1 registers are supposed to hold the logical values of the LED pins. A logical 0 should be seen in the INPUT0/1 registers for a pin when its corresponding LSn bits are set to 0, which is also the state needed for turning on an LED in a typical usage scenario. Existing code was doing the opposite and setting INPUT0/1 bit to a 1 when the LSn bit was set to 0, so this commit fixes that. Reviewed-by: Andrew Jeffery <andrew@codeconstruct.com.au> Signed-off-by: Glenn Miles <milesg@linux.vnet.ibm.com> Signed-off-by: Nicholas Piggin <npiggin@gmail.com>
This commit is contained in:
parent
21465ade7f
commit
7b99fb30b3
2 changed files with 16 additions and 8 deletions
|
@ -60,7 +60,7 @@ static void send_and_receive(void *obj, void *data, QGuestAllocator *alloc)
|
|||
g_assert_cmphex(value, ==, 0x55);
|
||||
|
||||
value = i2c_get8(i2cdev, PCA9552_INPUT0);
|
||||
g_assert_cmphex(value, ==, 0x0);
|
||||
g_assert_cmphex(value, ==, 0xFF);
|
||||
|
||||
pca9552_init(i2cdev);
|
||||
|
||||
|
@ -68,13 +68,13 @@ static void send_and_receive(void *obj, void *data, QGuestAllocator *alloc)
|
|||
g_assert_cmphex(value, ==, 0x54);
|
||||
|
||||
value = i2c_get8(i2cdev, PCA9552_INPUT0);
|
||||
g_assert_cmphex(value, ==, 0x01);
|
||||
g_assert_cmphex(value, ==, 0xFE);
|
||||
|
||||
value = i2c_get8(i2cdev, PCA9552_LS3);
|
||||
g_assert_cmphex(value, ==, 0x54);
|
||||
|
||||
value = i2c_get8(i2cdev, PCA9552_INPUT1);
|
||||
g_assert_cmphex(value, ==, 0x10);
|
||||
g_assert_cmphex(value, ==, 0xEF);
|
||||
}
|
||||
|
||||
static void pca9552_register_nodes(void)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue