summaryrefslogtreecommitdiff
path: root/EDK/Foundation/Efi/Protocol/TapeIo/TapeIo.h
blob: 5a3159f2eafd798adc7d6ee9283113779060e69a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
/*++
  Copyright (c) 2006, Intel Corporation                                                         
  All rights reserved. This program and the accompanying materials                          
  are licensed and made available under the terms and conditions of the BSD License         
  which accompanies this distribution.  The full text of the license may be found at        
  http://opensource.org/licenses/bsd-license.php                                            

  THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,                     
  WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.             

Module Name:

    TapeIo.h
    
Abstract: 
  EFI_TAPE_IO_PROTOCOL as defined in the UEFI 2.0.
  Provide services to control and access a tape device.

Revision History

--*/

#ifndef __EFI_TAPE_IO_PROTOCOL_H__
#define __EFI_TAPE_IO_PROTOCOL_H__

#define EFI_TAPE_IO_PROTOCOL_GUID \
  { \
    0x1e93e633, 0xd65a, 0x459e, {0xab, 0x84, 0x93, 0xd9, 0xec, 0x26, 0x6d, 0x18 } \
  }

typedef struct _EFI_TAPE_IO_PROTOCOL EFI_TAPE_IO_PROTOCOL;

typedef struct {
  UINT64     Signature;
  UINT32     Revision;
  UINT32     BootDescSize;
  UINT32     BootDescCRC;
  EFI_GUID   TapeGUID;
  EFI_GUID   TapeType;
  EFI_GUID   TapeUnique;
  UINT32     BLLocation;
  UINT32     BLBlocksize;
  UINT32     BLFilesize;
  CHAR8      OSVersion[40];
  CHAR8      AppVersion[40];
  CHAR8      CreationDate[10];
  CHAR8      CreationTime[10];
  CHAR8      SystemName[256];  // UTF-8
  CHAR8      TapeTitle[120];   // UTF-8
  CHAR8      pad[468];         // pad to 1024
} TAPE_HEADER;

typedef 
EFI_STATUS
(EFIAPI *EFI_TAPE_READ) (
  IN EFI_TAPE_IO_PROTOCOL *This,
  IN OUT UINTN            *BufferSize,
  OUT VOID                *Buffer
  )
/*++

  Routine Description:
    Reads from the tape.

  Arguments:
    This       - A pointer to the EFI_TAPE_IO_PROTOCOL instance.
    BufferSize - Size of the buffer in bytes pointed to by Buffer.
    Buffer     - Pointer to the buffer for data to be read into.

  Returns:
    EFI_SUCCESS           - Data was successfully transferred from the media.
    EFI_END_OF_FILE       - A filemark was encountered which limited the data
                            transferred by the read operation or the head is positioned
                            just after a filemark.
    EFI_NO_MEDIA          - No media is loaded in the device.
    EFI_NOT_READY         - The transfer failed since the device was not ready (e.g. not
                            online). The transfer may be retried at a later time.
    EFI_UNSUPPORTED       - The device does not support this type of transfer.
    EFI_TIMEOUT           - The transfer failed to complete within the timeout specified.
    EFI_MEDIA_CHANGED     - The media in the device was changed since the last access.
                            The transfer was aborted since the current position of the
                            media may be incorrect.
    EFI_INVALID_PARAMETER - A NULL Buffer was specified with a non-zero
                            BufferSize or the device is operating in fixed block
                            size mode and the BufferSize was not a multiple of
                            device¡¯s fixed block size
    EFI_DEVICE_ERROR      - A device error occurred while attempting to transfer data
                            from the media.
    
--*/
;    

typedef 
EFI_STATUS
(EFIAPI *EFI_TAPE_WRITE) (
  IN EFI_TAPE_IO_PROTOCOL *This,
  IN UINTN                *BufferSize,
  IN VOID                 *Buffer
  )
/*++

  Routine Description:
    Writes to the tape.

  Arguments:
    This        - A pointer to the EFI_TAPE_IO_PROTOCOL instance.
    BufferSize  - Size of the buffer in bytes pointed to by Buffer.
    Buffer      - Pointer to the buffer for data to be written from.
    
  Returns:
    EFI_SUCCESS         - Data was successfully transferred to the media.
    EFI_END_OF_MEDIA    - The logical end of media has been reached. Data may have
                          been successfully transferred to the media.
    EFI_NO_MEDIA        - No media is loaded in the device.
    EFI_NOT_READY       - The transfer failed since the device was not ready (e.g. not
                          online). The transfer may be retried at a later time.
    EFI_UNSUPPORTED     - The device does not support this type of transfer.
    EFI_TIMEOUT         - The transfer failed to complete within the timeout specified.
    EFI_MEDIA_CHANGED   - The media in the device was changed since the last access.
                          The transfer was aborted since the current position of the
                          media may be incorrect.
    EFI_WRITE_PROTECTED - The media in the device is write-protected. The transfer
                          was aborted since a write cannot be completed.
    EFI_INVALID_PARAMETER - A NULL Buffer was specified with a non-zero
                          BufferSize or the device is operating in fixed block
                          size mode and the BufferSize was not a multiple of
                          device¡¯s fixed block size
    EFI_DEVICE_ERROR      A device error occurred while attempting to transfer data
                          from the media.
    
--*/
; 
  

