|
|
1.1 ! root 1: /* ! 2: * Copyright (c) 1999 Apple Computer, Inc. All rights reserved. ! 3: * ! 4: * @APPLE_LICENSE_HEADER_START@ ! 5: * ! 6: * "Portions Copyright (c) 1999 Apple Computer, Inc. All Rights ! 7: * Reserved. This file contains Original Code and/or Modifications of ! 8: * Original Code as defined in and that are subject to the Apple Public ! 9: * Source License Version 1.0 (the 'License'). You may not use this file ! 10: * except in compliance with the License. Please obtain a copy of the ! 11: * License at http://www.apple.com/publicsource and read it before using ! 12: * this file. ! 13: * ! 14: * The Original Code and all software distributed under the License are ! 15: * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER ! 16: * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, ! 17: * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, ! 18: * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the ! 19: * License for the specific language governing rights and limitations ! 20: * under the License." ! 21: * ! 22: * @APPLE_LICENSE_HEADER_END@ ! 23: */ ! 24: /* ! 25: * Copyright 1997-1998 by Apple Computer, Inc., All rights reserved. ! 26: * Copyright 1994-1997 NeXT Software, Inc., All rights reserved. ! 27: * ! 28: * AtapiCntInternal.h - Definition of ATAPI controller class. ! 29: * ! 30: * ! 31: * HISTORY ! 32: * 21-Mar-1995 Rakesh Dubey at NeXT ! 33: * Created. ! 34: */ ! 35: ! 36: #import "AtapiCnt.h" ! 37: ! 38: /* ! 39: * Condition variable states for ioQueueLock. ! 40: */ ! 41: #define NO_WORK_AVAILABLE 0 ! 42: #define WORK_AVAILABLE 1 ! 43: ! 44: @interface AtapiController(Internal) ! 45: ! 46: /* ! 47: * One-time only initialization. ! 48: */ ! 49: - initResources:controller; ! 50: ! 51: /* ! 52: * Free up local resources. ! 53: */ ! 54: - free; ! 55: ! 56: ! 57: /* ! 58: * Alloc/free command buffers. ! 59: */ ! 60: - (atapiBuf_t *)allocAtapiBuf; ! 61: - (void)freeAtapiBuf:(atapiBuf_t *)atapiBuf; ! 62: ! 63: ! 64: /* ! 65: * -- Enqueue an atapiBuf_t on ioQueue<Disk,Nodisk> ! 66: * -- wake up the I/O thread ! 67: * -- wait for I/O complete (if atapiBuf->pending == NULL) ! 68: */ ! 69: - (IOReturn)enqueueAtapiBuf : (atapiBuf_t *)atapiBuf; ! 70: ! 71: /* ! 72: * Either wake up the thread which is waiting on the atapiCmdBuf, or send an ! 73: * ioComplete back to client. atapiCmdBuf->status must be valid. ! 74: */ ! 75: - (void)atapiIoComplete : (atapiBuf_t *)atapiBuf; ! 76: ! 77: /* ! 78: * Main command dispatch method. ! 79: */ ! 80: - (void)atapiCmdDispatch : (atapiBuf_t *)atapiBuf; ! 81: ! 82: /* ! 83: * Unlock ioQLock, updating condition variable as appropriate. ! 84: */ ! 85: - (void)unlockIoQLock; ! 86: ! 87: @end /* AtapiController(Internal) */ ! 88:
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.