gem5  v20.0.0.3
t1000.hh
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2004-2005 The Regents of The University of Michigan
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions are
7  * met: redistributions of source code must retain the above copyright
8  * notice, this list of conditions and the following disclaimer;
9  * redistributions in binary form must reproduce the above copyright
10  * notice, this list of conditions and the following disclaimer in the
11  * documentation and/or other materials provided with the distribution;
12  * neither the name of the copyright holders nor the names of its
13  * contributors may be used to endorse or promote products derived from
14  * this software without specific prior written permission.
15  *
16  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
19  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
20  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27  */
28 
35 #ifndef __DEV_T1000_HH__
36 #define __DEV_T1000_HH__
37 
38 #include "dev/platform.hh"
39 #include "params/T1000.hh"
40 
41 class IdeController;
42 class System;
43 
44 class T1000 : public Platform
45 {
46  public:
49 
50  public:
51  typedef T1000Params Params;
58  T1000(const Params *p);
59 
63  virtual void postConsoleInt();
64 
68  virtual void clearConsoleInt();
69 
73  virtual void postPciInt(int line);
74 
78  virtual void clearPciInt(int line);
79 
80 
81  virtual Addr pciToDma(Addr pciAddr) const;
82 
86  virtual Addr calcPciConfigAddr(int bus, int dev, int func);
87 
91  virtual Addr calcPciIOAddr(Addr addr);
92 
96  virtual Addr calcPciMemAddr(Addr addr);
97 };
98 
99 #endif // __DEV_T1000_HH__
virtual Addr calcPciConfigAddr(int bus, int dev, int func)
Calculate the configuration address given a bus/dev/func.
Definition: t1000.cc:83
ip6_addr_t addr
Definition: inet.hh:330
Device model for an Intel PIIX4 IDE controller.
Definition: ide_ctrl.hh:48
Definition: system.hh:72
virtual Addr pciToDma(Addr pciAddr) const
Definition: t1000.cc:75
T1000Params Params
Definition: t1000.hh:51
virtual void postPciInt(int line)
Cause the chipset to post a cpi interrupt to the CPU.
Definition: t1000.cc:63
Definition: t1000.hh:44
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Definition: types.hh:140
Generic interface for platforms.
virtual Addr calcPciIOAddr(Addr addr)
Calculate the address for an IO location on the PCI bus.
Definition: t1000.cc:90
virtual Addr calcPciMemAddr(Addr addr)
Calculate the address for a memory location on the PCI bus.
Definition: t1000.cc:97
virtual void clearConsoleInt()
Clear a posted CPU interrupt.
Definition: t1000.cc:56
T1000(const Params *p)
Constructor for the Tsunami Class.
Definition: t1000.cc:44
System * system
Pointer to the system.
Definition: t1000.hh:48
virtual void postConsoleInt()
Cause the cpu to post a serial interrupt to the CPU.
Definition: t1000.cc:49
Bitfield< 0 > p
virtual void clearPciInt(int line)
Clear a posted PCI->CPU interrupt.
Definition: t1000.cc:69

Generated on Fri Jul 3 2020 15:53:02 for gem5 by doxygen 1.8.13