malta_io.cc

来自「M5,一个功能强大的多处理器系统模拟器.很多针对处理器架构,性能的研究都使用它作」· CC 代码 · 共 694 行 · 第 1/2 页

CC
694
字号
            DPRINTF(Malta, "Timer set to curTick + %d\n",                    count * event.interval);            event.schedule(curTick + count * event.interval);        }        write_byte = LSB;        break;    }    */}voidMaltaIO::PITimer::Counter::setRW(int rw_val){                panic("MaltoIO::PITimer::Counter::setRW(...) not implemented inside malta_io.cc");                /*    if (rw_val != PIT_RW_16BIT)        panic("Only LSB/MSB read/write is implemented.\n");    */}voidMaltaIO::PITimer::Counter::setMode(int mode_val){                panic("MaltoIO::PITimer::Counter::setMode(...) not implemented inside malta_io.cc");                /*    if(mode_val != PIT_MODE_INTTC && mode_val != PIT_MODE_RATEGEN &&       mode_val != PIT_MODE_SQWAVE)        panic("PIT mode %#x is not implemented: \n", mode_val);    mode = mode_val;        */}voidMaltaIO::PITimer::Counter::setBCD(int bcd_val){                panic("MaltoIO::PITimer::Counter::setBCD(...) not implemented inside malta_io.cc");                /*    if (bcd_val != PIT_BCD_FALSE)        panic("PITimer does not implement BCD counts.\n");    */}boolMaltaIO::PITimer::Counter::outputHigh(){                panic("MaltoIO::PITimer::Counter::outputHigh(...) not implemented inside malta_io.cc");                return false;                /*    return output_high;    */}voidMaltaIO::PITimer::Counter::serialize(const string &base, ostream &os){    paramOut(os, base + ".count", count);    paramOut(os, base + ".latched_count", latched_count);    paramOut(os, base + ".period", period);    paramOut(os, base + ".mode", mode);    paramOut(os, base + ".output_high", output_high);    paramOut(os, base + ".latch_on", latch_on);    paramOut(os, base + ".read_byte", read_byte);    paramOut(os, base + ".write_byte", write_byte);    Tick event_tick = 0;    if (event.scheduled())        event_tick = event.when();    paramOut(os, base + ".event_tick", event_tick);}voidMaltaIO::PITimer::Counter::unserialize(const string &base, Checkpoint *cp,                                         const string &section){    paramIn(cp, section, base + ".count", count);    paramIn(cp, section, base + ".latched_count", latched_count);    paramIn(cp, section, base + ".period", period);    paramIn(cp, section, base + ".mode", mode);    paramIn(cp, section, base + ".output_high", output_high);    paramIn(cp, section, base + ".latch_on", latch_on);    paramIn(cp, section, base + ".read_byte", read_byte);    paramIn(cp, section, base + ".write_byte", write_byte);    Tick event_tick;    paramIn(cp, section, base + ".event_tick", event_tick);    if (event_tick)        event.schedule(event_tick);}MaltaIO::PITimer::Counter::CounterEvent::CounterEvent(Counter* c_ptr)    : Event(&mainEventQueue){    interval = (Tick)(Clock::Float::s / 1193180.0);    counter = c_ptr;}voidMaltaIO::PITimer::Counter::CounterEvent::process(){                panic("MaltaIO::PITimer::Counter::CounterEvent::process(...) not implemented inside malta_io.cc");                /*    DPRINTF(Malta, "Timer Interrupt\n");    switch (counter->mode) {      case PIT_MODE_INTTC:        counter->output_high = true;      case PIT_MODE_RATEGEN:      case PIT_MODE_SQWAVE:        break;      default:        panic("Unimplemented PITimer mode.\n");    }    */}const char *MaltaIO::PITimer::Counter::CounterEvent::description() const{    return "malta 8254 Interval timer";}MaltaIO::MaltaIO(Params *p)    : BasicPioDevice(p), malta(p->malta), pitimer(p->name + "pitimer"),      rtc(p->name + ".rtc", p->malta, p->frequency){    pioSize = 0x100;    // set the back pointer from malta to myself    malta->io = this;    timerData = 0;    picr = 0;    picInterrupting = false;}TickMaltaIO::frequency() const{    return Clock::Frequency / params()->frequency;}TickMaltaIO::read(PacketPtr pkt){                panic("MaltaIO::read(...) not implemented inside malta_io.cc");                return pioDelay;                /*    assert(pkt->result == Packet::Unknown);    assert(pkt->getAddr() >= pioAddr && pkt->getAddr() < pioAddr + pioSize);    Addr daddr = pkt->getAddr() - pioAddr;    DPRINTF(Malta, "io read  va=%#x size=%d IOPorrt=%#x\n", pkt->getAddr(),            pkt->getSize(), daddr);    pkt->allocate();    if (pkt->getSize() == sizeof(uint8_t)) {        switch(daddr) {          // PIC1 mask read          case TSDEV_PIC1_MASK:            pkt->set(~mask1);            break;          case TSDEV_PIC2_MASK:            pkt->set(~mask2);            break;          case TSDEV_PIC1_ISR:              // !!! If this is modified 64bit case needs to be too              // Pal code has to do a 64 bit physical read because there is              // no load physical byte instruction              pkt->set(picr);              break;          case TSDEV_PIC2_ISR:              // PIC2 not implemnted... just return 0              pkt->set(0x00);              break;          case TSDEV_TMR0_DATA:            pkt->set(pitimer.counter0.read());            break;          case TSDEV_TMR1_DATA:            pkt->set(pitimer.counter1.read());            break;          case TSDEV_TMR2_DATA:            pkt->set(pitimer.counter2.read());            break;          case TSDEV_RTC_DATA:            pkt->set(rtc.readData());            break;          case TSDEV_CTRL_PORTB:            if (pitimer.counter2.outputHigh())                pkt->set(PORTB_SPKR_HIGH);            else                pkt->set(0x00);            break;          default:            panic("I/O Read - va%#x size %d\n", pkt->getAddr(), pkt->getSize());        }    } else if (pkt->getSize() == sizeof(uint64_t)) {        if (daddr == TSDEV_PIC1_ISR)            pkt->set<uint64_t>(picr);        else           panic("I/O Read - invalid addr - va %#x size %d\n",                   pkt->getAddr(), pkt->getSize());    } else {       panic("I/O Read - invalid size - va %#x size %d\n", pkt->getAddr(), pkt->getSize());    }    pkt->result = Packet::Success;    return pioDelay;    */}TickMaltaIO::write(PacketPtr pkt){                panic("MaltaIO::write(...) not implemented inside malta_io.cc");                return pioDelay;                /*    assert(pkt->result == Packet::Unknown);    assert(pkt->getAddr() >= pioAddr && pkt->getAddr() < pioAddr + pioSize);    Addr daddr = pkt->getAddr() - pioAddr;    DPRINTF(Malta, "io write - va=%#x size=%d IOPort=%#x Data=%#x\n",            pkt->getAddr(), pkt->getSize(), pkt->getAddr() & 0xfff, (uint32_t)pkt->get<uint8_t>());    assert(pkt->getSize() == sizeof(uint8_t));    warn ("GOT HERE daddr=0x%x\n", daddr);    switch(daddr) {      case TSDEV_PIC1_MASK:        mask1 = ~(pkt->get<uint8_t>());        if ((picr & mask1) && !picInterrupting) {            picInterrupting = true;            malta->cchip->postDRIR(55);            DPRINTF(Malta, "posting pic interrupt to cchip\n");        }        if ((!(picr & mask1)) && picInterrupting) {            picInterrupting = false;            malta->cchip->clearDRIR(55);            DPRINTF(Malta, "clearing pic interrupt\n");        }        break;      case TSDEV_PIC2_MASK:        mask2 = pkt->get<uint8_t>();        //PIC2 Not implemented to interrupt        break;      case TSDEV_PIC1_ACK:        // clear the interrupt on the PIC        picr &= ~(1 << (pkt->get<uint8_t>() & 0xF));        if (!(picr & mask1))            malta->cchip->clearDRIR(55);        break;      case TSDEV_DMA1_MODE:        mode1 = pkt->get<uint8_t>();        break;      case TSDEV_DMA2_MODE:        mode2 = pkt->get<uint8_t>();        break;      case TSDEV_TMR0_DATA:        pitimer.counter0.write(pkt->get<uint8_t>());        break;      case TSDEV_TMR1_DATA:        pitimer.counter1.write(pkt->get<uint8_t>());        break;      case TSDEV_TMR2_DATA:        pitimer.counter2.write(pkt->get<uint8_t>());        break;      case TSDEV_TMR_CTRL:        pitimer.writeControl(pkt->get<uint8_t>());        break;      case TSDEV_RTC_ADDR:        rtc.writeAddr(pkt->get<uint8_t>());        break;      case TSDEV_RTC_DATA:        rtc.writeData(pkt->get<uint8_t>());        break;      case TSDEV_KBD:      case TSDEV_DMA1_CMND:      case TSDEV_DMA2_CMND:      case TSDEV_DMA1_MMASK:      case TSDEV_DMA2_MMASK:      case TSDEV_PIC2_ACK:      case TSDEV_DMA1_RESET:      case TSDEV_DMA2_RESET:      case TSDEV_DMA1_MASK:      case TSDEV_DMA2_MASK:      case TSDEV_CTRL_PORTB:        break;      default:        panic("I/O Write - va%#x size %d data %#x\n", pkt->getAddr(), pkt->getSize(), pkt->get<uint8_t>());    }    pkt->result = Packet::Success;    return pioDelay;    */}voidMaltaIO::postIntr(uint8_t interrupt){    malta->cchip->postIntr(interrupt);    DPRINTF(Malta, "posting pic interrupt to cchip\n");}voidMaltaIO::clearIntr(uint8_t interrupt){    malta->cchip->clearIntr(interrupt);    DPRINTF(Malta, "posting pic interrupt to cchip\n");}voidMaltaIO::serialize(ostream &os){    SERIALIZE_SCALAR(timerData);    SERIALIZE_SCALAR(mask1);    SERIALIZE_SCALAR(mask2);    SERIALIZE_SCALAR(mode1);    SERIALIZE_SCALAR(mode2);    SERIALIZE_SCALAR(picr);    SERIALIZE_SCALAR(picInterrupting);    // Serialize the timers    pitimer.serialize("pitimer", os);    rtc.serialize("rtc", os);}voidMaltaIO::unserialize(Checkpoint *cp, const string &section){    UNSERIALIZE_SCALAR(timerData);    UNSERIALIZE_SCALAR(mask1);    UNSERIALIZE_SCALAR(mask2);    UNSERIALIZE_SCALAR(mode1);    UNSERIALIZE_SCALAR(mode2);    UNSERIALIZE_SCALAR(picr);    UNSERIALIZE_SCALAR(picInterrupting);    // Unserialize the timers    pitimer.unserialize("pitimer", cp, section);    rtc.unserialize("rtc", cp, section);}MaltaIO *MaltaIOParams::create(){    return new MaltaIO(this);}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?