5 Copyright © 2019, The AROS Development Team. All rights reserved.
8 Desc: scsi.device main private include file
12 #if !defined(__OOP_NOMETHODBASES__)
13 #define __OOP_NOMETHODBASES__
16 #include <exec/devices.h>
17 #include <exec/semaphores.h>
18 #include <exec/execbase.h>
19 #include <exec/libraries.h>
20 #include <exec/ports.h>
22 #include <utility/hooks.h>
23 #include <utility/utility.h>
25 #include <exec/errors.h>
26 #include <devices/trackdisk.h>
27 #include <devices/scsidisk.h>
28 #include <devices/newstyle.h>
29 #include <devices/timer.h>
30 #include <devices/cd.h>
31 #include <hardware/scsi.h>
32 #include <hidd/scsi.h>
34 #include "include/devices/scsicmds.h"
36 #define MAX_DEVICEBUSES 2
37 #define MAX_BUSUNITS 2
38 #define STACK_SIZE 16384
43 Don't blame me for information redundance here!
45 Please note, that all structures here are more or less chained together.
46 The aim is, every single function in ata.device, no matter whether it takes
47 scsi_Unit or scsi_Bus or God knows what else, would have access to ata device
48 base and through it, to all other device structures.
50 I just wanted to avoid passing scsiBase everywhere. :-D
53 /* structure forward declarations */
60 struct Device scsi_Device
; /* Exec device structure */
61 struct Task
*scsi_Daemon
; /* master task pointer */
62 struct MsgPort
*DaemonPort
; /* Daemon's message port */
63 struct MinList Daemon_ios
; /* Daemon's IORequests */
64 struct SignalSemaphore DaemonSem
;
65 struct Task
*daemonParent
; /* Who sends control requests to daemon */
66 int scsi__buscount
; /* Number of all buses */
67 struct SignalSemaphore DetectionSem
; /* Device detection semaphore */
69 /* Arguments and flags */
80 ULONG scsi_ItersPer100ns
;
82 struct Library
*scsi_OOPBase
;
83 struct Library
*scsi_UtilityBase
;
86 /* Bus HIDD classes */
91 #if defined(__OOP_NOATTRBASES__)
92 OOP_AttrBase unitAttrBase
;
93 OOP_AttrBase hwAttrBase
;
94 OOP_AttrBase busAttrBase
;
95 OOP_AttrBase sbusAttrBase
;
96 OOP_AttrBase sunitAttrBase
;
98 #if defined(__OOP_NOMETHODBASES__)
99 OOP_MethodID hwMethodBase
;
100 OOP_MethodID busMethodBase
;
101 OOP_MethodID HiddSCMethodBase
;
104 struct List scsi_Controllers
;
107 #if defined(__OOP_NOATTRBASES__)
111 #undef HiddSCSIUnitAB
112 #undef HiddStorageUnitAB
113 #define HWAttrBase (SCSIBase->hwAttrBase)
114 #define HiddBusAB (SCSIBase->busAttrBase)
115 #define HiddSCSIBusAB (SCSIBase->sbusAttrBase)
116 #define HiddSCSIUnitAB (SCSIBase->unitAttrBase)
117 #define HiddStorageUnitAB (SCSIBase->sunitAttrBase)
120 #if defined(__OOP_NOMETHODBASES__)
122 #undef HiddSCSIBusBase
123 #define HWBase (SCSIBase->hwMethodBase)
124 #define HiddSCSIBusBase (SCSIBase->busMethodBase)
125 #define HiddStorageControllerBase (SCSIBase->HiddSCMethodBase)
128 #define OOPBase (SCSIBase->scsi_OOPBase)
129 #define UtilityBase (SCSIBase->scsi_UtilityBase)
131 struct scsi_Controller
135 OOP_Object
*sc_Object
;
139 A single IDE bus (channel)
143 struct scsiBase
*sb_Base
; /* device self */
145 /** Bus object data **/
146 struct SCSI_BusInterface
*busVectors
; /* Control vector table */
147 struct SCSI_PIOInterface
*pioVectors
; /* PIO vector table */
148 APTR
*dmaVectors
; /* DMA vector table */
149 ULONG pioDataSize
; /* PIO interface data size */
150 ULONG dmaDataSize
; /* DMA interface data size */
151 void *pioInterface
; /* PIO interface object */
152 void *dmaInterface
; /* DMA interface object */
153 BOOL keepEmpty
; /* Whether we should keep empty bus object */
156 volatile UBYTE sb_Dev
[MAX_BUSUNITS
]; /* Master/Slave type, see below */
157 UBYTE sb_Flags
; /* Bus flags similar to unit flags */
158 BYTE sb_SleepySignal
; /* Signal used to wake the task up, when it's waiting */
160 /** Data Requests/DMA **/
161 UBYTE sb_BusNum
; /* bus id - used to calculate device id */
163 OOP_Object
*sb_Units
[MAX_BUSUNITS
]; /* Units on the bus */
164 struct scsi_Unit
*sb_SelectedUnit
; /* Currently selected unit */
168 struct Task
*sb_Task
; /* Bus task handling all not-immediate transactions */
169 struct MsgPort
*sb_MsgPort
; /* Task's message port */
170 struct IORequest
*sb_Timer
; /* timer stuff */
172 struct Interrupt sb_ResetInt
;
174 APTR sb_BounceBufferPool
;
176 /** functions go here **/
177 void (*sb_HandleIRQ
)(struct scsi_Unit
* unit
, UBYTE status
);
181 #define DEV_NONE 0x00
182 #define DEV_UNKNOWN 0x01
184 #define DEV_SATA 0x03
185 #define DEV_ATAPI 0x80
186 #define DEV_SATAPI 0x81
189 DriveIdent structure as returned by ATA_IDENTIFY_[DEVICE|ATAPI]
192 UWORD id_General
; // 0
193 UWORD id_OldCylinders
; // 1
194 UWORD id_SpecificConfig
; // 2
195 UWORD id_OldHeads
; // 3
196 UWORD pad1
[2]; // 4-5
197 UWORD id_OldSectors
; // 6
198 UWORD pad2
[3]; // 7-9
199 UBYTE id_SerialNumber
[20]; // 10-19
201 ULONG id_BufSize
; // 21-22
202 UBYTE id_FirmwareRev
[8]; // 23-26
203 UBYTE id_Model
[40]; // 27-46
204 UWORD id_RWMultipleSize
; // 47
209 UWORD id_Capabilities
; // 49
210 UWORD id_OldCaps
; // 50
211 UWORD id_OldPIO
; // 51
212 UWORD id_OldDMA
; // 52
213 UWORD id_ConfigAvailable
; // 53
214 UWORD id_OldLCylinders
; // 54
215 UWORD id_OldLHeads
; // 55
216 UWORD id_OldLSectors
; // 56
217 UWORD pad6
[2]; // 57-58
218 UWORD id_RWMultipleTrans
; // 59
219 ULONG id_LBASectors
; // 60-61
220 UWORD id_DMADir
; // 62
221 UWORD id_MWDMASupport
; // 63
222 UWORD id_PIOSupport
; // 64
223 UWORD id_MWDMA_MinCycleTime
; // 65
224 UWORD id_MWDMA_DefCycleTime
; // 66
225 UWORD id_PIO_MinCycleTime
; // 67
226 UWORD id_PIO_MinCycleTimeIORDY
; // 68
227 UWORD pad8
[6]; // 69-74
228 UWORD id_QueueDepth
; // 75
229 UWORD pad9
[4]; // 76-79
230 UWORD id_SCSIVersion
; // 80
231 UWORD id_SCSIRevision
; // 81
232 UWORD id_Commands1
; // 82
233 UWORD id_Commands2
; // 83
234 UWORD id_Commands3
; // 84
235 UWORD id_Commands4
; // 85
236 UWORD id_Commands5
; // 86
237 UWORD id_Commands6
; // 87
238 UWORD id_UDMASupport
; // 88
239 UWORD id_SecurityEraseTime
; // 89
240 UWORD id_ESecurityEraseTime
; // 90
241 UWORD id_CurrentAdvPowerMode
; // 91
242 UWORD id_MasterPwdRevision
; // 92
243 UWORD id_HWResetResult
; // 93
244 UWORD id_AcousticManagement
; // 94
245 UWORD id_StreamMinimunReqSize
;// 95
246 UWORD id_StreamingTimeDMA
; // 96
247 UWORD id_StreamingLatency
; // 97
248 ULONG id_StreamingGranularity
; // 98-99
249 UQUAD id_LBA48Sectors
; // 100-103
250 UWORD id_StreamingTimePIO
; // 104
252 UWORD id_PhysSectorSize
; // 106
254 UQUAD id_UniqueIDi
[2]; // 108-115
256 ULONG id_WordsPerLogicalSector
; // 117-118
257 UWORD pad13
[8]; // 119-126
258 UWORD id_RemMediaStatusNotificationFeatures
; // 127
259 UWORD id_SecurityStatus
; // 128
260 UWORD pad14
[40]; // 129 - 168
261 UWORD id_DSManagement
; // 169
262 UWORD pad15
[86]; // 170 - 256
263 } __attribute__((packed
));
267 UBYTE command
; // current SCSI command
268 UBYTE feature
; // FF to indicate no feature
269 UBYTE secmul
; // for read multiple - multiplier. default 1
301 Unit structure describing given device on the bus. It contains all the
302 necessary information unit/device may need.
306 struct Unit su_Unit
; /* exec's unit */
307 struct DriveIdent
*su_Drive
; /* Drive Ident after IDENTIFY command */
308 struct scsi_Bus
*su_Bus
; /* Bus on which this unit is */
309 struct IOStdReq
*DaemonReq
; /* Disk change monitoring request */
311 ULONG su_XferModes
; /* available transfer modes */
312 ULONG su_UseModes
; /* Used transfer modes */
314 ULONG su_Capacity
; /* Highest sector accessible through LBA28 */
315 UQUAD su_Capacity48
; /* Highest sector accessible through LBA48 */
320 UBYTE su_FirmwareRev
[9];
321 UBYTE su_SerialNumber
[21];
324 Here are stored pointers to functions responsible for handling this
325 device. They are set during device initialization and point to most
326 effective functions for this particular unit. Read/Write may be done
327 in PIO mode reading single sectors, using multisector PIO, or
330 BYTE (*su_Read32
)(struct scsi_Unit
*, ULONG
, ULONG
, APTR
, ULONG
*);
331 BYTE (*su_Write32
)(struct scsi_Unit
*, ULONG
, ULONG
, APTR
, ULONG
*);
332 BYTE (*su_Read64
)(struct scsi_Unit
*, UQUAD
, ULONG
, APTR
, ULONG
*);
333 BYTE (*su_Write64
)(struct scsi_Unit
*, UQUAD
, ULONG
, APTR
, ULONG
*);
334 BYTE (*su_Eject
)(struct scsi_Unit
*);
335 BYTE (*su_DirectSCSI
)(struct scsi_Unit
*, struct SCSICmd
*);
336 BYTE (*su_Identify
)(struct scsi_Unit
*);
337 VOID (*su_ins
)(APTR
, APTR
, ULONG
);
338 VOID (*su_outs
)(APTR
, APTR
, ULONG
);
339 void *pioInterface
; /* PIO interface object, cached for performance */
341 ULONG su_UnitNum
; /* Unit number as coded by device */
342 ULONG su_Flags
; /* Unit flags, see below */
343 ULONG su_ChangeNum
; /* Number of disc changes */
345 struct Interrupt
*su_RemoveInt
; /* Raise this interrupt on a disc change */
346 struct List su_SoftList
; /* Raise even more interrupts from this list on disc change */
348 UBYTE su_SectorShift
; /* Sector shift. 9 here is 512 bytes sector */
349 UBYTE su_DevMask
; /* device mask used to simplify device number coding */
350 UBYTE su_SenseKey
; /* Sense key from ATAPI devices */
353 /******* PIO IO ********/
360 #define AF_XFER_DMA_MASK (AF_XFER_MDMA(0)|AF_XFER_MDMA(1)|AF_XFER_MDMA(2)| \
361 AF_XFER_UDMA(0)|AF_XFER_UDMA(1)|AF_XFER_UDMA(2)|AF_XFER_UDMA(3)| \
362 AF_XFER_UDMA(4)|AF_XFER_UDMA(5)|AF_XFER_UDMA(6))
364 /* Unit internal flags */
365 #define AB_DiscPresent 30 /* disc now in drive */
366 #define AB_DiscChanged 29 /* disc changed */
367 #define AB_Removable 28 /* media removable */
368 #define AB_DMA 27 /* DMA is in use */
369 #define AB_CHSOnly 26 /* only supports CHS commands */
371 #define AF_DiscPresent (1 << AB_DiscPresent)
372 #define AF_DiscChanged (1 << AB_DiscChanged)
373 #define AF_Removable (1 << AB_Removable)
374 #define AF_DMA (1 << AB_DMA)
375 #define AF_CHSOnly (1 << AB_CHSOnly)
377 #define Unit(io) ((struct scsi_Unit *)(io)->io_Unit)
378 #define IOStdReq(io) ((struct IOStdReq *)io)
380 /* Function prototypes */
382 BOOL
Hidd_SCSIBus_Start(OOP_Object
*o
, struct scsiBase
*SCSIBase
);
383 AROS_UFP3(BOOL
, Hidd_SCSIBus_Open
,
384 AROS_UFPA(struct Hook
*, h
, A0
),
385 AROS_UFPA(OOP_Object
*, obj
, A2
),
386 AROS_UFPA(IPTR
, reqUnit
, A1
));
388 void scsi_InitBus(struct scsi_Bus
*);
389 int atapi_TestUnitOK(struct scsi_Unit
*);
390 BOOL
scsi_setup_unit(struct scsi_Bus
*bus
, struct scsi_Unit
*unit
);
391 void scsi_init_unit(struct scsi_Bus
*bus
, struct scsi_Unit
*unit
, UBYTE u
);
393 BOOL
scsi_RegisterVolume(ULONG StartCyl
, ULONG EndCyl
, struct scsi_Unit
*unit
);
394 void BusTaskCode(struct scsi_Bus
*bus
, struct scsiBase
*SCSIBase
);
395 void DaemonCode(struct scsiBase
*LIBBASE
);
397 #define ATAPI_SS_EJECT 0x02
398 #define ATAPI_SS_LOAD 0x03
400 struct atapi_StartStop