OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [linux/] [linux-2.4/] [drivers/] [s390/] [char/] [tape34xx.h] - Blame information for rev 1765

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 1275 phoenix
 
2
/***************************************************************************
3
 *
4
 *  drivers/s390/char/tape34xx.h
5
 *    common tape device discipline for 34xx tapes.
6
 *
7
 *  S390 and zSeries version
8
 *    Copyright (C) 2001 IBM Corporation
9
 *    Author(s): Carsten Otte <cotte@de.ibm.com>
10
 *               Tuan Ngo-Anh <ngoanh@de.ibm.com>
11
 *
12
 ****************************************************************************
13
 */
14
 
15
#ifndef _TAPE34XX_H
16
 
17
#define _TAPE34XX_H
18
 
19
/*
20
 * The CCW commands for the Tape type of command.
21
 */
22
 
23
#define         INVALID_00              0x00    /* Invalid cmd      */
24
#define         BACKSPACEBLOCK          0x27    /* Back Space block */
25
#define         BACKSPACEFILE           0x2f    /* Back Space file */
26
#define         DATA_SEC_ERASE          0x97    /* Data security erase */
27
#define         ERASE_GAP               0x17    /* Erase Gap */
28
#define         FORSPACEBLOCK           0x37    /* Forward space block */
29
#define         FORSPACEFILE            0x3F    /* Forward Space file */
30
#define         FORCE_STREAM_CNT        0xEB    /* Forced streaming count #   */
31
#define         NOP                     0x03    /* No operation  */
32
#define         READ_FORWARD            0x02    /* Read forward */
33
#define         REWIND                  0x07    /* Rewind */
34
#define         REWIND_UNLOAD           0x0F    /* Rewind and Unload */
35
#define         SENSE                   0x04    /* Sense */
36
#define         NEW_MODE_SET            0xEB    /* Guess it is Mode set */
37
#define         WRITE_CMD               0x01    /* Write */
38
#define         WRITETAPEMARK           0x1F    /* Write Tape Mark */
39
 
40
#define         ASSIGN                  0xB7    /* 3420 REJECT,3480 OK  */
41
#define         CONTROL_ACCESS          0xE3    /* Set high speed */
42
#define         DIAG_MODE_SET           0x0B    /* 3420 NOP, 3480 REJECT*/
43
#define         LOAD_DISPLAY            0x9F    /* 3420 REJECT,3480 OK  */
44
#define         LOCATE                  0x4F    /* 3420 REJ, 3480 NOP   */
45
#define         LOOP_WRITE_TO_READ      0x8B    /* 3480 REJECT        */
46
#define         MODE_SET_DB             0xDB    /* 3420 REJECT,3480 OK  */
47
#define         MODE_SET_C3             0xC3    /* for 3420                */
48
#define         MODE_SET_CB             0xCB    /* for 3420                */
49
#define         MODE_SET_D3             0xD3    /* for 3420                */
50
#define         READ_BACKWARD           0x0C    /*                      */
51
#define         READ_BLOCK_ID           0x22    /* 3420 REJECT,3480 OK  */
52
#define         READ_BUFFER             0x12    /* 3420 REJECT,3480 OK  */
53
#define         READ_BUFF_LOG           0x24    /* 3420 REJECT,3480 OK  */
54
#define         RELEASE                 0xD4    /* 3420 NOP, 3480 REJECT*/
55
#define         REQ_TRK_IN_ERROR        0x1B    /* 3420 NOP, 3480 REJECT*/
56
#define         RESERVE                 0xF4    /* 3420 NOP, 3480 REJECT*/
57
#define         SENSE_GROUP_ID          0x34    /* 3420 REJECT,3480 OK  */
58
#define         SENSE_ID                0xE4    /* 3420 REJECT,3480 OK */
59
#define         READ_DEV_CHAR           0x64    /* Read device characteristics */
60
#define         SET_DIAGNOSE            0x4B    /* 3420 NOP, 3480 REJECT*/
61
#define         SET_GROUP_ID            0xAF    /* 3420 REJECT,3480 OK  */
62
#define         SET_TAPE_WRITE_IMMED    0xC3    /* for 3480                */
63
#define         SUSPEND                 0x5B    /* 3420 REJ, 3480 NOP   */
64
#define         SYNC                    0x43    /* Synchronize (flush buffer) */
65
#define         UNASSIGN                0xC7    /* 3420 REJECT,3480 OK  */
66
#define         PERF_SUBSYS_FUNC        0x77    /* 3490 CMD */
67
#define         READ_CONFIG_DATA        0xFA    /* 3490 CMD */
68
#define         READ_MESSAGE_ID         0x4E    /* 3490 CMD */
69
#define         READ_SUBSYS_DATA        0x3E    /* 3490 CMD */
70
#define         SET_INTERFACE_ID        0x73    /* 3490 CMD */
71
 
