i2c-dev.h 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. /* SPDX-License-Identifier: GPL-2.0+ WITH Linux-syscall-note */
  2. /*
  3. i2c-dev.h - i2c-bus driver, char device interface
  4. Copyright (C) 1995-97 Simon G. Vogl
  5. Copyright (C) 1998-99 Frodo Looijaard <frodol@dds.nl>
  6. This program is free software; you can redistribute it and/or modify
  7. it under the terms of the GNU General Public License as published by
  8. the Free Software Foundation; either version 2 of the License, or
  9. (at your option) any later version.
  10. This program is distributed in the hope that it will be useful,
  11. but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. GNU General Public License for more details.
  14. You should have received a copy of the GNU General Public License
  15. along with this program; if not, write to the Free Software
  16. Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
  17. MA 02110-1301 USA.
  18. */
  19. #ifndef _UAPI_LINUX_I2C_DEV_H
  20. #define _UAPI_LINUX_I2C_DEV_H
  21. #include <linux/types.h>
  22. #include <linux/compiler.h>
  23. /* /dev/i2c-X ioctl commands. The ioctl's parameter is always an
  24. * unsigned long, except for:
  25. * - I2C_FUNCS, takes pointer to an unsigned long
  26. * - I2C_RDWR, takes pointer to struct i2c_rdwr_ioctl_data
  27. * - I2C_SMBUS, takes pointer to struct i2c_smbus_ioctl_data
  28. */
  29. #define I2C_RETRIES 0x0701 /* number of times a device address should
  30. be polled when not acknowledging */
  31. #define I2C_TIMEOUT 0x0702 /* set timeout in units of 10 ms */
  32. /* NOTE: Slave address is 7 or 10 bits, but 10-bit addresses
  33. * are NOT supported! (due to code brokenness)
  34. */
  35. #define I2C_SLAVE 0x0703 /* Use this slave address */
  36. #define I2C_SLAVE_FORCE 0x0706 /* Use this slave address, even if it
  37. is already in use by a driver! */
  38. #define I2C_TENBIT 0x0704 /* 0 for 7 bit addrs, != 0 for 10 bit */
  39. #define I2C_FUNCS 0x0705 /* Get the adapter functionality mask */
  40. #define I2C_RDWR 0x0707 /* Combined R/W transfer (one STOP only) */
  41. #define I2C_PEC 0x0708 /* != 0 to use PEC with SMBus */
  42. #define I2C_SMBUS 0x0720 /* SMBus transfer */
  43. /* This is the structure as used in the I2C_SMBUS ioctl call */
  44. struct i2c_smbus_ioctl_data {
  45. __u8 read_write;
  46. __u8 command;
  47. __u32 size;
  48. union i2c_smbus_data __user *data;
  49. };
  50. /* This is the structure as used in the I2C_RDWR ioctl call */
  51. struct i2c_rdwr_ioctl_data {
  52. struct i2c_msg __user *msgs; /* pointers to i2c_msgs */
  53. __u32 nmsgs; /* number of i2c_msgs */
  54. };
  55. #define I2C_RDWR_IOCTL_MAX_MSGS 42
  56. /* Originally defined with a typo, keep it for compatibility */
  57. #define I2C_RDRW_IOCTL_MAX_MSGS I2C_RDWR_IOCTL_MAX_MSGS
  58. #endif /* _UAPI_LINUX_I2C_DEV_H */