|
#define | NO_OS_I3C_MAX_BUS_NUMBER 3 |
|
#define | NO_OS_I3C_MAX_DEV_NUMBER 15 |
|
#define | NO_OS_I3C_I2C_MAX_ADDR 0x7F |
|
#define | NO_OS_I3C_MAX_ADDR NO_OS_I3C_I2C_MAX_ADDR |
|
#define | NO_OS_I3C_BCAST_ADDR 0x7E |
|
#define | NO_OS_I3C_ADDR_FLAG_SIZE 2 |
|
#define | NO_OS_I3C_ADDR_PER_SLOT ((unsigned int)(sizeof(unsigned int)*8 / NO_OS_I3C_ADDR_FLAG_SIZE)) |
|
#define | NO_OS_I3C_ADDR_GET_SLOT(x) ((x) / NO_OS_I3C_ADDR_PER_SLOT) |
|
#define | NO_OS_I3C_ADDR_GET_POS(x) (((x) % NO_OS_I3C_ADDR_PER_SLOT) * NO_OS_I3C_ADDR_FLAG_SIZE) |
|
#define | NO_OS_I3C_ADDRSLOTS_SIZE (NO_OS_I3C_I2C_MAX_ADDR / NO_OS_I3C_ADDR_PER_SLOT) + !!(NO_OS_I3C_I2C_MAX_ADDR % NO_OS_I3C_ADDR_PER_SLOT) |
|
#define | NO_OS_I3C_CCC_BCAST 0 |
|
#define | NO_OS_I3C_CCC_DIRECT NO_OS_BIT(7) |
|
#define | NO_OS_I3C_CCC_ID(id, type) ((id) | (type)) |
|
#define | NO_OS_I3C_CCC_ADDR(x) ((x) & 0xFF) |
|
#define | NO_OS_I3C_CCC_GET_LEN(x) (((x) >> 8) & 0x0000FF) |
|
#define | NO_OS_I3C_CCC_SET_LEN(x) (((x) << 8) & 0x00FF00) |
|
#define | NO_OS_I3C_CCC_GET_DEF(x) (((x) >> 17) & NO_OS_BIT(0)) |
|
#define | NO_OS_I3C_CCC_SET_DEF NO_OS_BIT(17) |
|
#define | NO_OS_I3C_CCC_GET_RNW(x) (((x) >> 16) & NO_OS_BIT(0)) |
|
#define | NO_OS_I3C_CCC_SET_RNW(x) (((x) << 16) & NO_OS_BIT(16)) |
|
#define | NO_OS_I3C_CCC_ENEC_DIRECT 0x80 | NO_OS_I3C_CCC_SET_LEN(1) |
|
#define | NO_OS_I3C_CCC_DISEC_DIRECT 0x81 | NO_OS_I3C_CCC_SET_LEN(1) |
|
#define | NO_OS_I3C_CCC_ENEC_BCAST 0x00 | NO_OS_I3C_CCC_SET_DEF |
|
#define | NO_OS_I3C_CCC_DISEC_BCAST 0x01 | NO_OS_I3C_CCC_SET_DEF |
|
#define | NO_OS_I3C_CCC_ENTAS(as, type) NO_OS_I3C_CCC_ID((0x2 + (as)), (type)) |
|
#define | NO_OS_I3C_CCC_RSTDAA(type) NO_OS_I3C_CCC_ID(0x6, (type)) |
|
#define | NO_OS_I3C_CCC_SETMWL(type) NO_OS_I3C_CCC_ID(0x9, (type)) | NO_OS_I3C_CCC_SET_LEN(2) |
|
#define | NO_OS_I3C_CCC_SETMRL(type) NO_OS_I3C_CCC_ID(0xa, (type)) | NO_OS_I3C_CCC_SET_LEN(2) |
|
#define | NO_OS_I3C_CCC_SETXTIME_BCAST 0x28 | NO_OS_I3C_CCC_SET_DEF |
|
#define | NO_OS_I3C_CCC_SETXTIME_DIRECT 0x98 | NO_OS_I3C_CCC_SET_DEF |
|
#define | NO_OS_I3C_CCC_RSTACT_BCAST 0x2a | NO_OS_I3C_CCC_SET_DEF |
|
#define | NO_OS_I3C_CCC_RSTACT_DIRECT 0x9a | NO_OS_I3C_CCC_SET_DEF |
|
#define | NO_OS_I3C_CCC_RSTACT_I3C_ONLY 0x1 |
|
#define | NO_OS_I3C_CCC_RSTACT_WHOLE_TARGET 0x2 |
|
#define | NO_OS_I3C_CCC_ENTDAA NO_OS_I3C_CCC_ID(0x7, NO_OS_I3C_CCC_BCAST) |
|
#define | NO_OS_I3C_CCC_DEFSLVS NO_OS_I3C_CCC_ID(0x8, NO_OS_I3C_CCC_BCAST) |
|
#define | NO_OS_I3C_CCC_ENTTM NO_OS_I3C_CCC_ID(0xb, NO_OS_I3C_CCC_BCAST) |
|
#define | NO_OS_I3C_CCC_ENTHDR(x) NO_OS_I3C_CCC_ID((0x20 + (x)), NO_OS_I3C_CCC_BCAST) |
|
#define | NO_OS_I3C_CCC_SETAASA NO_OS_I3C_CCC_ID(0x29, NO_OS_I3C_CCC_BCAST) |
|
#define | NO_OS_I3C_CCC_SETDASA NO_OS_I3C_CCC_ID(0x7, NO_OS_I3C_CCC_DIRECT) |
|
#define | NO_OS_I3C_CCC_SETNEWDA NO_OS_I3C_CCC_ID(0x8, NO_OS_I3C_CCC_DIRECT) |
|
#define | NO_OS_I3C_CCC_GETMWL NO_OS_I3C_CCC_ID(0xb, NO_OS_I3C_CCC_DIRECT) |
|
#define | NO_OS_I3C_CCC_GETMRL NO_OS_I3C_CCC_ID(0xc, NO_OS_I3C_CCC_DIRECT) |
|
#define | NO_OS_I3C_CCC_GETPID (NO_OS_I3C_CCC_ID(0xd, NO_OS_I3C_CCC_DIRECT) | NO_OS_I3C_CCC_SET_LEN(6) | NO_OS_I3C_CCC_SET_RNW(1)) |
|
#define | NO_OS_I3C_CCC_GETBCR (NO_OS_I3C_CCC_ID(0xe, NO_OS_I3C_CCC_DIRECT) | NO_OS_I3C_CCC_SET_LEN(1) | NO_OS_I3C_CCC_SET_RNW(1)) |
|
#define | NO_OS_I3C_CCC_GETDCR (NO_OS_I3C_CCC_ID(0xf, NO_OS_I3C_CCC_DIRECT) | NO_OS_I3C_CCC_SET_LEN(1) | NO_OS_I3C_CCC_SET_RNW(1)) |
|
#define | NO_OS_I3C_CCC_GETSTATUS (NO_OS_I3C_CCC_ID(0x10, NO_OS_I3C_CCC_DIRECT) | NO_OS_I3C_CCC_SET_LEN(2) | NO_OS_I3C_CCC_SET_RNW(1)) |
|
#define | NO_OS_I3C_CCC_GETACCMST NO_OS_I3C_CCC_ID(0x11, NO_OS_I3C_CCC_DIRECT) |
|
#define | NO_OS_I3C_CCC_SETBRGTGT NO_OS_I3C_CCC_ID(0x13, NO_OS_I3C_CCC_DIRECT) |
|
#define | NO_OS_I3C_CCC_GETMXDS NO_OS_I3C_CCC_ID(0x14, NO_OS_I3C_CCC_DIRECT) |
|
#define | NO_OS_I3C_CCC_GETHDRCAP NO_OS_I3C_CCC_ID(0x15, NO_OS_I3C_CCC_DIRECT) |
|
#define | NO_OS_I3C_CCC_GETXTIME NO_OS_I3C_CCC_ID(0x19, NO_OS_I3C_CCC_DIRECT) |
|
#define | NO_OS_I3C_CCC_EVENT_SIR NO_OS_BIT(0) |
|
#define | NO_OS_I3C_CCC_EVENT_MR NO_OS_BIT(1) |
|
#define | NO_OS_I3C_CCC_EVENT_HJ NO_OS_BIT(3) |
|
#define | NO_OS_I3C_IRQ_IBI 0x1 |
|
#define | NO_OS_I3C_IRQ_HJ 0x2 |
|
#define | NO_OS_I3C_IRQ_CR 0x4 |
|
#define | NO_OS_I3C_BCR_IBI_REQUEST_CAPABLE(bcr) !!((bcr) & (1 << 1)) |
|
#define | NO_OS_I3C_BCR_IBI_PAYLOAD(bcr) !!((bcr) & (1 << 2)) |
|
#define | NO_OS_I3C_BCR_DEVICE_ROLE(bcr) (((bcr) && NO_OS_GENMASK(7,6)) >> 6) |
|
|
int | no_os_i3c_init (struct no_os_i3c_desc **desc, const struct no_os_i3c_init_param *param) |
| Initialize the I3C device. If the bus of the I3C device is not initialized, it will call to init it. More...
|
|
int | no_os_i3c_init_bus (struct no_os_i3c_bus_desc **desc, const struct no_os_i3c_bus_init_param *param) |
| Initialize the I3C bus. More...
|
|
int | no_os_i3c_remove (struct no_os_i3c_desc *desc) |
| Free the resources allocated by no_os_i3c_init(). More...
|
|
int | no_os_i3c_remove_bus (struct no_os_i3c_bus_desc *desc) |
| Free the resources allocated by no_os_i3c_init_bus. Must remove all devices first, if not, -EFAULT is returned. More...
|
|
int | no_os_i3c_do_daa (struct no_os_i3c_bus_desc *desc, bool rstdaa) |
| Do DAA to assign the dynamic addresses. More...
|
|
int | no_os_i3c_send_ccc (struct no_os_i3c_bus_desc *desc, uint8_t addr, uint32_t ccc, uint8_t *data) |
| Send CCC, either to a device device or broadcast to all. More...
|
|
int | no_os_i3c_send_direct_ccc (struct no_os_i3c_desc *desc, uint32_t ccc, uint8_t *data) |
| Send CCC to device device. More...
|
|
int | no_os_i3c_write (struct no_os_i3c_desc *desc, uint8_t *data, uint8_t size) |
| Write data to device device. More...
|
|
int | no_os_i3c_read (struct no_os_i3c_desc *desc, uint8_t *data, uint8_t size) |
| Read data from device device. More...
|
|
int | no_os_i3c_write_and_read (struct no_os_i3c_desc *desc, uint8_t *tx_data, uint8_t tx_data_len, uint8_t *rx_data, uint8_t rx_data_len) |
| Read and write the device. More...
|
|
int | no_os_i3c_conf_irq (struct no_os_i3c_bus_desc *desc, uint8_t irq, bool en) |
| Configure I3C interrupts. More...
|
|
int | no_os_i3c_wait_irq (struct no_os_i3c_bus_desc *desc, uint8_t irq) |
| Wait I3C interrupt. Set async_irq on call to false to ensure single entry point. More...
|
|
int | no_os_i3c_call_irq (struct no_os_i3c_bus_desc *desc) |
| Non-blocking I3C interrupt. Since a payload is always retrieved with it, also update the no_os_i3c_ccc_info fields. More...
|
|
int | no_os_i3c_async_irq (struct no_os_i3c_bus_desc *desc, bool en) |
| Enable I3C non-blocking interrupts. More...
|
|
uint8_t | no_os_i3c_addr_get_free (struct no_os_i3c_bus_desc *desc, uint8_t start_addr) |
| Get a free address. More...
|
|
void | no_os_i3c_addr_set_status (struct no_os_i3c_bus_desc *desc, uint8_t addr, enum no_os_i3c_slot_status status) |
| Set status of an address. More...
|
|
void | no_os_i3c_attach_callback (struct no_os_i3c_desc *desc, void(*callback)(struct no_os_i3c_desc *, uint32_t, uint32_t)) |
| Attach event callback. More...
|
|
void | no_os_i3c_detach_callback (struct no_os_i3c_desc *desc) |
| Detach event callback. More...
|
|
Header file of I3C Interface.
- Author
- Jorge Marques (jorge.nosp@m..mar.nosp@m.ques@.nosp@m.anal.nosp@m.og.co.nosp@m.m)
Copyright 2024(c) Analog Devices, Inc.
All rights reserved.
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
- Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
- Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
- Neither the name of Analog Devices, Inc. nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.
- The use of this software may or may not infringe the patent rights of one or more patent holders. This license does not release you from the requirement that you obtain separate licenses from these patent holders to use this software.
- Use of the software either in source or binary form, must be run on or directly connected to an Analog Devices Inc. component.
THIS SOFTWARE IS PROVIDED BY ANALOG DEVICES "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, NON-INFRINGEMENT, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL ANALOG DEVICES BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, INTELLECTUAL PROPERTY RIGHTS, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.