43#define CHIP_NAME "Maxim Integrated DS18B20"
44#define MANUFACTURER_NAME "Maxim Integrated"
45#define SUPPLY_VOLTAGE_MIN 3.0f
46#define SUPPLY_VOLTAGE_MAX 5.5f
47#define MAX_CURRENT 4.0f
48#define TEMPERATURE_MIN -55.0f
49#define TEMPERATURE_MAX 125.0f
50#define DRIVER_VERSION 2000
55#define DS18B20_CMD_SEARCH_ROM 0xF0
56#define DS18B20_CMD_READ_ROM 0x33
57#define DS18B20_CMD_MATCH_ROM 0x55
58#define DS18B20_CMD_SKIP_ROM 0xCC
59#define DS18B20_CMD_ALARM_SEARCH 0xEC
60#define DS18B20_CMD_CONVERT_T 0x44
61#define DS18B20_CMD_WRITE_SCRATCHPAD 0x4E
62#define DS18B20_CMD_READ_SCRATCHPAD 0xBE
63#define DS18B20_CMD_COPY_SCRATCHPAD 0x48
64#define DS18B20_CMD_RECALL_EE 0xB8
65#define DS18B20_CMD_READ_POWER_SUPPLY 0xB4
70static const uint8_t gcs_ds18b20_crc_table[256] =
72 0X00, 0X5E, 0XBC, 0XE2, 0X61, 0X3F, 0XDD, 0X83, 0XC2, 0X9C, 0X7E, 0X20, 0XA3,
73 0XFD, 0X1F, 0X41, 0X9D, 0XC3, 0X21, 0X7F, 0XFC, 0XA2, 0X40, 0X1E, 0X5F, 0X01,
74 0XE3, 0XBD, 0X3E, 0X60, 0X82, 0XDC, 0X23, 0X7D, 0X9F, 0XC1, 0X42, 0X1C, 0XFE,
75 0XA0, 0XE1, 0XBF, 0X5D, 0X03, 0X80, 0XDE, 0X3C, 0X62, 0XBE, 0XE0, 0X02, 0X5C,
76 0XDF, 0X81, 0X63, 0X3D, 0X7C, 0X22, 0XC0, 0X9E, 0X1D, 0X43, 0XA1, 0XFF, 0X46,
77 0X18, 0XFA, 0XA4, 0X27, 0X79, 0X9B, 0XC5, 0X84, 0XDA, 0X38, 0X66, 0XE5, 0XBB,
78 0X59, 0X07, 0XDB, 0X85, 0X67, 0X39, 0XBA, 0XE4, 0X06, 0X58, 0X19, 0X47, 0XA5,
79 0XFB, 0X78, 0X26, 0XC4, 0X9A, 0X65, 0X3B, 0XD9, 0X87, 0X04, 0X5A, 0XB8, 0XE6,
80 0XA7, 0XF9, 0X1B, 0X45, 0XC6, 0X98, 0X7A, 0X24, 0XF8, 0XA6, 0X44, 0X1A, 0X99,
81 0XC7, 0X25, 0X7B, 0X3A, 0X64, 0X86, 0XD8, 0X5B, 0X05, 0XE7, 0XB9, 0X8C, 0XD2,
82 0X30, 0X6E, 0XED, 0XB3, 0X51, 0X0F, 0X4E, 0X10, 0XF2, 0XAC, 0X2F, 0X71, 0X93,
83 0XCD, 0X11, 0X4F, 0XAD, 0XF3, 0X70, 0X2E, 0XCC, 0X92, 0XD3, 0X8D, 0X6F, 0X31,
84 0XB2, 0XEC, 0X0E, 0X50, 0XAF, 0XF1, 0X13, 0X4D, 0XCE, 0X90, 0X72, 0X2C, 0X6D,
85 0X33, 0XD1, 0X8F, 0X0C, 0X52, 0XB0, 0XEE, 0X32, 0X6C, 0X8E, 0XD0, 0X53, 0X0D,
86 0XEF, 0XB1, 0XF0, 0XAE, 0X4C, 0X12, 0X91, 0XCF, 0X2D, 0X73, 0XCA, 0X94, 0X76,
87 0X28, 0XAB, 0XF5, 0X17, 0X49, 0X08, 0X56, 0XB4, 0XEA, 0X69, 0X37, 0XD5, 0X8B,
88 0X57, 0X09, 0XEB, 0XB5, 0X36, 0X68, 0X8A, 0XD4, 0X95, 0XCB, 0X29, 0X77, 0XF4,
89 0XAA, 0X48, 0X16, 0XE9, 0XB7, 0X55, 0X0B, 0X88, 0XD6, 0X34, 0X6A, 0X2B, 0X75,
90 0X97, 0XC9, 0X4A, 0X14, 0XF6, 0XA8, 0X74, 0X2A, 0XC8, 0X96, 0X15, 0X4B, 0XA9,
91 0XF7, 0XB6, 0XE8, 0X0A, 0X54, 0XD7, 0X89, 0X6B, 0X35,
104static uint8_t a_ds18b20_check_crc(uint8_t *buf, uint8_t len, uint8_t crc)
109 for (i = 0; i < len; i++)
111 crc8 = gcs_ds18b20_crc_table[crc8 ^ buf[i]];
140 handle->
debug_print(
"ds18b20: bus write failed.\n");
148 handle->
debug_print(
"ds18b20: bus write failed.\n");
154 while ((res != 0) && (retry < 200))
156 if (handle->
bus_read((uint8_t *)&res) != 0)
159 handle->
debug_print(
"ds18b20: bus read failed.\n");
169 handle->
debug_print(
"ds18b20: bus read no response.\n");
178 while ((res == 0)&& (retry < 240))
180 if (handle->
bus_read((uint8_t *)&res) != 0)
183 handle->
debug_print(
"ds18b20: bus read failed.\n");
193 handle->
debug_print(
"ds18b20: bus read no response.\n");
215 handle->
debug_print(
"ds18b20: bus write failed.\n");
222 handle->
debug_print(
"ds18b20: bus write failed.\n");
229 handle->
debug_print(
"ds18b20: bus read failed.\n");
253 for (i = 1; i <= 8; i++)
255 if (a_ds18b20_read_bit(handle, (uint8_t *)&j) != 0)
258 handle->
debug_print(
"ds18b20: bus read byte failed.\n");
262 *
byte = (j << 7) | ((*
byte) >> 1);
284 for (j = 1; j <= 8; j++)
286 test_b =
byte & 0x01;
293 handle->
debug_print(
"ds18b20: bus write failed.\n");
301 handle->
debug_print(
"ds18b20: bus write failed.\n");
312 handle->
debug_print(
"ds18b20: bus write failed.\n");
320 handle->
debug_print(
"ds18b20: bus write failed.\n");
353 handle->
mode = (uint8_t)mode;
405 memcpy(handle->
rom, rom , 8);
433 if (a_ds18b20_reset(handle) != 0)
435 handle->
debug_print(
"ds18b20: bus rest failed.\n");
441 handle->
debug_print(
"ds18b20: write command failed.\n");
445 for (i = 0; i < 8; i++)
447 if (a_ds18b20_read_byte(handle, (uint8_t *)&rom[i]) != 0)
449 handle->
debug_print(
"ds18b20: read rom failed.\n");
484 if (a_ds18b20_reset(handle) != 0)
486 handle->
debug_print(
"ds18b20: bus reset failed.\n");
492 handle->
debug_print(
"ds18b20: write command failed.\n");
498 handle->
debug_print(
"ds18b20: write command failed.\n");
502 for (i = 0; i < 9; i++)
504 if (a_ds18b20_read_byte(handle, (uint8_t *)&buf[i]) != 0)
506 handle->
debug_print(
"ds18b20: read data failed.\n");
511 if (a_ds18b20_check_crc((uint8_t *)buf, 8, buf[8]) != 0)
513 handle->
debug_print(
"ds18b20: crc check error.\n");
517 if (a_ds18b20_reset(handle) != 0)
519 handle->
debug_print(
"ds18b20: bus reset failed.\n");
525 handle->
debug_print(
"ds18b20: write command failed.\n");
531 handle->
debug_print(
"ds18b20: write command failed.\n");
536 buf[4] |= resolution << 5;
537 for (i = 0; i < 3; i++)
539 if (a_ds18b20_write_byte(handle, buf[2+i]) != 0)
541 handle->
debug_print(
"ds18b20: write command failed.\n");
551 if (a_ds18b20_reset(handle) != 0)
553 handle->
debug_print(
"ds18b20: bus reset failed.\n");
559 handle->
debug_print(
"ds18b20: write command failed.\n");
563 for (i = 0; i < 8; i++)
565 if (a_ds18b20_write_byte(handle, handle->
rom[i]) != 0)
567 handle->
debug_print(
"ds18b20: write command failed.\n");
574 handle->
debug_print(
"ds18b20: write command failed.\n");
578 for (i = 0; i < 9; i++)
580 if (a_ds18b20_read_byte(handle, (uint8_t *)&buf[i]) != 0)
582 handle->
debug_print(
"ds18b20: read data failed.\n");
587 if (a_ds18b20_check_crc((uint8_t *)buf, 8, buf[8]) != 0)
589 handle->
debug_print(
"ds18b20: crc check error.\n");
593 if (a_ds18b20_reset(handle) != 0)
595 handle->
debug_print(
"ds18b20: bus reset failed.\n");
601 handle->
debug_print(
"ds18b20: write command failed.\n");
605 for (i = 0; i < 8; i++)
607 if (a_ds18b20_write_byte(handle, handle->
rom[i]) != 0)
609 handle->
debug_print(
"ds18b20: write command failed.\n");
616 handle->
debug_print(
"ds18b20: write command failed.\n");
621 buf[4] |= resolution << 5;
622 for (i = 0; i < 3; i++)
624 if (a_ds18b20_write_byte(handle, buf[2 + i]) != 0)
626 handle->
debug_print(
"ds18b20: write command failed.\n");
668 if (a_ds18b20_reset(handle) != 0)
670 handle->
debug_print(
"ds18b20: bus reset failed.\n");
676 handle->
debug_print(
"ds18b20: write command failed.\n");
682 handle->
debug_print(
"ds18b20: write command failed.\n");
686 for (i = 0; i < 9; i++)
688 if (a_ds18b20_read_byte(handle, (uint8_t *)&buf[i]) != 0)
690 handle->
debug_print(
"ds18b20: read data failed.\n");
695 if (a_ds18b20_check_crc((uint8_t *)buf, 8, buf[8]) != 0)
697 handle->
debug_print(
"ds18b20: crc check error.\n");
707 if (a_ds18b20_reset(handle) != 0)
709 handle->
debug_print(
"ds18b20: bus reset failed.\n");
715 handle->
debug_print(
"ds18b20: write command failed.\n");
719 for (i = 0; i < 8; i++)
721 if (a_ds18b20_write_byte(handle, handle->
rom[i]) != 0)
723 handle->
debug_print(
"ds18b20: write command failed.\n");
730 handle->
debug_print(
"ds18b20: write command failed.\n");
734 for (i = 0; i < 9; i++)
736 if (a_ds18b20_read_byte(handle, (uint8_t *)&buf[i]) != 0)
738 handle->
debug_print(
"ds18b20: read data failed.\n");
743 if (a_ds18b20_check_crc((uint8_t *)buf, 8, buf[8]) != 0)
745 handle->
debug_print(
"ds18b20: crc check error.\n");
788 if (a_ds18b20_reset(handle) != 0)
790 handle->
debug_print(
"ds18b20: bus reset failed.\n");
796 handle->
debug_print(
"ds18b20: write command failed.\n");
802 handle->
debug_print(
"ds18b20: write command failed.\n");
806 for (i = 0; i < 9; i++)
808 if (a_ds18b20_read_byte(handle, (uint8_t *)&buf[i]) != 0)
810 handle->
debug_print(
"ds18b20: read data failed.\n");
815 if (a_ds18b20_check_crc((uint8_t *)buf, 8, buf[8]) != 0)
817 handle->
debug_print(
"ds18b20: crc check error.\n");
821 if (a_ds18b20_reset(handle) != 0)
823 handle->
debug_print(
"ds18b20: bus reset failed.\n");
829 handle->
debug_print(
"ds18b20: write command failed.\n");
835 handle->
debug_print(
"ds18b20: write command failed.\n");
839 buf[2] = (uint8_t)threshold_high;
840 buf[3] = (uint8_t)threshold_low;
841 for (i = 0; i < 3; i++)
843 if (a_ds18b20_write_byte(handle, buf[2 + i]) != 0)
845 handle->
debug_print(
"ds18b20: write command failed.\n");
855 if (a_ds18b20_reset(handle) != 0)
857 handle->
debug_print(
"ds18b20: bus reset failed.\n");
863 handle->
debug_print(
"ds18b20: write command failed.\n");
867 for (i = 0; i < 8; i++)
869 if (a_ds18b20_write_byte(handle, handle->
rom[i]) != 0)
871 handle->
debug_print(
"ds18b20: write command failed.\n");
878 handle->
debug_print(
"ds18b20: write command failed.\n");
882 for (i = 0; i < 9; i++)
884 if (a_ds18b20_read_byte(handle, (uint8_t *)&buf[i]) != 0)
886 handle->
debug_print(
"ds18b20: read data failed.\n");
891 if (a_ds18b20_check_crc((uint8_t *)buf, 8, buf[8]) != 0)
893 handle->
debug_print(
"ds18b20: crc check error.\n");
897 if (a_ds18b20_reset(handle) != 0)
899 handle->
debug_print(
"ds18b20: bus reset failed.\n");
905 handle->
debug_print(
"ds18b20: write command failed.\n");
909 for (i = 0; i < 8; i++)
911 if (a_ds18b20_write_byte(handle, handle->
rom[i]) != 0)
913 handle->
debug_print(
"ds18b20: write command failed.\n");
920 handle->
debug_print(
"ds18b20: write command failed.\n");
924 buf[2] = (uint8_t)threshold_high;
925 buf[3] = (uint8_t)threshold_low;
926 for (i = 0; i < 3; i++)
928 if (a_ds18b20_write_byte(handle, buf[2 + i]) != 0)
930 handle->
debug_print(
"ds18b20: write command failed.\n");
973 if (a_ds18b20_reset(handle) != 0)
975 handle->
debug_print(
"ds18b20: bus reset failed.\n");
981 handle->
debug_print(
"ds18b20: write command failed.\n");
987 handle->
debug_print(
"ds18b20: write command failed.\n");
991 for (i = 0; i < 9; i++)
993 if (a_ds18b20_read_byte(handle, (uint8_t *)&buf[i]) != 0)
995 handle->
debug_print(
"ds18b20: read data failed.\n");
1000 if (a_ds18b20_check_crc((uint8_t *)buf, 8, buf[8]) != 0)
1002 handle->
debug_print(
"ds18b20: crc check error.\n");
1006 *threshold_high = (int8_t)(buf[2]);
1007 *threshold_low = (int8_t)(buf[3]);
1013 if (a_ds18b20_reset(handle) != 0)
1015 handle->
debug_print(
"ds18b20: bus reset failed.\n");
1021 handle->
debug_print(
"ds18b20: write command failed.\n");
1025 for (i = 0; i < 8; i++)
1027 if (a_ds18b20_write_byte(handle, handle->
rom[i]) != 0)
1029 handle->
debug_print(
"ds18b20: write command failed.\n");
1036 handle->
debug_print(
"ds18b20: write command failed.\n");
1040 for (i = 0; i < 9; i++)
1042 if (a_ds18b20_read_byte(handle, (uint8_t *)&buf[i]) != 0)
1044 handle->
debug_print(
"ds18b20: read data failed.\n");
1049 if (a_ds18b20_check_crc((uint8_t *)buf, 8, buf[8]) != 0)
1051 handle->
debug_print(
"ds18b20: crc check error.\n");
1055 *threshold_high = (int8_t)(buf[2]);
1056 *threshold_low = (int8_t)(buf[3]);
1093 if (a_ds18b20_reset(handle) != 0)
1095 handle->
debug_print(
"ds18b20: bus reset failed.\n");
1101 handle->
debug_print(
"ds18b20: write command failed.\n");
1107 handle->
debug_print(
"ds18b20: write command failed.\n");
1116 if (a_ds18b20_reset(handle) != 0)
1118 handle->
debug_print(
"ds18b20: bus reset failed.\n");
1124 handle->
debug_print(
"ds18b20: write command failed.\n");
1128 for (i = 0; i < 8; i++)
1130 if (a_ds18b20_write_byte(handle, handle->
rom[i]) != 0)
1132 handle->
debug_print(
"ds18b20: write command failed.\n");
1139 handle->
debug_print(
"ds18b20: write command failed.\n");
1179 if (a_ds18b20_reset(handle) != 0)
1181 handle->
debug_print(
"ds18b20: bus reset failed.\n");
1187 handle->
debug_print(
"ds18b20: write command failed.\n");
1193 handle->
debug_print(
"ds18b20: write command failed.\n");
1202 if (a_ds18b20_reset(handle) != 0)
1204 handle->
debug_print(
"ds18b20: bus reset failed.\n");
1210 handle->
debug_print(
"ds18b20: write command failed.\n");
1214 for (i = 0; i < 8; i++)
1216 if (a_ds18b20_write_byte(handle, handle->
rom[i]) != 0)
1218 handle->
debug_print(
"ds18b20: write command failed.\n");
1225 handle->
debug_print(
"ds18b20: write command failed.\n");
1262 *reg = (int8_t)(temp);
1289 *temp = (float)(reg);
1317 handle->
debug_print(
"ds18b20: bus_init is null.\n");
1323 handle->
debug_print(
"ds18b20: bus_deinit is null.\n");
1329 handle->
debug_print(
"ds18b20: bus_read is null.\n");
1335 handle->
debug_print(
"ds18b20: bus_write is null.\n");
1341 handle->
debug_print(
"ds18b20: delay_ms is null.\n");
1347 handle->
debug_print(
"ds18b20: delay_us is null.\n");
1353 handle->
debug_print(
"ds18b20: enable_irq is null.\n");
1359 handle->
debug_print(
"ds18b20: disable_irq is null.\n");
1366 handle->
debug_print(
"ds18b20: bus init failed.\n");
1370 if (a_ds18b20_reset(handle) != 0)
1443 if (a_ds18b20_reset(handle) != 0)
1445 handle->
debug_print(
"ds18b20: bus reset failed.\n");
1451 handle->
debug_print(
"ds18b20: write command failed.\n");
1457 handle->
debug_print(
"ds18b20: write command failed.\n");
1463 while ((res == 0) && (cnt < 100))
1465 if (a_ds18b20_read_bit(handle, (uint8_t *)&res) != 0)
1467 handle->
debug_print(
"ds18b20: read bit failed.\n");
1476 handle->
debug_print(
"ds18b20: bus read timeout.\n");
1480 if (a_ds18b20_reset(handle) != 0)
1482 handle->
debug_print(
"ds18b20: bus reset failed.\n");
1488 handle->
debug_print(
"ds18b20: write command failed.\n");
1494 handle->
debug_print(
"ds18b20: write command failed.\n");
1498 for (i = 0; i < 9; i++)
1500 if (a_ds18b20_read_byte(handle, (uint8_t *)&buf[i]) != 0)
1502 handle->
debug_print(
"ds18b20: read byte failed.\n");
1507 if (a_ds18b20_check_crc((uint8_t *)buf, 8, buf[8]) != 0)
1509 handle->
debug_print(
"ds18b20: crc check error.\n");
1513 *raw = (int16_t)(((uint16_t)buf[1]) << 8) | buf[0];
1516 if ((((uint16_t)(*raw)) & (1 << 15)) != 0)
1518 *raw = (*raw ) >> 3;
1519 *raw = (*raw) | 0xE000U;
1523 *raw = (*raw ) >> 3;
1525 *temp = (float)(*raw) * 0.5f;
1529 if ((((uint16_t)(*raw)) & (1 << 15)) != 0)
1531 *raw = (*raw ) >> 2;
1532 *raw = (*raw) | 0xC000U;
1536 *raw = (*raw ) >> 2;
1538 *temp = (float)(*raw) * 0.25f;
1542 if ((((uint16_t)(*raw)) & (1 << 15)) != 0)
1544 *raw = (*raw ) >> 1;
1545 *raw = (*raw) | 0x8000U;
1549 *raw = (*raw ) >> 1;
1551 *temp = (float)(*raw) * 0.125f;
1555 *raw = (*raw ) >> 0;
1556 *temp = (float)(*raw) * 0.0625f;
1560 handle->
debug_print(
"ds18b20: resolution invalid.\n");
1569 if (a_ds18b20_reset(handle) != 0)
1571 handle->
debug_print(
"ds18b20: bus reset failed.\n");
1577 handle->
debug_print(
"ds18b20: write command failed.\n");
1581 for (i = 0; i < 8; i++)
1583 if (a_ds18b20_write_byte(handle, handle->
rom[i]) != 0)
1585 handle->
debug_print(
"ds18b20: write command failed.\n");
1592 handle->
debug_print(
"ds18b20: write command failed.\n");
1598 while ((res == 0) && (cnt < 100))
1600 if (a_ds18b20_read_bit(handle, (uint8_t *)&res) != 0)
1602 handle->
debug_print(
"ds18b20: read bit failed.\n");
1611 handle->
debug_print(
"ds18b20: bus read timeout.\n");
1615 if (a_ds18b20_reset(handle) != 0)
1617 handle->
debug_print(
"ds18b20: bus reset failed.\n");
1623 handle->
debug_print(
"ds18b20: write command failed.\n");
1627 for (i = 0; i < 8; i++)
1629 if (a_ds18b20_write_byte(handle, handle->
rom[i]) != 0)
1631 handle->
debug_print(
"ds18b20: write command failed.\n");
1638 handle->
debug_print(
"ds18b20: write command failed.\n");
1642 for (i = 0; i < 9; i++)
1644 if (a_ds18b20_read_byte(handle, (uint8_t *)&buf[i]) != 0)
1646 handle->
debug_print(
"ds18b20: read byte failed.\n");
1651 if (a_ds18b20_check_crc((uint8_t *)buf, 8, buf[8]) != 0)
1653 handle->
debug_print(
"ds18b20: crc check error.\n");
1657 *raw = (int16_t)(((uint16_t)buf[1]) << 8) | buf[0];
1660 if ((((uint16_t)(*raw)) & (1 << 15)) != 0)
1662 *raw = (*raw ) >> 3;
1663 *raw = (*raw) | 0xE000U;
1667 *raw = (*raw ) >> 3;
1669 *temp = (float)(*raw) * 0.5f;
1673 if ((((uint16_t)(*raw)) & (1 << 15)) != 0)
1675 *raw = (*raw ) >> 2;
1676 *raw = (*raw) | 0xC000U;
1680 *raw = (*raw ) >> 2;
1682 *temp = (float)(*raw) * 0.25f;
1686 if ((((uint16_t)(*raw)) & (1 << 15)) != 0)
1688 *raw = (*raw ) >> 1;
1689 *raw = (*raw) | 0x8000U;
1693 *raw = (*raw ) >> 1;
1695 *temp = (float)(*raw) * 0.125f;
1699 *raw = (*raw ) >> 0;
1700 *temp = (float)(*raw) * 0.0625f;
1704 handle->
debug_print(
"ds18b20: resolution invalid.\n");
1735 for (i = 0; i < 2; i++)
1738 if (a_ds18b20_read_bit(handle, (uint8_t *)&res) != 0)
1741 handle->
debug_print(
"ds18b20: read bit failed.\n");
1745 *data = (*data) | res;
1768 handle->
debug_print(
"ds18b20: write bit failed.\n");
1776 handle->
debug_print(
"ds18b20: write bit failed.\n");
1784 handle->
debug_print(
"ds18b20: write bit failed.\n");
1805static uint8_t a_ds18b20_search(
ds18b20_handle_t *handle, uint8_t (*pid)[8], uint8_t cmd, uint8_t *number)
1807 uint8_t k, l = 0, conflict_bit, m, n;
1815 handle->
debug_print(
"ds18b20: number is over DS18B20_MAX_SEARCH_SIZE.\n");
1820 memset((uint8_t *)ss, 0,
sizeof(uint8_t) * 64);
1823 if (a_ds18b20_reset(handle) != 0)
1829 if (a_ds18b20_write_byte(handle, cmd) != 0)
1831 handle->
debug_print(
"ds18b20: write command failed.\n");
1835 for (m = 0; m < 8; m++)
1837 for (n = 0; n < 8; n++)
1839 if (a_ds18b20_read_2bit(handle, (uint8_t *)&k) != 0)
1841 handle->
debug_print(
"ds18b20: read 2bit failed.\n");
1849 if (a_ds18b20_write_bit(handle, 0) != 0)
1851 handle->
debug_print(
"ds18b20: write bit failed.\n");
1855 ss[(m * 8 + n)] = 0;
1860 if (a_ds18b20_write_bit(handle, 1) != 0)
1862 handle->
debug_print(
"ds18b20: write bit failed.\n");
1866 ss[(m * 8 + n)] = 1;
1870 conflict_bit = (uint8_t)(m * 8 + n + 1);
1871 if (conflict_bit > buffer[l])
1873 if (a_ds18b20_write_bit(handle, 0) != 0)
1875 handle->
debug_print(
"ds18b20: write bit failed.\n");
1879 ss[(m * 8 + n)] = 0;
1880 buffer[++l] = conflict_bit;
1882 else if (conflict_bit < buffer[l])
1884 s = s|((ss[(m * 8 + n)] & 0x01) << 7);
1885 if (a_ds18b20_write_bit(handle, ss[(m*8+n)]) != 0)
1887 handle->
debug_print(
"ds18b20: write bit failed.\n");
1892 else if (conflict_bit == buffer[l])
1895 if (a_ds18b20_write_bit(handle, 1) != 0)
1897 handle->
debug_print(
"ds18b20: write bit failed.\n");
1901 ss[(m * 8 + n)] = 1;
1921 if (num > (*number))
1925 }
while (buffer[l] != 0);
2003 if (a_ds18b20_reset(handle) != 0)
2005 handle->
debug_print(
"ds18b20: bus reset failed.\n");
2011 handle->
debug_print(
"ds18b20: write command failed.\n");
2017 handle->
debug_print(
"ds18b20: write command failed.\n");
2021 if (a_ds18b20_read_bit(handle, (uint8_t *)power_mode) != 0)
2023 handle->
debug_print(
"ds18b20: read bit failed.\n");
2032 if (a_ds18b20_reset(handle) != 0)
2034 handle->
debug_print(
"ds18b20: bus reset failed.\n");
2040 handle->
debug_print(
"ds18b20: write command failed.\n");
2044 for (i = 0; i < 8; i++)
2046 if (a_ds18b20_write_byte(handle, handle->
rom[i]) != 0)
2048 handle->
debug_print(
"ds18b20: write command failed.\n");
2055 handle->
debug_print(
"ds18b20: write command failed.\n");
2059 if (a_ds18b20_read_bit(handle, (uint8_t *)power_mode) != 0)
2061 handle->
debug_print(
"ds18b20: read bit failed.\n");
#define DS18B20_CMD_READ_SCRATCHPAD
#define DS18B20_CMD_WRITE_SCRATCHPAD
#define DS18B20_CMD_SKIP_ROM
#define SUPPLY_VOLTAGE_MAX
#define DS18B20_CMD_MATCH_ROM
#define DS18B20_CMD_READ_ROM
#define MANUFACTURER_NAME
#define SUPPLY_VOLTAGE_MIN
#define DS18B20_CMD_RECALL_EE
#define DS18B20_CMD_CONVERT_T
#define CHIP_NAME
chip information definition
#define DS18B20_CMD_SEARCH_ROM
chip command definition
#define DS18B20_CMD_COPY_SCRATCHPAD
#define DS18B20_CMD_READ_POWER_SUPPLY
#define DS18B20_CMD_ALARM_SEARCH
driver ds18b20 header file
uint8_t ds18b20_alarm_convert_to_data(ds18b20_handle_t *handle, int8_t reg, float *temp)
convert the register data to the alarm temperature
uint8_t ds18b20_search_alarm(ds18b20_handle_t *handle, uint8_t(*rom)[8], uint8_t *num)
search the ds18b20 alarm rom
#define DS18B20_MAX_SEARCH_SIZE
ds18b20 max search size definition
uint8_t ds18b20_get_power_mode(ds18b20_handle_t *handle, ds18b20_power_mode_t *power_mode)
get the power mode
uint8_t ds18b20_search_rom(ds18b20_handle_t *handle, uint8_t(*rom)[8], uint8_t *num)
search the ds18b20 rom
uint8_t ds18b20_scrachpad_get_alarm_threshold(ds18b20_handle_t *handle, int8_t *threshold_high, int8_t *threshold_low)
get the alarm threshold in the scratchpad
uint8_t ds18b20_scratchpad_set_alarm_threshold(ds18b20_handle_t *handle, int8_t threshold_high, int8_t threshold_low)
set the alarm threshold in the scratchpad
uint8_t ds18b20_alarm_convert_to_register(ds18b20_handle_t *handle, float temp, int8_t *reg)
convert the alarm temperature to the register data
uint8_t ds18b20_scratchpad_get_resolution(ds18b20_handle_t *handle, ds18b20_resolution_t *resolution)
get the resolution in the scratchpad
ds18b20_power_mode_t
ds18b20 power mode enumeration definition
uint8_t ds18b20_init(ds18b20_handle_t *handle)
initialize the chip
uint8_t ds18b20_set_rom(ds18b20_handle_t *handle, uint8_t rom[8])
set the handle rom
uint8_t ds18b20_copy_eeprom_to_scratchpad(ds18b20_handle_t *handle)
copy the eeprom content to the scratchpad
uint8_t ds18b20_copy_scratchpad_to_eeprom(ds18b20_handle_t *handle)
copy the scratchpad content to the eeprom
ds18b20_resolution_t
ds18b20 resolution enumeration definition
uint8_t ds18b20_info(ds18b20_info_t *info)
get chip's information
uint8_t ds18b20_read(ds18b20_handle_t *handle, int16_t *raw, float *temp)
read data from the chip
uint8_t ds18b20_scratchpad_set_resolution(ds18b20_handle_t *handle, ds18b20_resolution_t resolution)
set the resolution in the scratchpad
struct ds18b20_handle_s ds18b20_handle_t
ds18b20 handle structure definition
ds18b20_mode_t
ds18b20 mode enumeration definition
uint8_t ds18b20_deinit(ds18b20_handle_t *handle)
close the chip
uint8_t ds18b20_get_mode(ds18b20_handle_t *handle, ds18b20_mode_t *mode)
get the chip mode
uint8_t ds18b20_set_mode(ds18b20_handle_t *handle, ds18b20_mode_t mode)
set the chip mode
struct ds18b20_info_s ds18b20_info_t
ds18b20 info structure definition
uint8_t ds18b20_get_rom(ds18b20_handle_t *handle, uint8_t rom[8])
get the chip rom
@ DS18B20_RESOLUTION_11BIT
@ DS18B20_RESOLUTION_9BIT
@ DS18B20_RESOLUTION_10BIT
@ DS18B20_RESOLUTION_12BIT
uint8_t(* bus_deinit)(void)
void(* delay_ms)(uint32_t ms)
void(* debug_print)(const char *const fmt,...)
void(* delay_us)(uint32_t us)
void(* disable_irq)(void)
uint8_t(* bus_read)(uint8_t *value)
uint8_t(* bus_write)(uint8_t value)
uint8_t(* bus_init)(void)
float supply_voltage_max_v
char manufacturer_name[32]
float supply_voltage_min_v