/* * Copyright (c) 2008 The Regents of The University of Michigan * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are * met: redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer; * redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution; * neither the name of the copyright holders nor the names of its * contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * Authors: Gabe Black */ #include "dev/x86/i8237.hh" #include "mem/packet.hh" #include "mem/packet_access.hh" Tick X86ISA::I8237::read(PacketPtr pkt) { assert(pkt->getSize() == 1); Addr offset = pkt->getAddr() - pioAddr; switch (offset) { case 0x0: panic("Read from i8237 channel 0 current address unimplemented.\n"); case 0x1: panic("Read from i8237 channel 0 remaining " "word count unimplemented.\n"); case 0x2: panic("Read from i8237 channel 1 current address unimplemented.\n"); case 0x3: panic("Read from i8237 channel 1 remaining " "word count unimplemented.\n"); case 0x4: panic("Read from i8237 channel 2 current address unimplemented.\n"); case 0x5: panic("Read from i8237 channel 2 remaining " "word count unimplemented.\n"); case 0x6: panic("Read from i8237 channel 3 current address unimplemented.\n"); case 0x7: panic("Read from i8237 channel 3 remaining " "word count unimplemented.\n"); case 0x8: panic("Read from i8237 status register unimplemented.\n"); default: panic("Read from undefined i8237 register %d.\n", offset); } pkt->makeAtomicResponse(); return latency; } Tick X86ISA::I8237::write(PacketPtr pkt) { assert(pkt->getSize() == 1); Addr offset = pkt->getAddr() - pioAddr; switch (offset) { case 0x0: panic("Write to i8237 channel 0 starting address unimplemented.\n"); case 0x1: panic("Write to i8237 channel 0 starting " "word count unimplemented.\n"); case 0x2: panic("Write to i8237 channel 1 starting address unimplemented.\n"); case 0x3: panic("Write to i8237 channel 1 starting " "word count unimplemented.\n"); case 0x4: panic("Write to i8237 channel 2 starting address unimplemented.\n"); case 0x5: panic("Write to i8237 channel 2 starting " "word count unimplemented.\n"); case 0x6: panic("Write to i8237 channel 3 starting address unimplemented.\n"); case 0x7: panic("Write to i8237 channel 3 starting " "word count unimplemented.\n"); case 0x8: panic("Write to i8237 command register unimplemented.\n"); case 0x9: panic("Write to i8237 request register unimplemented.\n"); case 0xa: { uint8_t command = pkt->get(); uint8_t select = bits(command, 1, 0); uint8_t bitVal = bits(command, 2); if (!bitVal) panic("Turning on i8237 channels unimplemented.\n"); replaceBits(maskReg, select, bitVal); } break; case 0xb: panic("Write to i8237 mode register unimplemented.\n"); case 0xc: panic("Write to i8237 clear LSB/MSB flip-flop " "register unimplemented.\n"); case 0xd: panic("Write to i8237 master clear/reset register unimplemented.\n"); case 0xe: panic("Write to i8237 clear mask register unimplemented.\n"); case 0xf: panic("Write to i8237 write all mask register bits unimplemented.\n"); default: panic("Write to undefined i8237 register.\n"); } pkt->makeAtomicResponse(); return latency; } void X86ISA::I8237::serialize(CheckpointOut &cp) const { SERIALIZE_SCALAR(maskReg); } void X86ISA::I8237::unserialize(CheckpointIn &cp) { UNSERIALIZE_SCALAR(maskReg); } X86ISA::I8237 * I8237Params::create() { return new X86ISA::I8237(this); }