72
#ifndef MIN
73
#define MIN(a,b)                ( (a) < (b) ? (a) : (b) )
74
#endif
75
 
76
 
77
#define BLOCKSIZE               4096            /* size of the tape rcds */
78
 
79
#define COMMAND_CHAIN    CCW_FLAG_CC      /* redefine from irq.h */
80
#define CHANNEL_END      DEV_STAT_CHN_END /* redefine from irq.h */
81
#define DEVICE_END       DEV_STAT_DEV_END /* redefine from irq.h */
82
#define UNIT_CHECK       DEV_STAT_UNIT_CHECK  /* redefine from irq.h */
83
#define UNIT_EXCEPTION   DEV_STAT_UNIT_EXCEP  /* redefine from irq.h */
84
#define CONTROL_UNIT_END DEV_STAT_CU_END      /* redefine from irq.h */
85
#define INCORR_LEN       SCHN_STAT_INCORR_LEN /* redefine from irq.h */
86
 
87
#define SENSE_COMMAND_REJECT        0x80
88
#define SENSE_INTERVENTION_REQUIRED 0x40
89
#define SENSE_BUS_OUT_CHECK         0x20
90
#define SENSE_EQUIPMENT_CHECK       0x10
91
#define SENSE_DATA_CHECK            0x08
92
#define SENSE_OVERRUN               0x04
93
#define SENSE_DEFERRED_UNIT_CHECK   0x02
94
#define SENSE_ASSIGNED_ELSEWHERE    0x01
95
 
96
#define SENSE_LOCATE_FAILURE        0x80
97
#define SENSE_DRIVE_ONLINE          0x40
98
#define SENSE_RESERVED              0x20
99
#define SENSE_RECORD_SEQUENCE_ERR   0x10
100
#define SENSE_BEGINNING_OF_TAPE     0x08
101
#define SENSE_WRITE_MODE            0x04
102
#define SENSE_WRITE_PROTECT         0x02
103
#define SENSE_NOT_CAPABLE           0x01
104
 
105
#define SENSE_CHANNEL_ADAPTER_CODE  0xE0
106
#define SENSE_CHANNEL_ADAPTER_LOC   0x10
107
#define SENSE_REPORTING_CU          0x08
108
#define SENSE_AUTOMATIC_LOADER      0x04
109
#define SENSE_TAPE_SYNC_MODE        0x02
110
#define SENSE_TAPE_POSITIONING      0x01
111
 
112
typedef struct _tape34xx_disc_data_t {
113
    __u8 modeset_byte;
114
} tape34xx_disc_data_t  __attribute__ ((packed, aligned(8)));
115
 
