grub2: bring back build of aros-side grub2 tools
[AROS.git] / rom / usb / classes / rawwrap / dev.h
blob0e56d7bb5c09a36ddf778bafeb712db8c74b33d6
2 /* DEVICE STUFF */
4 #define DEVNAME "usbraw.device"
6 #define DEVBASETYPEPTR struct NepRawDevBase *
8 /* local protos */
10 AROS_UFP3(DEVBASETYPEPTR, devInit,
11 AROS_UFPA(DEVBASETYPEPTR, base, D0),
12 AROS_UFPA(BPTR, seglist, A0),
13 AROS_UFPA(struct ExecBase *, SysBase, A6));
15 AROS_LD3(DEVBASETYPEPTR, devOpen,
16 AROS_LDA(struct IOStdReq *, ioreq, A1),
17 AROS_LDA(ULONG, unitnum, D0),
18 AROS_LDA(ULONG, flags, D1),
19 DEVBASETYPEPTR, base, 1, dev);
21 AROS_LD1(BPTR, devClose,
22 AROS_LDA(struct IOStdReq *, ioreq, A1),
23 DEVBASETYPEPTR, base, 2, dev);
25 AROS_LD1(BPTR, devExpunge,
26 AROS_LDA(DEVBASETYPEPTR, extralh, D0),
27 DEVBASETYPEPTR, base, 3, dev);
29 AROS_LD0(DEVBASETYPEPTR, devReserved,
30 DEVBASETYPEPTR, base, 4, dev);
32 AROS_LD1(void, devBeginIO,
33 AROS_LDA(struct IOStdReq *, ioreq, A1),
34 DEVBASETYPEPTR, base, 5, dev);
36 AROS_LD1(LONG, devAbortIO,
37 AROS_LDA(struct IOStdReq *, ioreq, A1),
38 DEVBASETYPEPTR, base, 6, dev);
40 /* Device stuff */
42 /* Reply the iorequest with success
44 #define RC_OK 0
46 /* Magic cookie, don't set error fields & don't reply the ioreq
48 #define RC_DONTREPLY -1
50 struct Unit *Open_Unit(struct IOStdReq *ioreq,
51 LONG unitnr,
52 struct NepRawDevBase *base);
53 void Close_Unit(struct NepRawDevBase *base, struct NepClassRawWrap *ncp,
54 struct IOStdReq *ioreq);
56 WORD cmdNSDeviceQuery(struct IOStdReq *ioreq, struct NepClassRawWrap *ncp, struct NepRawDevBase *base);
58 void TermIO(struct IOStdReq *ioreq, struct NepRawDevBase *base);
60 struct my_NSDeviceQueryResult
62 ULONG DevQueryFormat; /* this is type 0 */
63 ULONG SizeAvailable; /* bytes available */
64 UWORD DeviceType; /* what the device does */
65 UWORD DeviceSubType; /* depends on the main type */
66 const UWORD *SupportedCommands; /* 0 terminated list of cmd's */