lpcusbsio_i2c.h 8.01 KB
Newer Older
Gus Grubba's avatar
Gus Grubba committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189
/*
 * @brief Protocol definitions for LPCUSBSIO's I2C interface
 *
 * @note
 * Copyright(C) NXP Semiconductors, 2013
 * All rights reserved.
 *
 * @par
 * Software that is described herein is for illustrative purposes only
 * which provides customers with programming information regarding the
 * LPC products.  This software is supplied "AS IS" without any warranties of
 * any kind, and NXP Semiconductors and its licensor disclaim any and
 * all warranties, express or implied, including all implied warranties of
 * merchantability, fitness for a particular purpose and non-infringement of
 * intellectual property rights.  NXP Semiconductors assumes no responsibility
 * or liability for the use of the software, conveys no license or rights under any
 * patent, copyright, mask work right, or any other intellectual property rights in
 * or to any products. NXP Semiconductors reserves the right to make changes
 * in the software without notification. NXP Semiconductors also makes no
 * representation or warranty that such application will be suitable for the
 * specified use without further testing or modification.
 *
 * @par
 * Permission to use, copy, modify, and distribute this software and its
 * documentation is hereby granted, under NXP Semiconductors' and its
 * licensor's relevant copyrights in the software, without fee, provided that it
 * is used in conjunction with NXP Semiconductors microcontrollers.  This
 * copyright, permission, and disclaimer notice must appear in all copies of
 * this code.
 */

#ifndef __LPCUSBSIO_I2C_H_
#define __LPCUSBSIO_I2C_H_

