#include "arch/mips/utility.hh"
  
  class ThreadContext;
- class FunctionalPort;
  
  namespace MipsISA {
 -    inline Addr PteAddr(Addr a) { return (a & PteMask) << PteShift; }
 -
 -    // User Virtual
 -    inline bool IsUSeg(Addr a) { return USegBase <= a && a <= USegEnd; }
 -
 -    inline bool IsKSeg0(Addr a) { return KSeg0Base <= a && a <= KSeg0End; }
 -
 -    inline Addr KSeg02Phys(Addr addr) { return addr & KSeg0Mask; }
 -
 -    inline Addr KSeg12Phys(Addr addr) { return addr & KSeg1Mask; }
 -
 -    inline bool IsKSeg1(Addr a) { return KSeg1Base <= a && a <= KSeg1End; }
 -
 -    inline bool IsKSSeg(Addr a) { return KSSegBase <= a && a <= KSSegEnd; }
 -
 -    inline bool IsKSeg3(Addr a) { return KSeg3Base <= a && a <= KSeg3End; }
 -
 -
      Addr vtophys(Addr vaddr);
      Addr vtophys(ThreadContext *tc, Addr vaddr);
  
 
  #define __SOLARIS_HH__
  
  #include "base/types.hh"
 -#include "config/full_system.hh"
 -
 -#if FULL_SYSTEM
 -
 -class Solaris {};
 -
 -#else //!FULL_SYSTEM
 -
  #include "kern/operatingsystem.hh"
  
- class TranslatingPort;
- 
  ///
  /// This class encapsulates the types, structures, constants,
  /// functions, and syscall-number mappings specific to the Solaris
 
  system.physmem.port = system.membus.port
  cpu.connectAllPorts(system.membus)
  
 -root = Root(system = system)
+ # Connect the system port for loading of binaries etc
+ system.system_port = system.membus.port
+ 
 +root = Root(full_system = False, system = system)
 
  # Tie the cpu cache ports to the ruby cpu ports and
  # physmem, respectively
  #
 -cpu.icache_port = system.ruby._cpu_ruby_ports[0].port
 -cpu.dcache_port = system.ruby._cpu_ruby_ports[0].port
 +cpu.connectAllPorts(system.ruby._cpu_ruby_ports[0])
  
- # Connect the system port for loading of binaries etc
- system.system_port = system.ruby._sys_port_proxy.port
- 
  # -----------------------
  # run simulation
  # -----------------------