Skip to content

Commit c3eacc8

Browse files
authored
Merge pull request #474 from WangYuxin-esp/feature/support_sccb_handle_16bit_val
Feature/support sccb handle 16bit val
2 parents 5c8349f + f3d04ea commit c3eacc8

File tree

2 files changed

+60
-4
lines changed

2 files changed

+60
-4
lines changed

driver/private_include/sccb.h

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -14,7 +14,9 @@ int SCCB_Use_Port(int sccb_i2c_port);
1414
int SCCB_Deinit(void);
1515
uint8_t SCCB_Probe();
1616
uint8_t SCCB_Read(uint8_t slv_addr, uint8_t reg);
17-
uint8_t SCCB_Write(uint8_t slv_addr, uint8_t reg, uint8_t data);
17+
int SCCB_Write(uint8_t slv_addr, uint8_t reg, uint8_t data);
1818
uint8_t SCCB_Read16(uint8_t slv_addr, uint16_t reg);
19-
uint8_t SCCB_Write16(uint8_t slv_addr, uint16_t reg, uint8_t data);
19+
int SCCB_Write16(uint8_t slv_addr, uint16_t reg, uint8_t data);
20+
uint16_t SCCB_Read_Addr16_Val16(uint8_t slv_addr, uint16_t reg);
21+
int SCCB_Write_Addr16_Val16(uint8_t slv_addr, uint16_t reg, uint16_t data);
2022
#endif // __SCCB_H__

driver/sccb.c

Lines changed: 56 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -139,7 +139,7 @@ uint8_t SCCB_Read(uint8_t slv_addr, uint8_t reg)
139139
return data;
140140
}
141141

142-
uint8_t SCCB_Write(uint8_t slv_addr, uint8_t reg, uint8_t data)
142+
int SCCB_Write(uint8_t slv_addr, uint8_t reg, uint8_t data)
143143
{
144144
esp_err_t ret = ESP_FAIL;
145145
i2c_cmd_handle_t cmd = i2c_cmd_link_create();
@@ -184,7 +184,7 @@ uint8_t SCCB_Read16(uint8_t slv_addr, uint16_t reg)
184184
return data;
185185
}
186186

187-
uint8_t SCCB_Write16(uint8_t slv_addr, uint16_t reg, uint8_t data)
187+
int SCCB_Write16(uint8_t slv_addr, uint16_t reg, uint8_t data)
188188
{
189189
static uint16_t i = 0;
190190
esp_err_t ret = ESP_FAIL;
@@ -204,3 +204,57 @@ uint8_t SCCB_Write16(uint8_t slv_addr, uint16_t reg, uint8_t data)
204204
}
205205
return ret == ESP_OK ? 0 : -1;
206206
}
207+
208+
uint16_t SCCB_Read_Addr16_Val16(uint8_t slv_addr, uint16_t reg)
209+
{
210+
uint16_t data = 0;
211+
uint8_t *data_u8 = (uint8_t *)&data;
212+
esp_err_t ret = ESP_FAIL;
213+
uint16_t reg_htons = LITTLETOBIG(reg);
214+
uint8_t *reg_u8 = (uint8_t *)&reg_htons;
215+
i2c_cmd_handle_t cmd = i2c_cmd_link_create();
216+
i2c_master_start(cmd);
217+
i2c_master_write_byte(cmd, ( slv_addr << 1 ) | WRITE_BIT, ACK_CHECK_EN);
218+
i2c_master_write_byte(cmd, reg_u8[0], ACK_CHECK_EN);
219+
i2c_master_write_byte(cmd, reg_u8[1], ACK_CHECK_EN);
220+
i2c_master_stop(cmd);
221+
ret = i2c_master_cmd_begin(sccb_i2c_port, cmd, 1000 / portTICK_RATE_MS);
222+
i2c_cmd_link_delete(cmd);
223+
if(ret != ESP_OK) return -1;
224+
225+
cmd = i2c_cmd_link_create();
226+
i2c_master_start(cmd);
227+
i2c_master_write_byte(cmd, ( slv_addr << 1 ) | READ_BIT, ACK_CHECK_EN);
228+
i2c_master_read_byte(cmd, &data_u8[1], ACK_VAL);
229+
i2c_master_read_byte(cmd, &data_u8[0], NACK_VAL);
230+
i2c_master_stop(cmd);
231+
ret = i2c_master_cmd_begin(sccb_i2c_port, cmd, 1000 / portTICK_RATE_MS);
232+
i2c_cmd_link_delete(cmd);
233+
if(ret != ESP_OK) {
234+
ESP_LOGE(TAG, "W [%04x]=%04x fail\n", reg, data);
235+
}
236+
return data;
237+
}
238+
239+
int SCCB_Write_Addr16_Val16(uint8_t slv_addr, uint16_t reg, uint16_t data)
240+
{
241+
esp_err_t ret = ESP_FAIL;
242+
uint16_t reg_htons = LITTLETOBIG(reg);
243+
uint8_t *reg_u8 = (uint8_t *)&reg_htons;
244+
uint16_t data_htons = LITTLETOBIG(data);
245+
uint8_t *data_u8 = (uint8_t *)&data_htons;
246+
i2c_cmd_handle_t cmd = i2c_cmd_link_create();
247+
i2c_master_start(cmd);
248+
i2c_master_write_byte(cmd, ( slv_addr << 1 ) | WRITE_BIT, ACK_CHECK_EN);
249+
i2c_master_write_byte(cmd, reg_u8[0], ACK_CHECK_EN);
250+
i2c_master_write_byte(cmd, reg_u8[1], ACK_CHECK_EN);
251+
i2c_master_write_byte(cmd, data_u8[0], ACK_CHECK_EN);
252+
i2c_master_write_byte(cmd, data_u8[1], ACK_CHECK_EN);
253+
i2c_master_stop(cmd);
254+
ret = i2c_master_cmd_begin(sccb_i2c_port, cmd, 1000 / portTICK_RATE_MS);
255+
i2c_cmd_link_delete(cmd);
256+
if(ret != ESP_OK) {
257+
ESP_LOGE(TAG, "W [%04x]=%04x fail\n", reg, data);
258+
}
259+
return ret == ESP_OK ? 0 : -1;
260+
}

0 commit comments

Comments
 (0)