#ifdef __cplusplus
extern "C"
{
#endif

#pragma pack(1)

/** @defgroup LPCUSBSIO_I2C LPCUSBSIO protocol definitions for I2C interface
 * @ingroup LPCUSBSIO
 * This package defines the LPCUSBSIO packet structure for I2C interface.
 * Both the firmware and PC (host) libraries use this definitions to construct
 * the I2C payloads.
 * @{
 */

#define HID_I2C_MAX_PACKETS         4        /*!< Maximum packets allowed in processing queue */
#define HID_I2C_PACKET_SZ           64        /*!< Packet size of each I2C command packet */
#define HID_I2C_HEADER_SZ           5        /*!< Size of the header in I2C command packet */

/* HID_I2C Requests */
#define HID_I2C_REQ_RESET           0        /*!< Request to abort and flush all pending requests */
#define HID_I2C_REQ_INIT_PORT       1        /*!< Request to initialize the I2C port */
#define HID_I2C_REQ_DEINIT_PORT     2        /*!< Request to de-initialize the I2C port */
#define HID_I2C_REQ_DEVICE_WRITE    3        /*!< Request to write data to the I2C port */
#define HID_I2C_REQ_DEVICE_READ     4        /*!< Request to read data from the I2C port */
#define HID_I2C_REQ_DEVICE_XFER     5        /*!< Request to write and then read data from the I2C port */

/*AL ! Add GPIO Requests */
#define HID_GPIO_REQ_SET_VEN        6        /*!< Request to set the VEN GPIO State*/
#define HID_GPIO_REQ_SET_DWL        7        /*!< Request to set the DWL GPIO State*/

/**
 * @brief    HID to I2C bridge Request structure.
 *  Defines the structure of HID to I2C Request packet. This is same as
 *  HID OUT report.
 */
typedef struct __HIDI2C_OUT_REPORT {
    uint16_t length;        /*!< Length of the HID_I2C Request structure including cmd, transId and length fields. */
    uint8_t transId;    /*!< I2C_HID transaction identifier. Rolls over after 255. */
    uint8_t sesId;        /*!< I2C_HID session identifier. */
    uint8_t req;        /*!< I2C_HID Request */
    uint8_t data[];        /*!< Data corresponding to the Request */

} HID_I2C_OUT_REPORT_T;

/** HID_I2C responses. The response code below 0x10 should match with I2CM_STATUS codes. */
#define HID_I2C_RES_OK              0x00        /*!< Requested Request was executed successfully. */
#define HID_I2C_RES_ERROR           0x01        /*!< Unknown error condition. */
#define HID_I2C_RES_NAK             0x02        /*!< No device responded for given slave address. */
#define HID_I2C_RES_BUS_ERROR       0x03        /*!< I2C bus error */
#define HID_I2C_RES_SLAVE_NAK       0x04        /*!< NAK received after SLA+W or SLA+R */
#define HID_I2C_RES_ARBLOST         0x05        /*!< Arbitration lost */

#define HID_I2C_RES_TIMEOUT         0x10        /*!< Transaction timed out. */
#define HID_I2C_RES_INVALID_CMD     0x11        /*!< Invalid HID_I2C Request or Request not supported in this version. */
#define HID_I2C_RES_INVALID_PARAM   0x12        /*!< Invalid parameters are provided for the given Request. */
#define HID_I2C_RES_PARTIAL_DATA    0x13        /*!< Partial transfer completed. */

/**
 * @brief    HID to I2C bridge response structure.
 *  Defines the structure of HID to I2C Request packet. This is same as
 *  HID OUT report.
 */
typedef struct __HIDI2C_IN_REPORT {
    uint16_t length;        /*!< Length of the HID_I2C response structure including resp, transId and length fields.*/
    uint8_t transId;    /*!< I2C_HID transaction identifier. */
    uint8_t sesId;        /*!< I2C_HID session identifier. */
    uint8_t resp;        /*!< I2C_HID reponse */
    uint8_t data[];        /*!< Data corresponding to the response */

} HID_I2C_IN_REPORT_T;

/**
 * @brief Port configuration information
 */
typedef struct __HIDI2C_PortConfig_t {
    uint32_t busSpeed;    /*!< I2C bus speed */
    uint32_t Options;    /*!< Configuration options */
} HID_I2C_PORTCONFIG_T;

/** I2C_IO_OPTIONS Options to I2C_DeviceWrite & I2C_DeviceRead routines
 * @{
 */
/** Generate start condition before transmitting */
#define HID_I2C_TRANSFER_OPTIONS_START_BIT      0x0001

/** Generate stop condition at the end of transfer */
#define HID_I2C_TRANSFER_OPTIONS_STOP_BIT       0x0002

/** Continue transmitting data in bulk without caring about Ack or nAck from device if this bit is
   not set. If this bit is set then stop transmitting the data in the buffer when the device nAcks*/
#define HID_I2C_TRANSFER_OPTIONS_BREAK_ON_NACK  0x0004

/** lpcusbsio-I2C generates an ACKs for every byte read. Some I2C slaves require the I2C
   master to generate a nACK for the last data byte read. Setting this bit enables working with such
   I2C slaves */
#define HID_I2C_TRANSFER_OPTIONS_NACK_LAST_BYTE 0x0008

/* Setting this bit would mean that the address field should be ignored.
    The address is either a part of the data or this is a special I2C
    frame that doesn't require an address. For example when transferring a
    frame greater than the USB_HID packet this option can be used. */
#define HID_I2C_TRANSFER_OPTIONS_NO_ADDRESS     0x00000040

/** @} */

/**
 * @brief    HID to I2C bridge read and write transfer parameters structure.
 *  Defines the structure of HID to I2C read-write transfer parameters.
 */
typedef struct __HIDI2C_RW_PARAMS {
    uint16_t length;        /*!< Length of the transfer.*/
    uint8_t options;    /*!< check @ref I2C_IO_OPTIONS. */
    uint8_t slaveAddr;    /*!< I2C slave device address. */
    uint8_t data[];        /*!< Data corresponding to the response */

} HID_I2C_RW_PARAMS_T;

/** I2C_FAST_XFER_OPTIONS I2C master faster transfer options
 * @{
 */

/** Ignore NACK during data transfer. By default transfer is aborted. */
#define I2C_FAST_XFER_OPTION_IGNORE_NACK     0x01
/** ACK last byte received. By default we NACK last byte we receive per I2C spec. */
#define I2C_FAST_XFER_OPTION_LAST_RX_ACK     0x02

/**
 * @}
 */

/**
 * @brief    HID to I2C bridge fast transfer parameters structure.
 *  Defines the parameters structure for HID_I2C_REQ_DEVICE_XFER command.
 */
typedef struct __HIDI2C_XFER_PARAMS {
    uint8_t txLength;    /*!< Length of the Tx transfer.*/
    uint8_t rxLength;    /*!< Length of the Rx transfer. */
    uint8_t options;    /*!< check @ref I2C_FAST_XFER_OPTIONS. */
    uint8_t slaveAddr;    /*!< I2C slave device address. */
    uint8_t data[];        /*!< Data corresponding to the response */

} HID_I2C_XFER_PARAMS_T;

/**
 * @}
 */

#pragma pack()

#ifdef __cplusplus
}
#endif

#endif /* __LPCUSBSIO_I2C_H_ */