116
/* discipline functions */
117
int tape34xx_ioctl_overload (struct inode *inode, struct file *filp, unsigned int cmd, unsigned long arg);
118
ccw_req_t * tape34xx_write_block (const char *data, size_t count, tape_info_t * ti);
119
void tape34xx_free_write_block (ccw_req_t * cqr, tape_info_t * ti);
120
ccw_req_t * tape34xx_read_block (const char *data, size_t count, tape_info_t * ti);
121
void  tape34xx_free_read_block (ccw_req_t * cqr, tape_info_t * ti);
122
void  tape34xx_clear_read_block (ccw_req_t * cqr, tape_info_t * ti);
123
ccw_req_t * tape34xx_mtfsf (tape_info_t * ti, int count);
124
ccw_req_t * tape34xx_mtbsf (tape_info_t * ti, int count);
125
ccw_req_t * tape34xx_mtfsr (tape_info_t * ti, int count);
126
ccw_req_t * tape34xx_mtbsr (tape_info_t * ti, int count);
127
ccw_req_t * tape34xx_mtweof (tape_info_t * ti, int count);
128
ccw_req_t * tape34xx_mtrew (tape_info_t * ti, int count);
129
ccw_req_t * tape34xx_mtoffl (tape_info_t * ti, int count);
130
ccw_req_t * tape34xx_mtnop (tape_info_t * ti, int count);
131
ccw_req_t * tape34xx_mtbsfm (tape_info_t * ti, int count);
132
ccw_req_t * tape34xx_mtfsfm (tape_info_t * ti, int count);
133
ccw_req_t * tape34xx_mteom (tape_info_t * ti, int count);
134
ccw_req_t * tape34xx_mterase (tape_info_t * ti, int count);
135
ccw_req_t * tape34xx_mtsetdensity (tape_info_t * ti, int count);
136
ccw_req_t * tape34xx_mtseek (tape_info_t * ti, int count);
137
ccw_req_t * tape34xx_mttell (tape_info_t * ti, int count);
138
ccw_req_t * tape34xx_mtsetdrvbuffer (tape_info_t * ti, int count);
139
ccw_req_t * tape34xx_mtlock (tape_info_t * ti, int count);
140
ccw_req_t * tape34xx_mtunlock (tape_info_t * ti, int count);
141
ccw_req_t * tape34xx_mtload (tape_info_t * ti, int count);
142
ccw_req_t * tape34xx_mtunload (tape_info_t * ti, int count);
143
ccw_req_t * tape34xx_mtcompression (tape_info_t * ti, int count);
144
ccw_req_t * tape34xx_mtsetpart (tape_info_t * ti, int count);
145
ccw_req_t * tape34xx_mtmkpart (tape_info_t * ti, int count);
146
ccw_req_t * tape34xx_mtiocget (tape_info_t * ti, int count);
147
ccw_req_t * tape34xx_mtiocpos (tape_info_t * ti, int count);
148
ccw_req_t * tape34xx_bread (struct request *req, tape_info_t* ti,int tapeblock_major);
149
ccw_req_t * tape34xx_bwrite (struct request *req, tape_info_t* ti,int tapeblock_major);
150
void tape34xx_free_bread (ccw_req_t*,struct _tape_info_t*);
151
void tape34xx_free_bwrite (ccw_req_t*,struct _tape_info_t*);
152
 
153
/* Event handlers */
154
void tape34xx_default_handler (tape_info_t * ti);
155
void tape34xx_unexpect_uchk_handler (tape_info_t * ti);
156
void tape34xx_unused_done(tape_info_t* ti);
157
void tape34xx_idle_done(tape_info_t* ti);
158
void tape34xx_block_done(tape_info_t* ti);
159
void tape34xx_bsf_init_done(tape_info_t* ti);
160
void tape34xx_dse_init_done(tape_info_t* ti);
161
void tape34xx_fsf_init_done(tape_info_t* ti);
162
void tape34xx_bsb_init_done(tape_info_t* ti);
163
void tape34xx_fsb_init_done(tape_info_t* ti);
164
void tape34xx_lbl_init_done(tape_info_t* ti);
165
void tape34xx_nop_init_done(tape_info_t* ti);
166
void tape34xx_rfo_init_done(tape_info_t* ti);
167
void tape34xx_rbi_init_done(tape_info_t* ti);
168
void tape34xx_rew_init_done(tape_info_t* ti);
169
void tape34xx_rew_release_init_done(tape_info_t* ti);
170
void tape34xx_run_init_done(tape_info_t* ti);
171
void tape34xx_wri_init_done(tape_info_t* ti);
172
void tape34xx_wtm_init_done(tape_info_t* ti);
173
 
174
extern void schedule_tapeblock_exec_IO (tape_info_t *ti);
175
 
176
// the error recovery stuff:
177
void tape34xx_error_recovery (tape_info_t* ti);
178
void tape34xx_error_recovery_has_failed (tape_info_t* ti,int error_id);
179
void tape34xx_error_recovery_succeded(tape_info_t* ti);
180
void tape34xx_error_recovery_do_retry(tape_info_t* ti);
181
void tape34xx_error_recovery_read_opposite (tape_info_t* ti);
182
void  tape34xx_error_recovery_HWBUG (tape_info_t* ti,int condno);
183
#endif // _TAPE34XX_H

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.