#include "rc522_i2c.h" #include "esphome/core/log.h" namespace esphome { namespace rc522_i2c { static const char *TAG = "rc522_i2c"; void RC522I2C::dump_config() { RC522::dump_config(); LOG_I2C_DEVICE(this); } /** * Reads a uint8_t from the specified register in the MFRC522 chip. * The interface is described in the datasheet section 8.1.2. */ uint8_t RC522I2C::pcd_read_register(PcdRegister reg ///< The register to read from. One of the PCD_Register enums. ) { uint8_t value; read_byte(reg >> 1, &value); ESP_LOGVV(TAG, "read_register_(%x) -> %x", reg, value); return value; } /** * Reads a number of uint8_ts from the specified register in the MFRC522 chip. * The interface is described in the datasheet section 8.1.2. */ void RC522I2C::pcd_read_register(PcdRegister reg, ///< The register to read from. One of the PCD_Register enums. uint8_t count, ///< The number of uint8_ts to read uint8_t *values, ///< uint8_t array to store the values in. uint8_t rx_align ///< Only bit positions rxAlign..7 in values[0] are updated. ) { if (count == 0) { return; } std::string buf; buf = "Rx"; char cstrb[20]; uint8_t b = values[0]; read_bytes(reg >> 1, values, count); if (rx_align) // Only update bit positions rxAlign..7 in values[0] { // Create bit mask for bit positions rxAlign..7 uint8_t mask = 0xFF << rx_align; // Apply mask to both current value of values[0] and the new data in values array. values[0] = (b & ~mask) | (values[0] & mask); } } void RC522I2C::pcd_write_register(PcdRegister reg, ///< The register to write to. One of the PCD_Register enums. uint8_t value ///< The value to write. ) { this->write_byte(reg >> 1, value); } /** * Writes a number of uint8_ts to the specified register in the MFRC522 chip. * The interface is described in the datasheet section 8.1.2. */ void RC522I2C::pcd_write_register(PcdRegister reg, ///< The register to write to. One of the PCD_Register enums. uint8_t count, ///< The number of uint8_ts to write to the register uint8_t *values ///< The values to write. uint8_t array. ) { write_bytes(reg >> 1, values, count); } // bool RC522I2C::write_data(const std::vector &data) { // return this->write_bytes_raw(data.data(), data.size()); } // bool RC522I2C::read_data(std::vector &data, uint8_t len) { // delay(5); // std::vector ready; // ready.resize(1); // uint32_t start_time = millis(); // while (true) { // if (this->read_bytes_raw(ready.data(), 1)) { // if (ready[0] == 0x01) // break; // } // if (millis() - start_time > 100) { // ESP_LOGV(TAG, "Timed out waiting for readiness from RC522!"); // return false; // } // } // data.resize(len + 1); // this->read_bytes_raw(data.data(), len + 1); // return true; // } } // namespace rc522_i2c } // namespace esphome