1 1.5 mlelstv /* $NetBSD: i2c_io.h,v 1.5 2022/06/29 15:34:15 mlelstv Exp $ */ 2 1.1 thorpej 3 1.1 thorpej /* 4 1.1 thorpej * Copyright (c) 2003 Wasabi Systems, Inc. 5 1.1 thorpej * All rights reserved. 6 1.1 thorpej * 7 1.1 thorpej * Written by Jason R. Thorpe for Wasabi Systems, Inc. 8 1.1 thorpej * 9 1.1 thorpej * Redistribution and use in source and binary forms, with or without 10 1.1 thorpej * modification, are permitted provided that the following conditions 11 1.1 thorpej * are met: 12 1.1 thorpej * 1. Redistributions of source code must retain the above copyright 13 1.1 thorpej * notice, this list of conditions and the following disclaimer. 14 1.1 thorpej * 2. Redistributions in binary form must reproduce the above copyright 15 1.1 thorpej * notice, this list of conditions and the following disclaimer in the 16 1.1 thorpej * documentation and/or other materials provided with the distribution. 17 1.1 thorpej * 3. All advertising materials mentioning features or use of this software 18 1.1 thorpej * must display the following acknowledgement: 19 1.1 thorpej * This product includes software developed for the NetBSD Project by 20 1.1 thorpej * Wasabi Systems, Inc. 21 1.1 thorpej * 4. The name of Wasabi Systems, Inc. may not be used to endorse 22 1.1 thorpej * or promote products derived from this software without specific prior 23 1.1 thorpej * written permission. 24 1.1 thorpej * 25 1.1 thorpej * THIS SOFTWARE IS PROVIDED BY WASABI SYSTEMS, INC. ``AS IS'' AND 26 1.1 thorpej * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 27 1.1 thorpej * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 28 1.1 thorpej * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL WASABI SYSTEMS, INC 29 1.1 thorpej * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 30 1.1 thorpej * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 31 1.1 thorpej * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 32 1.1 thorpej * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 33 1.1 thorpej * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 34 1.1 thorpej * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 35 1.1 thorpej * POSSIBILITY OF SUCH DAMAGE. 36 1.1 thorpej */ 37 1.1 thorpej 38 1.1 thorpej #ifndef _DEV_I2C_I2C_IO_H_ 39 1.1 thorpej #define _DEV_I2C_I2C_IO_H_ 40 1.1 thorpej 41 1.4 riastrad #include <sys/types.h> 42 1.1 thorpej #include <sys/ioccom.h> 43 1.1 thorpej 44 1.1 thorpej /* I2C bus address. */ 45 1.1 thorpej typedef uint16_t i2c_addr_t; 46 1.1 thorpej 47 1.1 thorpej /* High-level I2C operations. */ 48 1.3 pgoyette #define I2C_OPMASK_STOP 1 49 1.3 pgoyette #define I2C_OPMASK_WRITE 2 50 1.3 pgoyette #define I2C_OPMASK_BLKMODE 4 51 1.3 pgoyette 52 1.3 pgoyette #define I2C_OP_STOP_P(x) (((int)(x) & I2C_OPMASK_STOP) != 0) 53 1.3 pgoyette #define I2C_OP_WRITE_P(x) (((int)(x) & I2C_OPMASK_WRITE) != 0) 54 1.3 pgoyette #define I2C_OP_READ_P(x) (!I2C_OP_WRITE_P(x)) 55 1.3 pgoyette #define I2C_OP_BLKMODE_P(x) (((int)(x) & I2C_OPMASK_BLKMODE) != 0) 56 1.3 pgoyette 57 1.1 thorpej typedef enum { 58 1.3 pgoyette I2C_OP_READ = 0, 59 1.3 pgoyette I2C_OP_READ_WITH_STOP = I2C_OPMASK_STOP, 60 1.3 pgoyette I2C_OP_WRITE = I2C_OPMASK_WRITE, 61 1.3 pgoyette I2C_OP_WRITE_WITH_STOP = I2C_OPMASK_WRITE | I2C_OPMASK_STOP, 62 1.3 pgoyette I2C_OP_READ_BLOCK = I2C_OPMASK_BLKMODE | I2C_OPMASK_STOP, 63 1.3 pgoyette I2C_OP_WRITE_BLOCK = I2C_OPMASK_BLKMODE | I2C_OPMASK_WRITE | 64 1.3 pgoyette I2C_OPMASK_STOP, 65 1.1 thorpej } i2c_op_t; 66 1.1 thorpej 67 1.1 thorpej /* 68 1.1 thorpej * This structure describes a single I2C control script fragment. 69 1.1 thorpej * 70 1.1 thorpej * Note that use of this scripted API allows for support of automated 71 1.1 thorpej * SMBus controllers. The following table maps SMBus operations to 72 1.1 thorpej * script fragment configuration: 73 1.1 thorpej * 74 1.1 thorpej * SMBus "write byte": I2C_OP_WRITE_WITH_STOP 75 1.1 thorpej * cmdlen = 1 76 1.1 thorpej * 77 1.1 thorpej * SMBus "read byte": I2C_OP_READ_WITH_STOP 78 1.1 thorpej * cmdlen = 1 79 1.1 thorpej * 80 1.1 thorpej * SMBus "receive byte": I2C_OP_READ_WITH_STOP 81 1.1 thorpej * cmdlen = 0 82 1.1 thorpej * 83 1.1 thorpej * Note that while each of these 3 SMBus operations implies a STOP 84 1.1 thorpej * (which an automated controller will likely perform automatically), 85 1.1 thorpej * non-SMBus clients may continue to function even if they issue 86 1.1 thorpej * I2C_OP_WRITE and I2C_OP_READ. 87 1.1 thorpej */ 88 1.1 thorpej 89 1.1 thorpej /* 90 1.1 thorpej * I2C_IOCTL_EXEC: 91 1.1 thorpej * 92 1.1 thorpej * User ioctl to execute an i2c operation. 93 1.1 thorpej */ 94 1.1 thorpej typedef struct i2c_ioctl_exec { 95 1.1 thorpej i2c_op_t iie_op; /* operation to perform */ 96 1.1 thorpej i2c_addr_t iie_addr; /* address of device */ 97 1.1 thorpej const void *iie_cmd; /* pointer to command */ 98 1.1 thorpej size_t iie_cmdlen; /* length of command */ 99 1.1 thorpej void *iie_buf; /* pointer to data buffer */ 100 1.1 thorpej size_t iie_buflen; /* length of data buffer */ 101 1.1 thorpej } i2c_ioctl_exec_t; 102 1.5 mlelstv #define I2C_EXEC_MAX_CMDLEN 4096 103 1.5 mlelstv #define I2C_EXEC_MAX_BUFLEN 4096 104 1.1 thorpej 105 1.1 thorpej #define I2C_IOCTL_EXEC _IOW('I', 0, i2c_ioctl_exec_t) 106 1.1 thorpej 107 1.1 thorpej #endif /* _DEV_I2C_I2C_IO_H_ */ 108