xref: /qemu/tests/qtest/libqos/i2c.h (revision 907b5105f1b9e1af1abbdbb4f2039c7ab105c001)
12bf7b457SAndreas Färber /*
22bf7b457SAndreas Färber  * I2C libqos
32bf7b457SAndreas Färber  *
42bf7b457SAndreas Färber  * Copyright (c) 2012 Andreas Färber
52bf7b457SAndreas Färber  *
62bf7b457SAndreas Färber  * This work is licensed under the terms of the GNU GPL, version 2 or later.
72bf7b457SAndreas Färber  * See the COPYING file in the top-level directory.
82bf7b457SAndreas Färber  */
92bf7b457SAndreas Färber #ifndef LIBQOS_I2C_H
102bf7b457SAndreas Färber #define LIBQOS_I2C_H
112bf7b457SAndreas Färber 
12*907b5105SMarc-André Lureau #include "../libqtest.h"
13a2ce7dbdSPaolo Bonzini #include "qgraph.h"
142bf7b457SAndreas Färber 
152bf7b457SAndreas Färber typedef struct I2CAdapter I2CAdapter;
162bf7b457SAndreas Färber struct I2CAdapter {
172bf7b457SAndreas Färber     void (*send)(I2CAdapter *adapter, uint8_t addr,
182bf7b457SAndreas Färber                  const uint8_t *buf, uint16_t len);
192bf7b457SAndreas Färber     void (*recv)(I2CAdapter *adapter, uint8_t addr,
202bf7b457SAndreas Färber                  uint8_t *buf, uint16_t len);
21f1dfd507SEric Blake 
22f1dfd507SEric Blake     QTestState *qts;
232bf7b457SAndreas Färber };
242bf7b457SAndreas Färber 
2506599472SPaolo Bonzini typedef struct QI2CAddress QI2CAddress;
2606599472SPaolo Bonzini struct QI2CAddress {
2706599472SPaolo Bonzini     uint8_t addr;
2806599472SPaolo Bonzini };
2906599472SPaolo Bonzini 
30c0825c63SPaolo Bonzini typedef struct QI2CDevice QI2CDevice;
31c0825c63SPaolo Bonzini struct QI2CDevice {
32c0825c63SPaolo Bonzini     /*
33c0825c63SPaolo Bonzini      * For now, all devices are simple enough that there is no need for
34c0825c63SPaolo Bonzini      * them to define their own constructor and get_driver functions.
35c0825c63SPaolo Bonzini      * Therefore, QOSGraphObject is included directly in QI2CDevice;
36c0825c63SPaolo Bonzini      * the tests expect to get a QI2CDevice rather than doing something
37c0825c63SPaolo Bonzini      * like obj->get_driver("i2c-device").
38c0825c63SPaolo Bonzini      *
39c0825c63SPaolo Bonzini      * In fact there is no i2c-device interface even, because there are
40c0825c63SPaolo Bonzini      * no generic I2C tests).
41c0825c63SPaolo Bonzini      */
42c0825c63SPaolo Bonzini     QOSGraphObject obj;
43c0825c63SPaolo Bonzini     I2CAdapter *bus;
4406599472SPaolo Bonzini     uint8_t addr;
45c0825c63SPaolo Bonzini };
46c0825c63SPaolo Bonzini 
47c0825c63SPaolo Bonzini void *i2c_device_create(void *i2c_bus, QGuestAllocator *alloc, void *addr);
4806599472SPaolo Bonzini void add_qi2c_address(QOSGraphEdgeOptions *opts, QI2CAddress *addr);
49c0825c63SPaolo Bonzini 
5039397a9aSAlexander Bulekov void qi2c_send(QI2CDevice *dev, const uint8_t *buf, uint16_t len);
5139397a9aSAlexander Bulekov void qi2c_recv(QI2CDevice *dev, uint8_t *buf, uint16_t len);
522bf7b457SAndreas Färber 
5306599472SPaolo Bonzini void i2c_read_block(QI2CDevice *dev, uint8_t reg,
54e8ecb706SPaolo Bonzini                     uint8_t *buf, uint16_t len);
5506599472SPaolo Bonzini void i2c_write_block(QI2CDevice *dev, uint8_t reg,
56e8ecb706SPaolo Bonzini                      const uint8_t *buf, uint16_t len);
5706599472SPaolo Bonzini uint8_t i2c_get8(QI2CDevice *dev, uint8_t reg);
5806599472SPaolo Bonzini uint16_t i2c_get16(QI2CDevice *dev, uint8_t reg);
5906599472SPaolo Bonzini void i2c_set8(QI2CDevice *dev, uint8_t reg, uint8_t value);
6006599472SPaolo Bonzini void i2c_set16(QI2CDevice *dev, uint8_t reg, uint16_t value);
61e8ecb706SPaolo Bonzini 
62732c919cSPaolo Bonzini /* i2c-omap.c */
63732c919cSPaolo Bonzini typedef struct OMAPI2C {
64c0825c63SPaolo Bonzini     QOSGraphObject obj;
65732c919cSPaolo Bonzini     I2CAdapter parent;
662bf7b457SAndreas Färber 
67732c919cSPaolo Bonzini     uint64_t addr;
68732c919cSPaolo Bonzini } OMAPI2C;
69732c919cSPaolo Bonzini 
70732c919cSPaolo Bonzini void omap_i2c_init(OMAPI2C *s, QTestState *qts, uint64_t addr);
71732c919cSPaolo Bonzini 
72732c919cSPaolo Bonzini /* i2c-imx.c */
73732c919cSPaolo Bonzini typedef struct IMXI2C {
74c0825c63SPaolo Bonzini     QOSGraphObject obj;
75732c919cSPaolo Bonzini     I2CAdapter parent;
76732c919cSPaolo Bonzini 
77732c919cSPaolo Bonzini     uint64_t addr;
78732c919cSPaolo Bonzini } IMXI2C;
79732c919cSPaolo Bonzini 
80732c919cSPaolo Bonzini void imx_i2c_init(IMXI2C *s, QTestState *qts, uint64_t addr);
817f398627SJean-Christophe Dubois 
822bf7b457SAndreas Färber #endif
83