Implementation of 1-Wire with added Alarm Search Functionality

Dependents:   Max32630_One_Wire_Interface

RomId.hpp

Committer:
IanBenzMaxim
Date:
2016-04-08
Revision:
49:36954b62f503
Parent:
33:a4c015046956
Child:
62:43039aeca2ab

File content as of revision 49:36954b62f503:

/******************************************************************//**
* Copyright (C) 2016 Maxim Integrated Products, Inc., All Rights Reserved.
*
* Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the "Software"),
* to deal in the Software without restriction, including without limitation
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
* and/or sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included
* in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
* IN NO EVENT SHALL MAXIM INTEGRATED BE LIABLE FOR ANY CLAIM, DAMAGES
* OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*
* Except as contained in this notice, the name of Maxim Integrated
* Products, Inc. shall not be used except as stated in the Maxim Integrated
* Products, Inc. Branding Policy.
*
* The mere transfer of this software does not imply any licenses
* of trade secrets, proprietary technology, copyrights, patents,
* trademarks, maskwork rights, or any other form of intellectual
* property whatsoever. Maxim Integrated Products, Inc. retains all
* ownership rights.
**********************************************************************/


#ifndef _ROMID_HPP
#define _ROMID_HPP

#include <cstdint>

#include "array.hpp"

/// Standard container for a 1-Wire ROM ID.
class RomId
{
public:
    /// Length of the buffer in bytes.
    static const std::size_t byteLen = 8;
    
    /// Built-in array representation.
    typedef array<std::uint8_t, byteLen>::Buffer ByteBuffer;

    /// Perform a CRC8 calculation.
    /// @param crc8 Beginning state of the CRC generator.
    /// @param data Data to pass though the CRC generator.
    /// @returns The calculated CRC8.
    static std::uint8_t calculateCRC8(std::uint8_t crc8, std::uint8_t data);
    
    /// Perform a CRC8 calculation with variable length data.
    /// @param[in] data Data array to pass through the CRC generator.
    /// @param data_len Length of the data array to process.
    /// @param crc Beginning state of the CRC generator.
    /// @returns The calculated CRC8.
    static std::uint8_t calculateCRC8(const std::uint8_t * data, std::size_t data_len, std::uint8_t crc = 0);

private:
    static const std::size_t familyCodeIdx = 0;
    static const std::size_t crc8Idx = 7;
    
    /// Default starting value is all bytes 0x00.
    static const std::uint8_t defaultByteVal = 0x00;

    array<std::uint8_t, byteLen> m_romId;

public:
    const RomId & operator=(const RomId & rhs)
    {
        this->m_romId = rhs.m_romId;
        return rhs;
    }
    
    bool operator==(const RomId & rhs) const
    {
        return (this->m_romId == rhs.m_romId);
    }
    
    bool operator!=(const RomId & rhs) const
    {
        return !operator==(rhs);
    }
    
    /// Conversion to array reference.
    operator ByteBuffer &()
    {
        return m_romId;
    }
    
    /// Conversion to const array reference.
    operator const ByteBuffer &() const
    {
        return m_romId;
    }

    /// Reset to the default starting value.
    void reset()
    {
        std::memset(m_romId, defaultByteVal, byteLen);
    }

    RomId() { reset(); }
    RomId(const RomId & romId) : m_romId(romId.m_romId) { }
    RomId(const ByteBuffer & romIdBytes) : m_romId(romIdBytes) { }

    /// Read the Family Code byte.
    std::uint8_t familyCode() const
    {
        return m_romId[familyCodeIdx];
    }
    
    /// Set the family code byte.
    void setFamilyCode(std::uint8_t familyCode)
    {
        m_romId[familyCodeIdx] = familyCode;
    }

    /// Read the CRC8 byte.
    std::uint8_t crc8() const
    {
        return m_romId[crc8Idx];
    }
    
    /// Set the CRC8 byte.
    void setCrc8(std::uint8_t crc8)
    {
        m_romId[crc8Idx] = crc8;
    }
    
    /// Check if the CRC8 is valid for the ROM ID.
    /// @returns True if the CRC8 is valid.
    bool crc8Valid() const
    {
        return (calculateCRC8(m_romId, (byteLen - 1), 0x00) == crc8());
    }
    
    /// Calculate and set the CRC8 for the ROM ID.
    void setValidCrc8()
    {
        setCrc8(calculateCRC8(m_romId, (byteLen - 1), 0x00));
    }

    /// Check if the ROM ID is valid (Family Code and CRC8 are both valid).
    /// @returns True if the ROM ID is valid.
    bool valid() const
    {
        return (crc8Valid() && (familyCode() != defaultByteVal));
    }
};

#endif