1 /*
2 * Copyright (c) 2021 Intel Corporation
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
7 #include <zephyr/drivers/i2c.h>
8 #include <zephyr/kernel.h>
9 #include <zephyr/ztest.h>
10
11 /* command to configure port direction of NXP PCA95xx */
12 #define REG_CONF_PORT0 0x06U
13
14 /* test data used to write into registers */
15 uint8_t test_data[2] = {0xAA, 0xAA};
16
17 /**
18 * @brief Test i2c api by communicating with pca95xx
19 * @details
20 * - get i2c mainline device
21 * - write data into pca95xx
22 * - read data from pca95xx
23 * - check read data whether correct
24 */
ZTEST(i2c,test_i2c_pca95xx)25 ZTEST(i2c, test_i2c_pca95xx)
26 {
27 int32_t ret;
28 uint8_t datas[3];
29 uint32_t i2c_cfg = I2C_SPEED_SET(I2C_SPEED_STANDARD) | I2C_MODE_CONTROLLER;
30
31 /* get i2c device */
32 const struct i2c_dt_spec i2c = I2C_DT_SPEC_GET(DT_COMPAT_GET_ANY_STATUS_OKAY(nxp_pca95xx));
33
34 zassert_true(device_is_ready(i2c.bus), "I2C controller device is not ready");
35
36 /* configure i2c device */
37 ret = i2c_configure(i2c.bus, i2c_cfg);
38 zassert_true(ret == 0, "Failed to configure i2c device");
39
40 /* write configuration to register 6 and 7 of PCA95XX*/
41 (void)memset(datas, 0, 3);
42 datas[0] = REG_CONF_PORT0;
43 datas[1] = test_data[0];
44 datas[2] = test_data[1];
45 ret = i2c_write_dt(&i2c, datas, 3);
46 zassert_true(ret == 0, "Failed to write data to i2c device");
47
48 /* read configuration from register 6 and 7 */
49 (void)memset(datas, 0, 3);
50 datas[0] = REG_CONF_PORT0;
51 ret = i2c_write_dt(&i2c, datas, 1);
52 zassert_true(ret == 0, "Failed to write data to i2c device");
53
54 (void)memset(datas, 0, 3);
55 ret = i2c_read_dt(&i2c, datas, 2);
56 zassert_true(ret == 0, "Failed to read data from i2c device");
57
58 /* check read data whether correct */
59 ret = memcmp(datas, test_data, 2);
60 zassert_true(ret == 0, "Read data is different to write data");
61 }
62
63 ZTEST_SUITE(i2c, NULL, NULL, NULL, NULL, NULL);
64