typedef 
EFI_STATUS
(EFIAPI *EFI_TAPE_REWIND) (
  IN EFI_TAPE_IO_PROTOCOL *This
  )
/*++

  Routine Description:
    Rewinds the tape.

  Arguments:
    This - A pointer to the EFI_TAPE_IO_PROTOCOL instance.

  Returns:
    EFI_SUCCESS      - The media was successfully repositioned.
    EFI_NO_MEDIA     - No media is loaded in the device.
    EFI_NOT_READY    - Repositioning the media failed since the device was not
                       ready (e.g. not online). The transfer may be retried at a later time.
    EFI_UNSUPPORTED  - The device does not support this type of media repositioning.
    EFI_TIMEOUT      - Repositioning of the media did not complete within the timeout specified.
    EFI_DEVICE_ERROR - A device error occurred while attempting to reposition the media.

--*/
;   


typedef
EFI_STATUS
(EFIAPI *EFI_TAPE_SPACE) (
  IN EFI_TAPE_IO_PROTOCOL *This,
  INTN                    Direction,
  UINTN                   Type
  )
/*++

  Routine Description:
    Positions the tape.

  Arguments:
    This      - A pointer to the EFI_TAPE_IO_PROTOCOL instance.
    Direction - Direction and number of data blocks or filemarks to space over on media.
    Type      - Type of mark to space over on media.
    
  Returns:
    EFI_SUCCESS       - The media was successfully repositioned.
    EFI_END_OF_MEDIA  - Beginning or end of media was reached before the
                        indicated number of data blocks or filemarks were found.
    EFI_NO_MEDIA      - No media is loaded in the device.
    EFI_NOT_READY     - The reposition failed since the device was not ready (e.g. not
                        online). The reposition may be retried at a later time.
    EFI_UNSUPPORTED   - The device does not support this type of repositioning.
    EFI_TIMEOUT       - The repositioning failed to complete within the timeout specified.
    EFI_MEDIA_CHANGED - The media in the device was changed since the last access.
                        Repositioning the media was aborted since the current
                        position of the media may be incorrect.
    EFI_DEVICE_ERROR  - A device error occurred while attempting to reposition the media.
    
--*/
;   

typedef 
EFI_STATUS
(EFIAPI *EFI_TAPE_WRITEFM) (
  IN EFI_TAPE_IO_PROTOCOL *This,
  IN UINTN                Count
  )
/*++

  Routine Description:
    Writes filemarks to the media.

  Arguments:
    This    - A pointer to the EFI_TAPE_IO_PROTOCOL instance.
    Count   - Number of filemarks to write to the media.

  Returns:
    EFI_SUCCESS       - Data was successfully transferred from the media.
    EFI_NO_MEDIA      - No media is loaded in the device.
    EFI_NOT_READY     - The transfer failed since the device was not ready (e.g. not
                        online). The transfer may be retried at a later time.
    EFI_UNSUPPORTED   - The device does not support this type of repositioning.
    EFI_TIMEOUT       - The transfer failed to complete within the timeout specified.
    EFI_MEDIA_CHANGED - The media in the device was changed since the last access.
                        The transfer was aborted since the current position of the
                        media may be incorrect.
    EFI_DEVICE_ERROR  - A device error occurred while attempting to transfer data from the media.

--*/
;   

typedef 
EFI_STATUS
(EFIAPI *EFI_TAPE_RESET) (
  IN EFI_TAPE_IO_PROTOCOL *This,
  IN BOOLEAN              ExtendedVerification
  )
/*++

  Routine Description:
    Resets the tape device.

  Arguments:
    This                  - A pointer to the EFI_TAPE_IO_PROTOCOL instance.
    ExtendedVerification  - Indicates whether the parent bus should also be reset.

  Returns:
    EFI_SUCCESS       - The bus and/or device were successfully reset.
    EFI_NO_MEDIA      - No media is loaded in the device.
    EFI_NOT_READY     - The reset failed since the device and/or bus was not ready.
                        The reset may be retried at a later time.
    EFI_UNSUPPORTED   - The device does not support this type of reset.
    EFI_TIMEOUT       - The reset did not complete within the timeout allowed.
    EFI_DEVICE_ERROR  - A device error occurred while attempting to reset the bus and/or device.

--*/
;    

struct _EFI_TAPE_IO_PROTOCOL {
  EFI_TAPE_READ           TapeRead;
  EFI_TAPE_WRITE          TapeWrite;
  EFI_TAPE_REWIND         TapeRewind;
  EFI_TAPE_SPACE          TapeSpace;
  EFI_TAPE_WRITEFM        TapeWriteFM;
  EFI_TAPE_RESET          TapeReset;
};

extern EFI_GUID gEfiTapeIoProtocolGuid;

#endif