T1000.py revision 3914
112047Schristian.menard@tu-dresden.defrom m5.params import *
212047Schristian.menard@tu-dresden.defrom m5.proxy import *
312047Schristian.menard@tu-dresden.defrom Device import BasicPioDevice, IsaFake, BadAddr
412047Schristian.menard@tu-dresden.defrom Uart import Uart8250
512047Schristian.menard@tu-dresden.defrom Platform import Platform
612047Schristian.menard@tu-dresden.defrom SimConsole import SimConsole, ConsoleListener
712047Schristian.menard@tu-dresden.de
812047Schristian.menard@tu-dresden.de
912047Schristian.menard@tu-dresden.declass MmDisk(BasicPioDevice):
1012047Schristian.menard@tu-dresden.de    type = 'MmDisk'
1112047Schristian.menard@tu-dresden.de    image = Param.DiskImage("Disk Image")
1212047Schristian.menard@tu-dresden.de    pio_addr = 0x1F40000000
1312047Schristian.menard@tu-dresden.de
1412047Schristian.menard@tu-dresden.declass DumbTOD(BasicPioDevice):
1512047Schristian.menard@tu-dresden.de    type = 'DumbTOD'
1612047Schristian.menard@tu-dresden.de    time = Param.Time('01/01/2009', "System time to use ('Now' for real time)")
1712047Schristian.menard@tu-dresden.de    pio_addr = 0xfff0c1fff8
1812047Schristian.menard@tu-dresden.de
1912047Schristian.menard@tu-dresden.de
2012047Schristian.menard@tu-dresden.declass T1000(Platform):
2112047Schristian.menard@tu-dresden.de    type = 'T1000'
2212047Schristian.menard@tu-dresden.de    system = Param.System(Parent.any, "system")
2312047Schristian.menard@tu-dresden.de
2412047Schristian.menard@tu-dresden.de    fake_clk = IsaFake(pio_addr=0x9600000000, pio_size=0x100000000,
2512047Schristian.menard@tu-dresden.de            warn_access="Accessing Clock Unit -- Unimplemented!")
2612047Schristian.menard@tu-dresden.de
2712047Schristian.menard@tu-dresden.de    fake_membnks = IsaFake(pio_addr=0x9700000000, pio_size=16384,
2812047Schristian.menard@tu-dresden.de            ret_data64=0x0000000000000000, update_data=False,
2912047Schristian.menard@tu-dresden.de            warn_access="Accessing Memory Banks -- Unimplemented!")
3012047Schristian.menard@tu-dresden.de
3112047Schristian.menard@tu-dresden.de    fake_iob = IsaFake(pio_addr=0x9800000000, pio_size=0x100000000,
3212047Schristian.menard@tu-dresden.de            warn_access="Accessing IOB -- Unimplemented!")
3312047Schristian.menard@tu-dresden.de
3412047Schristian.menard@tu-dresden.de    fake_jbi = IsaFake(pio_addr=0x8000000000, pio_size=0x100000000,
3512047Schristian.menard@tu-dresden.de            warn_access="Accessing JBI -- Unimplemented!")
3612047Schristian.menard@tu-dresden.de
3712047Schristian.menard@tu-dresden.de    fake_l2_1 = IsaFake(pio_addr=0xA900000000, pio_size=0x8,
3812047Schristian.menard@tu-dresden.de            ret_data64=0x0000000000000001, update_data=True,
3912047Schristian.menard@tu-dresden.de            warn_access="Accessing L2 Cache Banks -- Unimplemented!")
4012047Schristian.menard@tu-dresden.de
4112047Schristian.menard@tu-dresden.de    fake_l2_2 = IsaFake(pio_addr=0xA900000040, pio_size=0x8,
4212047Schristian.menard@tu-dresden.de            ret_data64=0x0000000000000001, update_data=True,
4312047Schristian.menard@tu-dresden.de            warn_access="Accessing L2 Cache Banks -- Unimplemented!")
4412047Schristian.menard@tu-dresden.de
4512047Schristian.menard@tu-dresden.de    fake_l2_3 = IsaFake(pio_addr=0xA900000080, pio_size=0x8,
4612047Schristian.menard@tu-dresden.de            ret_data64=0x0000000000000001, update_data=True,
4712047Schristian.menard@tu-dresden.de            warn_access="Accessing L2 Cache Banks -- Unimplemented!")
4812047Schristian.menard@tu-dresden.de
4912047Schristian.menard@tu-dresden.de    fake_l2_4 = IsaFake(pio_addr=0xA9000000C0, pio_size=0x8,
5012047Schristian.menard@tu-dresden.de            ret_data64=0x0000000000000001, update_data=True,
5112047Schristian.menard@tu-dresden.de            warn_access="Accessing L2 Cache Banks -- Unimplemented!")
5212047Schristian.menard@tu-dresden.de
5312047Schristian.menard@tu-dresden.de    fake_l2esr_1 = IsaFake(pio_addr=0xAB00000000, pio_size=0x8,
5412047Schristian.menard@tu-dresden.de            ret_data64=0x0000000000000000, update_data=True,
5512047Schristian.menard@tu-dresden.de            warn_access="Accessing L2 ESR Cache Banks -- Unimplemented!")
5612047Schristian.menard@tu-dresden.de
5712047Schristian.menard@tu-dresden.de    fake_l2esr_2 = IsaFake(pio_addr=0xAB00000040, pio_size=0x8,
5812047Schristian.menard@tu-dresden.de            ret_data64=0x0000000000000000, update_data=True,
5912047Schristian.menard@tu-dresden.de            warn_access="Accessing L2 ESR Cache Banks -- Unimplemented!")
6012047Schristian.menard@tu-dresden.de
6112047Schristian.menard@tu-dresden.de    fake_l2esr_3 = IsaFake(pio_addr=0xAB00000080, pio_size=0x8,
6212047Schristian.menard@tu-dresden.de            ret_data64=0x0000000000000000, update_data=True,
6312047Schristian.menard@tu-dresden.de            warn_access="Accessing L2 ESR Cache Banks -- Unimplemented!")
6412047Schristian.menard@tu-dresden.de
6512047Schristian.menard@tu-dresden.de    fake_l2esr_4 = IsaFake(pio_addr=0xAB000000C0, pio_size=0x8,
6612047Schristian.menard@tu-dresden.de            ret_data64=0x0000000000000000, update_data=True,
6712047Schristian.menard@tu-dresden.de            warn_access="Accessing L2 ESR Cache Banks -- Unimplemented!")
6812047Schristian.menard@tu-dresden.de
6912047Schristian.menard@tu-dresden.de    fake_ssi = IsaFake(pio_addr=0xff00000000, pio_size=0x10000000,
7012047Schristian.menard@tu-dresden.de            warn_access="Accessing SSI -- Unimplemented!")
7112047Schristian.menard@tu-dresden.de
7212047Schristian.menard@tu-dresden.de    hvuart = Uart8250(pio_addr=0xfff0c2c000)
7312047Schristian.menard@tu-dresden.de    htod = DumbTOD()
7412047Schristian.menard@tu-dresden.de
7512047Schristian.menard@tu-dresden.de    puart0 = Uart8250(pio_addr=0x1f10000000)
7612047Schristian.menard@tu-dresden.de    console = SimConsole(listener = ConsoleListener())
7712047Schristian.menard@tu-dresden.de
7812047Schristian.menard@tu-dresden.de    # Attach I/O devices to specified bus object.  Can't do this
7912047Schristian.menard@tu-dresden.de    # earlier, since the bus object itself is typically defined at the
80    # System level.
81    def attachIO(self, bus):
82        self.fake_clk.pio = bus.port
83        self.fake_membnks.pio = bus.port
84        self.fake_iob.pio = bus.port
85        self.fake_jbi.pio = bus.port
86        self.fake_l2_1.pio = bus.port
87        self.fake_l2_2.pio = bus.port
88        self.fake_l2_3.pio = bus.port
89        self.fake_l2_4.pio = bus.port
90        self.fake_l2esr_1.pio = bus.port
91        self.fake_l2esr_2.pio = bus.port
92        self.fake_l2esr_3.pio = bus.port
93        self.fake_l2esr_4.pio = bus.port
94        self.fake_ssi.pio = bus.port
95        self.puart0.pio = bus.port
96        self.hvuart.pio = bus.port
97        self.htod.pio = bus.port
98