gem5  v20.0.0.0
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
Classes | Public Member Functions | Protected Types | Protected Member Functions | Protected Attributes | List of all members
Intel8254Timer Class Reference

Programmable Interval Timer (Intel 8254) More...

#include <intel_8254_timer.hh>

Inheritance diagram for Intel8254Timer:
EventManager X86ISA::I8254::X86Intel8254Timer

Classes

class  Counter
 Counter element for PIT. More...
 

Public Member Functions

virtual ~Intel8254Timer ()
 
 Intel8254Timer (EventManager *em, const std::string &name, Counter *counter0, Counter *counter1, Counter *counter2)
 
 Intel8254Timer (EventManager *em, const std::string &name)
 
void writeControl (const CtrlReg data)
 Write control word. More...
 
uint8_t readCounter (unsigned int num)
 
void writeCounter (unsigned int num, const uint8_t data)
 
bool outputHigh (unsigned int num)
 
void serialize (const std::string &base, CheckpointOut &cp) const
 Serialize this object to the given output stream. More...
 
void unserialize (const std::string &base, CheckpointIn &cp)
 Reconstruct the state of this object from a checkpoint. More...
 
void startup ()
 Start ticking. More...
 
- Public Member Functions inherited from EventManager
EventQueueeventQueue () const
 
void schedule (Event &event, Tick when)
 
void deschedule (Event &event)
 
void reschedule (Event &event, Tick when, bool always=false)
 
void schedule (Event *event, Tick when)
 
void deschedule (Event *event)
 
void reschedule (Event *event, Tick when, bool always=false)
 
void wakeupEventQueue (Tick when=(Tick) -1)
 
void setCurTick (Tick newVal)
 
 EventManager (EventManager &em)
 
 EventManager (EventManager *em)
 
 EventManager (EventQueue *eq)
 

Protected Types

enum  ReadWriteVal { LatchCommand, LsbOnly, MsbOnly, TwoPhase }
 
enum  ModeVal {
  InitTc, OneShot, RateGen, SquareWave,
  SoftwareStrobe, HardwareStrobe
}
 

Protected Member Functions

 BitUnion8 (CtrlReg) Bitfield< 7
 
 EndBitUnion (CtrlReg) enum SelectVal
 
const std::string & name () const
 
virtual void counterInterrupt (unsigned int num)
 

Protected Attributes

 sel
 
Bitfield< 5, 4 > rw
 
Bitfield< 3, 1 > mode
 
Bitfield< 0 > bcd
 
std::string _name
 
Countercounter [3]
 PIT has three seperate counters. More...
 
- Protected Attributes inherited from EventManager
EventQueueeventq
 A pointer to this object's event queue. More...
 

Detailed Description

Programmable Interval Timer (Intel 8254)

Definition at line 43 of file intel_8254_timer.hh.

Member Enumeration Documentation

◆ ModeVal

enum Intel8254Timer::ModeVal
protected
Enumerator
InitTc 
OneShot 
RateGen 
SquareWave 
SoftwareStrobe 
HardwareStrobe 

Definition at line 67 of file intel_8254_timer.hh.

◆ ReadWriteVal

Enumerator
LatchCommand 
LsbOnly 
MsbOnly 
TwoPhase 

Definition at line 60 of file intel_8254_timer.hh.

Constructor & Destructor Documentation

◆ ~Intel8254Timer()

virtual Intel8254Timer::~Intel8254Timer ( )
inlinevirtual

Definition at line 208 of file intel_8254_timer.hh.

References data, X86ISA::em, Intel8254Timer(), Event::name(), and writeControl().

◆ Intel8254Timer() [1/2]

Intel8254Timer::Intel8254Timer ( EventManager em,
const std::string &  name,
Counter counter0,
Counter counter1,
Counter counter2 
)

Referenced by ~Intel8254Timer().

◆ Intel8254Timer() [2/2]

Intel8254Timer::Intel8254Timer ( EventManager em,
const std::string &  name 
)

Member Function Documentation

◆ BitUnion8()

Intel8254Timer::BitUnion8 ( CtrlReg  )
protected

◆ counterInterrupt()

virtual void Intel8254Timer::counterInterrupt ( unsigned int  num)
inlineprotectedvirtual

Reimplemented in X86ISA::I8254::X86Intel8254Timer.

Definition at line 200 of file intel_8254_timer.hh.

References DPRINTF.

Referenced by Intel8254Timer::Counter::CounterEvent::process().

◆ EndBitUnion()

Intel8254Timer::EndBitUnion ( CtrlReg  )
inlineprotected

Definition at line 51 of file intel_8254_timer.hh.

◆ name()

const std::string& Intel8254Timer::name ( ) const
inlineprotected

Definition at line 194 of file intel_8254_timer.hh.

References Intel8254Timer::Counter::_name.

Referenced by X86ISA::I8254::I8254().

◆ outputHigh()

bool Intel8254Timer::outputHigh ( unsigned int  num)
inline

◆ readCounter()

uint8_t Intel8254Timer::readCounter ( unsigned int  num)
inline

◆ serialize()

void Intel8254Timer::serialize ( const std::string &  base,
CheckpointOut cp 
) const

Serialize this object to the given output stream.

Parameters
baseThe base name of the counter object.
osThe stream to serialize to.

Definition at line 71 of file intel_8254_timer.cc.

Referenced by X86ISA::I8254::serialize(), MaltaIO::serialize(), and X86ISA::I8254::writeControl().

◆ startup()

void Intel8254Timer::startup ( )

Start ticking.

Definition at line 89 of file intel_8254_timer.cc.

Referenced by X86ISA::I8254::startup(), MaltaIO::startup(), and X86ISA::I8254::writeControl().

◆ unserialize()

void Intel8254Timer::unserialize ( const std::string &  base,
CheckpointIn cp 
)

Reconstruct the state of this object from a checkpoint.

Parameters
baseThe base name of the counter object.
cpThe checkpoint use.
sectionThe section name of this object

Definition at line 80 of file intel_8254_timer.cc.

Referenced by X86ISA::I8254::unserialize(), MaltaIO::unserialize(), and X86ISA::I8254::writeControl().

◆ writeControl()

void Intel8254Timer::writeControl ( const CtrlReg  data)

Write control word.

Definition at line 54 of file intel_8254_timer.cc.

References panic, and ArmISA::sel.

Referenced by X86ISA::I8254::write(), X86ISA::I8254::writeControl(), and ~Intel8254Timer().

◆ writeCounter()

void Intel8254Timer::writeCounter ( unsigned int  num,
const uint8_t  data 
)
inline

Member Data Documentation

◆ _name

std::string Intel8254Timer::_name
protected

Definition at line 193 of file intel_8254_timer.hh.

◆ bcd

Bitfield<0> Intel8254Timer::bcd
protected

Definition at line 50 of file intel_8254_timer.hh.

◆ counter

Counter* Intel8254Timer::counter[3]
protected

◆ mode

Bitfield<3, 1> Intel8254Timer::mode
protected

Definition at line 49 of file intel_8254_timer.hh.

◆ rw

Bitfield<5, 4> Intel8254Timer::rw
protected

Definition at line 48 of file intel_8254_timer.hh.

◆ sel

Intel8254Timer::sel
protected

Definition at line 47 of file intel_8254_timer.hh.


The documentation for this class was generated from the following files:

Generated on Thu May 28 2020 16:21:46 for gem5 by doxygen 1.8.13