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