X-Git-Url: https://git.libre-soc.org/?a=blobdiff_plain;f=dev%2Fide_ctrl.cc;h=4805570d20bbb861545776214cb4ea56318a7e9d;hb=19fd3439c738e06be8c43078f520054011a385cc;hp=7ef5fe8e44987de1c3aecb27bc76e97b0d35c91f;hpb=e937b38e2ccf0bf75794178f29c8482d76bec9c8;p=gem5.git diff --git a/dev/ide_ctrl.cc b/dev/ide_ctrl.cc index 7ef5fe8e4..4805570d2 100644 --- a/dev/ide_ctrl.cc +++ b/dev/ide_ctrl.cc @@ -192,6 +192,22 @@ IdeController::getDisk(IdeDisk *diskPtr) return -1; } +bool +IdeController::isDiskSelected(IdeDisk *diskPtr) +{ + for (int i = 0; i < 4; i++) { + if ((long)diskPtr == (long)disks[i]) { + // is disk is on primary or secondary channel + int channel = i/2; + // is disk the master or slave + int devID = i%2; + + return (dev[channel] == devID); + } + } + panic("Unable to find disk by pointer!!\n"); +} + //// // Command completion //// @@ -656,6 +672,7 @@ IdeController::unserialize(Checkpoint *cp, const std::string §ion) UNSERIALIZE_SCALAR(io_enabled); UNSERIALIZE_SCALAR(bm_enabled); UNSERIALIZE_ARRAY(cmd_in_progress, 4); + if (pioInterface) { pioInterface->addAddrRange(pri_cmd_addr, pri_cmd_addr + pri_cmd_size - 1);