xref: /qemu/tests/qtest/pca9552-test.c (revision 06599472ec40efef3de7cb2bc98d61e8d4b18a63)
15141d415SCédric Le Goater /*
25141d415SCédric Le Goater  * QTest testcase for the PCA9552 LED blinker
35141d415SCédric Le Goater  *
45141d415SCédric Le Goater  * Copyright (c) 2017-2018, IBM Corporation.
55141d415SCédric Le Goater  *
65141d415SCédric Le Goater  * This work is licensed under the terms of the GNU GPL, version 2 or later.
75141d415SCédric Le Goater  * See the COPYING file in the top-level directory.
85141d415SCédric Le Goater  */
95141d415SCédric Le Goater 
105141d415SCédric Le Goater #include "qemu/osdep.h"
115141d415SCédric Le Goater 
125141d415SCédric Le Goater #include "libqtest.h"
1393c3fe2aSPaolo Bonzini #include "libqos/qgraph.h"
145141d415SCédric Le Goater #include "libqos/i2c.h"
155141d415SCédric Le Goater #include "hw/misc/pca9552_regs.h"
165141d415SCédric Le Goater 
175141d415SCédric Le Goater #define PCA9552_TEST_ID   "pca9552-test"
185141d415SCédric Le Goater #define PCA9552_TEST_ADDR 0x60
195141d415SCédric Le Goater 
2093c3fe2aSPaolo Bonzini static void pca9552_init(QI2CDevice *i2cdev)
21eadcd3b2SPaolo Bonzini {
22eadcd3b2SPaolo Bonzini     /* Switch on LEDs 0 and 12 */
23*06599472SPaolo Bonzini     i2c_set8(i2cdev, PCA9552_LS0, 0x54);
24*06599472SPaolo Bonzini     i2c_set8(i2cdev, PCA9552_LS3, 0x54);
25eadcd3b2SPaolo Bonzini }
26eadcd3b2SPaolo Bonzini 
2793c3fe2aSPaolo Bonzini static void receive_autoinc(void *obj, void *data, QGuestAllocator *alloc)
285141d415SCédric Le Goater {
2993c3fe2aSPaolo Bonzini     QI2CDevice *i2cdev = (QI2CDevice *)obj;
305141d415SCédric Le Goater     uint8_t resp;
315141d415SCédric Le Goater     uint8_t reg = PCA9552_LS0 | PCA9552_AUTOINC;
325141d415SCédric Le Goater 
33eadcd3b2SPaolo Bonzini     pca9552_init(i2cdev);
34eadcd3b2SPaolo Bonzini 
35*06599472SPaolo Bonzini     i2c_send(i2cdev, &reg, 1);
365141d415SCédric Le Goater 
375141d415SCédric Le Goater     /* PCA9552_LS0 */
38*06599472SPaolo Bonzini     i2c_recv(i2cdev, &resp, 1);
395141d415SCédric Le Goater     g_assert_cmphex(resp, ==, 0x54);
405141d415SCédric Le Goater 
415141d415SCédric Le Goater     /* PCA9552_LS1 */
42*06599472SPaolo Bonzini     i2c_recv(i2cdev, &resp, 1);
435141d415SCédric Le Goater     g_assert_cmphex(resp, ==, 0x55);
445141d415SCédric Le Goater 
455141d415SCédric Le Goater     /* PCA9552_LS2 */
46*06599472SPaolo Bonzini     i2c_recv(i2cdev, &resp, 1);
475141d415SCédric Le Goater     g_assert_cmphex(resp, ==, 0x55);
485141d415SCédric Le Goater 
495141d415SCédric Le Goater     /* PCA9552_LS3 */
50*06599472SPaolo Bonzini     i2c_recv(i2cdev, &resp, 1);
515141d415SCédric Le Goater     g_assert_cmphex(resp, ==, 0x54);
525141d415SCédric Le Goater }
535141d415SCédric Le Goater 
5493c3fe2aSPaolo Bonzini static void send_and_receive(void *obj, void *data, QGuestAllocator *alloc)
555141d415SCédric Le Goater {
5693c3fe2aSPaolo Bonzini     QI2CDevice *i2cdev = (QI2CDevice *)obj;
575141d415SCédric Le Goater     uint8_t value;
585141d415SCédric Le Goater 
59*06599472SPaolo Bonzini     value = i2c_get8(i2cdev, PCA9552_LS0);
605141d415SCédric Le Goater     g_assert_cmphex(value, ==, 0x55);
615141d415SCédric Le Goater 
62*06599472SPaolo Bonzini     value = i2c_get8(i2cdev, PCA9552_INPUT0);
635141d415SCédric Le Goater     g_assert_cmphex(value, ==, 0x0);
645141d415SCédric Le Goater 
65eadcd3b2SPaolo Bonzini     pca9552_init(i2cdev);
66eadcd3b2SPaolo Bonzini 
67*06599472SPaolo Bonzini     value = i2c_get8(i2cdev, PCA9552_LS0);
685141d415SCédric Le Goater     g_assert_cmphex(value, ==, 0x54);
695141d415SCédric Le Goater 
70*06599472SPaolo Bonzini     value = i2c_get8(i2cdev, PCA9552_INPUT0);
715141d415SCédric Le Goater     g_assert_cmphex(value, ==, 0x01);
725141d415SCédric Le Goater 
73*06599472SPaolo Bonzini     value = i2c_get8(i2cdev, PCA9552_LS3);
745141d415SCédric Le Goater     g_assert_cmphex(value, ==, 0x54);
755141d415SCédric Le Goater 
76*06599472SPaolo Bonzini     value = i2c_get8(i2cdev, PCA9552_INPUT1);
775141d415SCédric Le Goater     g_assert_cmphex(value, ==, 0x10);
785141d415SCédric Le Goater }
795141d415SCédric Le Goater 
8093c3fe2aSPaolo Bonzini static void pca9552_register_nodes(void)
815141d415SCédric Le Goater {
8293c3fe2aSPaolo Bonzini     QOSGraphEdgeOptions opts = {
8393c3fe2aSPaolo Bonzini         .extra_device_opts = "address=0x60"
8493c3fe2aSPaolo Bonzini     };
85*06599472SPaolo Bonzini     add_qi2c_address(&opts, &(QI2CAddress) { 0x60 });
865141d415SCédric Le Goater 
8793c3fe2aSPaolo Bonzini     qos_node_create_driver("pca9552", i2c_device_create);
8893c3fe2aSPaolo Bonzini     qos_node_consumes("pca9552", "i2c-bus", &opts);
895141d415SCédric Le Goater 
9093c3fe2aSPaolo Bonzini     qos_add_test("tx-rx", "pca9552", send_and_receive, NULL);
9193c3fe2aSPaolo Bonzini     qos_add_test("rx-autoinc", "pca9552", receive_autoinc, NULL);
925141d415SCédric Le Goater }
9393c3fe2aSPaolo Bonzini libqos_init(pca9552_register_nodes);
94