blob: fe578e867adfa892860e036fc6aacc9b02ebaf78 [file] [log] [blame]
Ben Cheng655a7c02013-10-16 16:09:24 -07001/****************************************************************************
2 ****************************************************************************
3 ***
4 *** This header was automatically generated from a Linux kernel header
5 *** of the same name, to make information necessary for userspace to
6 *** call into the kernel available to libc. It contains only constants,
7 *** structures, and macros generated from the original header, and thus,
8 *** contains no copyrightable information.
9 ***
10 *** To edit the content of this header, modify the corresponding
11 *** source file (e.g. under external/kernel-headers/original/) then
12 *** run bionic/libc/kernel/tools/update_all.py
13 ***
14 *** Any manual change here will be lost the next time this script will
15 *** be run. You've been warned!
16 ***
17 ****************************************************************************
18 ****************************************************************************/
19#ifndef _UAPI_LINUX_I2C_H
20#define _UAPI_LINUX_I2C_H
21#include <linux/types.h>
22struct i2c_msg {
Tao Baod7db5942015-01-28 10:07:51 -080023 __u16 addr;
24 __u16 flags;
Ben Cheng655a7c02013-10-16 16:09:24 -070025#define I2C_M_RD 0x0001
Christopher Ferris106b3a82016-08-24 12:15:38 -070026#define I2C_M_TEN 0x0010
Christopher Ferris76a1d452018-06-27 14:12:29 -070027#define I2C_M_DMA_SAFE 0x0200
Ben Cheng655a7c02013-10-16 16:09:24 -070028#define I2C_M_RECV_LEN 0x0400
Christopher Ferris106b3a82016-08-24 12:15:38 -070029#define I2C_M_NO_RD_ACK 0x0800
30#define I2C_M_IGNORE_NAK 0x1000
31#define I2C_M_REV_DIR_ADDR 0x2000
Christopher Ferris106b3a82016-08-24 12:15:38 -070032#define I2C_M_NOSTART 0x4000
33#define I2C_M_STOP 0x8000
Tao Baod7db5942015-01-28 10:07:51 -080034 __u16 len;
35 __u8 * buf;
Ben Cheng655a7c02013-10-16 16:09:24 -070036};
37#define I2C_FUNC_I2C 0x00000001
38#define I2C_FUNC_10BIT_ADDR 0x00000002
39#define I2C_FUNC_PROTOCOL_MANGLING 0x00000004
Ben Cheng655a7c02013-10-16 16:09:24 -070040#define I2C_FUNC_SMBUS_PEC 0x00000008
41#define I2C_FUNC_NOSTART 0x00000010
Christopher Ferris05d08e92016-02-04 13:16:38 -080042#define I2C_FUNC_SLAVE 0x00000020
Ben Cheng655a7c02013-10-16 16:09:24 -070043#define I2C_FUNC_SMBUS_BLOCK_PROC_CALL 0x00008000
Christopher Ferris05d08e92016-02-04 13:16:38 -080044#define I2C_FUNC_SMBUS_QUICK 0x00010000
Ben Cheng655a7c02013-10-16 16:09:24 -070045#define I2C_FUNC_SMBUS_READ_BYTE 0x00020000
46#define I2C_FUNC_SMBUS_WRITE_BYTE 0x00040000
47#define I2C_FUNC_SMBUS_READ_BYTE_DATA 0x00080000
Christopher Ferris05d08e92016-02-04 13:16:38 -080048#define I2C_FUNC_SMBUS_WRITE_BYTE_DATA 0x00100000
Ben Cheng655a7c02013-10-16 16:09:24 -070049#define I2C_FUNC_SMBUS_READ_WORD_DATA 0x00200000
50#define I2C_FUNC_SMBUS_WRITE_WORD_DATA 0x00400000
51#define I2C_FUNC_SMBUS_PROC_CALL 0x00800000
Christopher Ferris05d08e92016-02-04 13:16:38 -080052#define I2C_FUNC_SMBUS_READ_BLOCK_DATA 0x01000000
Ben Cheng655a7c02013-10-16 16:09:24 -070053#define I2C_FUNC_SMBUS_WRITE_BLOCK_DATA 0x02000000
54#define I2C_FUNC_SMBUS_READ_I2C_BLOCK 0x04000000
55#define I2C_FUNC_SMBUS_WRITE_I2C_BLOCK 0x08000000
Christopher Ferris49f525c2016-12-12 14:55:36 -080056#define I2C_FUNC_SMBUS_HOST_NOTIFY 0x10000000
Christopher Ferris05d08e92016-02-04 13:16:38 -080057#define I2C_FUNC_SMBUS_BYTE (I2C_FUNC_SMBUS_READ_BYTE | I2C_FUNC_SMBUS_WRITE_BYTE)
Tao Baod7db5942015-01-28 10:07:51 -080058#define I2C_FUNC_SMBUS_BYTE_DATA (I2C_FUNC_SMBUS_READ_BYTE_DATA | I2C_FUNC_SMBUS_WRITE_BYTE_DATA)
59#define I2C_FUNC_SMBUS_WORD_DATA (I2C_FUNC_SMBUS_READ_WORD_DATA | I2C_FUNC_SMBUS_WRITE_WORD_DATA)
Christopher Ferris49f525c2016-12-12 14:55:36 -080060#define I2C_FUNC_SMBUS_BLOCK_DATA (I2C_FUNC_SMBUS_READ_BLOCK_DATA | I2C_FUNC_SMBUS_WRITE_BLOCK_DATA)
Christopher Ferris05d08e92016-02-04 13:16:38 -080061#define I2C_FUNC_SMBUS_I2C_BLOCK (I2C_FUNC_SMBUS_READ_I2C_BLOCK | I2C_FUNC_SMBUS_WRITE_I2C_BLOCK)
Tao Baod7db5942015-01-28 10:07:51 -080062#define I2C_FUNC_SMBUS_EMUL (I2C_FUNC_SMBUS_QUICK | I2C_FUNC_SMBUS_BYTE | I2C_FUNC_SMBUS_BYTE_DATA | I2C_FUNC_SMBUS_WORD_DATA | I2C_FUNC_SMBUS_PROC_CALL | I2C_FUNC_SMBUS_WRITE_BLOCK_DATA | I2C_FUNC_SMBUS_I2C_BLOCK | I2C_FUNC_SMBUS_PEC)
Christopher Ferrisa9750ed2021-05-03 14:02:49 -070063#define I2C_FUNC_SMBUS_EMUL_ALL (I2C_FUNC_SMBUS_EMUL | I2C_FUNC_SMBUS_READ_BLOCK_DATA | I2C_FUNC_SMBUS_BLOCK_PROC_CALL)
Ben Cheng655a7c02013-10-16 16:09:24 -070064#define I2C_SMBUS_BLOCK_MAX 32
Christopher Ferris49f525c2016-12-12 14:55:36 -080065union i2c_smbus_data {
Christopher Ferris05d08e92016-02-04 13:16:38 -080066 __u8 byte;
Tao Baod7db5942015-01-28 10:07:51 -080067 __u16 word;
68 __u8 block[I2C_SMBUS_BLOCK_MAX + 2];
Christopher Ferris49f525c2016-12-12 14:55:36 -080069};
Christopher Ferris05d08e92016-02-04 13:16:38 -080070#define I2C_SMBUS_READ 1
Ben Cheng655a7c02013-10-16 16:09:24 -070071#define I2C_SMBUS_WRITE 0
72#define I2C_SMBUS_QUICK 0
Christopher Ferris49f525c2016-12-12 14:55:36 -080073#define I2C_SMBUS_BYTE 1
Christopher Ferris05d08e92016-02-04 13:16:38 -080074#define I2C_SMBUS_BYTE_DATA 2
Ben Cheng655a7c02013-10-16 16:09:24 -070075#define I2C_SMBUS_WORD_DATA 3
76#define I2C_SMBUS_PROC_CALL 4
Christopher Ferris49f525c2016-12-12 14:55:36 -080077#define I2C_SMBUS_BLOCK_DATA 5
Christopher Ferris05d08e92016-02-04 13:16:38 -080078#define I2C_SMBUS_I2C_BLOCK_BROKEN 6
Ben Cheng655a7c02013-10-16 16:09:24 -070079#define I2C_SMBUS_BLOCK_PROC_CALL 7
80#define I2C_SMBUS_I2C_BLOCK_DATA 8
Christopher Ferris49f525c2016-12-12 14:55:36 -080081#endif