1*64b70da0SThomas Gleixner /* SPDX-License-Identifier: GPL-2.0-or-later */
2f7018c21STomi Valkeinen /*
3f7018c21STomi Valkeinen * Copyright 2011 Florian Tobias Schandinat <FlorianSchandinat@gmx.de>
4f7018c21STomi Valkeinen */
5f7018c21STomi Valkeinen /*
6f7018c21STomi Valkeinen * infrastructure for devices connected via I2C
7f7018c21STomi Valkeinen */
8f7018c21STomi Valkeinen
9f7018c21STomi Valkeinen #ifndef __VIA_AUX_H__
10f7018c21STomi Valkeinen #define __VIA_AUX_H__
11f7018c21STomi Valkeinen
12f7018c21STomi Valkeinen
13f7018c21STomi Valkeinen #include <linux/list.h>
14f7018c21STomi Valkeinen #include <linux/i2c.h>
15f7018c21STomi Valkeinen #include <linux/fb.h>
16f7018c21STomi Valkeinen
17f7018c21STomi Valkeinen
18f7018c21STomi Valkeinen struct via_aux_bus {
19f7018c21STomi Valkeinen struct i2c_adapter *adap; /* the I2C device to access the bus */
20f7018c21STomi Valkeinen struct list_head drivers; /* drivers for devices on this bus */
21f7018c21STomi Valkeinen };
22f7018c21STomi Valkeinen
23f7018c21STomi Valkeinen struct via_aux_drv {
24f7018c21STomi Valkeinen struct list_head chain; /* chain to support multiple drivers */
25f7018c21STomi Valkeinen
26f7018c21STomi Valkeinen struct via_aux_bus *bus; /* the I2C bus used */
27f7018c21STomi Valkeinen u8 addr; /* the I2C slave address */
28f7018c21STomi Valkeinen
29f7018c21STomi Valkeinen const char *name; /* human readable name of the driver */
30f7018c21STomi Valkeinen void *data; /* private data of this driver */
31f7018c21STomi Valkeinen
32f7018c21STomi Valkeinen void (*cleanup)(struct via_aux_drv *drv);
33f7018c21STomi Valkeinen const struct fb_videomode* (*get_preferred_mode)
34f7018c21STomi Valkeinen (struct via_aux_drv *drv);
35f7018c21STomi Valkeinen };
36f7018c21STomi Valkeinen
37f7018c21STomi Valkeinen
38f7018c21STomi Valkeinen struct via_aux_bus *via_aux_probe(struct i2c_adapter *adap);
39f7018c21STomi Valkeinen void via_aux_free(struct via_aux_bus *bus);
40f7018c21STomi Valkeinen const struct fb_videomode *via_aux_get_preferred_mode(struct via_aux_bus *bus);
41f7018c21STomi Valkeinen
42f7018c21STomi Valkeinen
via_aux_add(struct via_aux_drv * drv)43f7018c21STomi Valkeinen static inline bool via_aux_add(struct via_aux_drv *drv)
44f7018c21STomi Valkeinen {
45f7018c21STomi Valkeinen struct via_aux_drv *data = kmalloc(sizeof(*data), GFP_KERNEL);
46f7018c21STomi Valkeinen
47f7018c21STomi Valkeinen if (!data)
48f7018c21STomi Valkeinen return false;
49f7018c21STomi Valkeinen
50f7018c21STomi Valkeinen *data = *drv;
51f7018c21STomi Valkeinen list_add_tail(&data->chain, &data->bus->drivers);
52f7018c21STomi Valkeinen return true;
53f7018c21STomi Valkeinen }
54f7018c21STomi Valkeinen
via_aux_read(struct via_aux_drv * drv,u8 start,u8 * buf,u8 len)55f7018c21STomi Valkeinen static inline bool via_aux_read(struct via_aux_drv *drv, u8 start, u8 *buf,
56f7018c21STomi Valkeinen u8 len)
57f7018c21STomi Valkeinen {
58f7018c21STomi Valkeinen struct i2c_msg msg[2] = {
59f7018c21STomi Valkeinen {.addr = drv->addr, .flags = 0, .len = 1, .buf = &start},
60f7018c21STomi Valkeinen {.addr = drv->addr, .flags = I2C_M_RD, .len = len, .buf = buf} };
61f7018c21STomi Valkeinen
62f7018c21STomi Valkeinen return i2c_transfer(drv->bus->adap, msg, 2) == 2;
63f7018c21STomi Valkeinen }
64f7018c21STomi Valkeinen
65f7018c21STomi Valkeinen
66f7018c21STomi Valkeinen /* probe functions of existing drivers - should only be called in via_aux.c */
67f7018c21STomi Valkeinen void via_aux_ch7301_probe(struct via_aux_bus *bus);
68f7018c21STomi Valkeinen void via_aux_edid_probe(struct via_aux_bus *bus);
69f7018c21STomi Valkeinen void via_aux_sii164_probe(struct via_aux_bus *bus);
70f7018c21STomi Valkeinen void via_aux_vt1636_probe(struct via_aux_bus *bus);
71f7018c21STomi Valkeinen void via_aux_vt1632_probe(struct via_aux_bus *bus);
72f7018c21STomi Valkeinen void via_aux_vt1631_probe(struct via_aux_bus *bus);
73f7018c21STomi Valkeinen void via_aux_vt1625_probe(struct via_aux_bus *bus);
74f7018c21STomi Valkeinen void via_aux_vt1622_probe(struct via_aux_bus *bus);
75f7018c21STomi Valkeinen void via_aux_vt1621_probe(struct via_aux_bus *bus);
76f7018c21STomi Valkeinen
77f7018c21STomi Valkeinen
78f7018c21STomi Valkeinen #endif /* __VIA_AUX_H__ */
79