/*************************************************************************** * Copyright (C) 2006 Nicolas Hadacek * * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation; either version 2 of the License, or * * (at your option) any later version. * ***************************************************************************/ #ifndef REGISTER_H #define REGISTER_H #include "common/common/storage.h" #include "devices/base/generic_device.h" namespace Register { class TypeData; } namespace Device { enum RegisterProperty { NotAccessible = 0x0, Readable = 0x1, Writable = 0x2 }; TQ_DECLARE_FLAGS(RegisterProperties, RegisterProperty) TQ_DECLARE_OPERATORS_FOR_FLAGS(RegisterProperties) enum { MAX_NB_PORTS = 8 }; enum { MAX_NB_PORT_BITS = 16 }; enum BitState { Low = 0, High, WeakPullUp, WeakPullDown, HighImpedance, Unknown }; enum IoState { IoLow = 0, IoHigh, IoUnknown }; class PortBitData { public: PortBitData() : state(Unknown), driving(false), drivenState(IoUnknown), drivingState(IoUnknown) {} BitState state; bool driving; IoState drivenState, drivingState; bool operator !=(const PortBitData &pdb) const { return ( state!=pdb.state || driving!=pdb.driving || drivenState!=pdb.drivenState || drivingState!=pdb.drivingState ); } }; } // namespace namespace Register { //---------------------------------------------------------------------------- enum Type { Regular, Special, Combined, Invalid }; class TypeData { public: TypeData() : _nbChars(0) {} TypeData(Address address, uint nbChars); TypeData(const TQString &name, uint nbChars); TypeData(const TQString &name, Address address, uint nbChars); bool operator ==(const TypeData &data) const { return _name==data._name && _address==data._address && _nbChars==data._nbChars; } Type type() const; TQString name() const { return _name; } Address address() const { return _address; } uint nbChars() const { return _nbChars; } TQString toString() const; static TypeData fromString(const TQString &s); private: uint _nbChars; Address _address; TQString _name; }; } // namespace namespace Device { //---------------------------------------------------------------------------- class RegistersData { public: RegistersData() {} virtual ~RegistersData() {} virtual uint nbRegisters() const = 0; virtual uint nbBits() const = 0; uint nbBytes() const { return nbBitsToNbBytes(nbBits()); } uint nbChars() const { return nbBitsToNbChars(nbBits()); } virtual uint addressFromIndex(uint i) const = 0; virtual uint indexFromAddress(Address address) const = 0; virtual RegisterProperties properties(Address address) const = 0; virtual TQValueList relatedRegisters(const Register::TypeData &data) const = 0; virtual bool hasPort(uint index) const = 0; virtual int portIndex(Address address) const = 0; virtual TQString portName(uint index) const = 0; virtual bool hasPortBit(uint index, uint bit) const = 0; virtual TQString portBitName(uint index, uint bit) const = 0; }; } // namespace namespace Register { //---------------------------------------------------------------------------- class List; extern List &list(); class List : public GenericStorage { Q_OBJECT TQ_OBJECT public: List() : GenericStorage(0, "register_list") {} void init(); void setWatched(const TypeData &data, bool watched); void clearWatched(); const TQValueList &watched() const { return _watched; } bool isWatched(const TypeData &data) const { return _watched.tqcontains(data); } void setValue(const TypeData &data, BitValue value); BitValue value(const TypeData &data) const; BitValue oldValue(const TypeData &data) const; void setPortData(uint index, const TQMap &data); TQMap portData(uint index) const { return _portDatas[index].current; } TQMap oldPortData(uint index) const { return _portDatas[index].old; } private: class StateData { public: BitValue current, old; }; TQMap _regulars; // registers with address TQMap _specials; // registers with no address class PortData { public: TQMap current, old; }; TQMap _portDatas; // port index TQValueList _watched; }; } // namespace #endif