9,7 → 9,7 |
if not defined mac_address {$mac_address = "10:10:10:10:10:24"} |
if not defined disk_size {$disk_size = 2128486400} |
if not defined rtc_time {$rtc_time = "2002-06-02 17:00:00 UTC"} |
if not defined num_cpus {$num_cpus = 3} |
if not defined num_cpus {$num_cpus = 4} |
if not defined megs_per_cpu {$megs_per_cpu = 256} |
if not defined cpu_class {$cpu_class = "ultrasparc-iii-plus"} |
|
95,33 → 95,3 |
($scsi_cdrom.get-component-object cd).insert (new-file-cdrom $cdrom_path) |
$system.set-prom-env boot-command "boot /ssm@0,0/pci@19,700000/scsi@2/disk@6,0:f" |
$system.set-prom-env auto-boot? true |
|
@buf = 0; |
@offset = 0; |
@register2Number = SIM_get_register_number(SIM_current_processor(), "g2"); |
@register3Number = SIM_get_register_number(SIM_current_processor(), "g3"); |
|
@def schedule(): |
SIM_realtime_event(100, handler, 0, 0, ''); |
|
@def handler(x): |
global buf |
global offset |
if (SIM_simics_is_running()): |
register2Value = SIM_read_register(SIM_current_processor(), register2Number); |
if ((buf == 0) and register2Value == 0x18273645): |
buf = SIM_read_register(SIM_current_processor(), register3Number); |
SIM_write_register(SIM_current_processor(), register2Number, 0); |
SIM_flush(); |
print buf |
elif (buf != 0): |
byte = SIM_read_phys_memory(SIM_current_processor(), buf + offset, 1); |
while byte != 0: |
SIM_putchar(byte); |
SIM_flush(); |
SIM_write_phys_memory(SIM_current_processor(), buf + offset, 0, 1); |
offset = (offset + 1) % 512; |
byte = SIM_read_phys_memory(SIM_current_processor(), buf + offset, 1); |
schedule(); |
|
@schedule(); |