Blame view

include/scsi/scsi_transport.h 3.89 KB
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
  /* 
   *  Transport specific attributes.
   *
   *  Copyright (c) 2003 Silicon Graphics, Inc.  All rights reserved.
   *
   *  This program is free software; you can redistribute it and/or modify
   *  it under the terms of the GNU General Public License as published by
   *  the Free Software Foundation; either version 2 of the License, or
   *  (at your option) any later version.
   *
   *  This program is distributed in the hope that it will be useful,
   *  but WITHOUT ANY WARRANTY; without even the implied warranty of
   *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   *  GNU General Public License for more details.
   *
   *  You should have received a copy of the GNU General Public License
   *  along with this program; if not, write to the Free Software
   *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
   */
  #ifndef SCSI_TRANSPORT_H
  #define SCSI_TRANSPORT_H
  
  #include <linux/transport_class.h>
242f9dcb8   Jens Axboe   block: unify requ...
24
  #include <linux/blkdev.h>
c3e9dda4f   James Bottomley   [SCSI] allow the ...
25
  #include <scsi/scsi_host.h>
a9b732029   Rolf Eike Beer   [SCSI] scsi_trans...
26
  #include <scsi/scsi_device.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
27
28
29
30
31
32
  
  struct scsi_transport_template {
  	/* the attribute containers */
  	struct transport_container host_attrs;
  	struct transport_container target_attrs;
  	struct transport_container device_attrs;
5c44cd2af   James.Smart@Emulex.Com   [SCSI] fix target...
33
  	/*
e02f3f592   Christoph Hellwig   [SCSI] remove tar...
34
  	 * If set, called from sysfs and legacy procfs rescanning code.
5c44cd2af   James.Smart@Emulex.Com   [SCSI] fix target...
35
  	 */
e02f3f592   Christoph Hellwig   [SCSI] remove tar...
36
  	int (*user_scan)(struct Scsi_Host *, uint, uint, uint);
5c44cd2af   James.Smart@Emulex.Com   [SCSI] fix target...
37

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
38
39
40
41
  	/* The size of the specific transport attribute structure (a
  	 * space of this size will be left at the end of the
  	 * scsi_* structure */
  	int	device_size;
c3e9dda4f   James Bottomley   [SCSI] allow the ...
42
  	int	device_private_offset;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
43
  	int	target_size;
c3e9dda4f   James Bottomley   [SCSI] allow the ...
44
  	int	target_private_offset;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
45
  	int	host_size;
c3e9dda4f   James Bottomley   [SCSI] allow the ...
46
  	/* no private offset for the host; there's an alternative mechanism */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
47
48
49
50
51
  
  	/*
  	 * True if the transport wants to use a host-based work-queue
  	 */
  	unsigned int create_work_queue : 1;
c829c3941   James Smart   [SCSI] FC transpo...
52
53
  
  	/*
9227c33de   Christoph Hellwig   [PATCH] move ->eh...
54
55
56
57
58
  	 * Allows a transport to override the default error handler.
  	 */
  	void (* eh_strategy_handler)(struct Scsi_Host *);
  
  	/*
c829c3941   James Smart   [SCSI] FC transpo...
59
60
61
62
63
64
65
66
  	 * This is an optional routine that allows the transport to become
  	 * involved when a scsi io timer fires. The return value tells the
  	 * timer routine how to finish the io timeout handling:
  	 * EH_HANDLED:		I fixed the error, please complete the command
  	 * EH_RESET_TIMER:	I need more time, reset the timer and
  	 *			begin counting again
  	 * EH_NOT_HANDLED	Begin normal error recovery
  	 */
242f9dcb8   Jens Axboe   block: unify requ...
67
  	enum blk_eh_timer_return (*eh_timed_out)(struct scsi_cmnd *);
2c47f9efb   FUJITA Tomonori   [SCSI] tgt: add I...
68
69
70
71
72
73
  
  	/*
  	 * Used as callback for the completion of i_t_nexus request
  	 * for target drivers.
  	 */
  	int (* it_nexus_response)(struct Scsi_Host *, u64, int);
bfb743740   FUJITA Tomonori   [SCSI] tgt: move ...
74
75
76
77
78
79
  
  	/*
  	 * Used as callback for the completion of task management
  	 * request for target drivers.
  	 */
  	int (* tsk_mgmt_response)(struct Scsi_Host *, u64, u64, int);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
80
81
82
  };
  
  #define transport_class_to_shost(tc) \
ee959b00c   Tony Jones   SCSI: convert str...
83
  	dev_to_shost((tc)->parent)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
84

c3e9dda4f   James Bottomley   [SCSI] allow the ...
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
  /* Private area maintenance. The driver requested allocations come
   * directly after the transport class allocations (if any).  The idea
   * is that you *must* call these only once.  The code assumes that the
   * initial values are the ones the transport specific code requires */
  static inline void
  scsi_transport_reserve_target(struct scsi_transport_template * t, int space)
  {
  	BUG_ON(t->target_private_offset != 0);
  	t->target_private_offset = ALIGN(t->target_size, sizeof(void *));
  	t->target_size = t->target_private_offset + space;
  }
  static inline void
  scsi_transport_reserve_device(struct scsi_transport_template * t, int space)
  {
  	BUG_ON(t->device_private_offset != 0);
  	t->device_private_offset = ALIGN(t->device_size, sizeof(void *));
  	t->device_size = t->device_private_offset + space;
  }
  static inline void *
  scsi_transport_target_data(struct scsi_target *starget)
  {
  	struct Scsi_Host *shost = dev_to_shost(&starget->dev);
  	return (u8 *)starget->starget_data
  		+ shost->transportt->target_private_offset;
  
  }
  static inline void *
  scsi_transport_device_data(struct scsi_device *sdev)
  {
  	struct Scsi_Host *shost = sdev->host;
  	return (u8 *)sdev->sdev_data
  		+ shost->transportt->device_private_offset;
  }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
118
  #endif /* SCSI_TRANSPORT_H */