Blame view

kernel/linux-rt-4.4.41/drivers/scsi/snic/snic_disc.h 2.98 KB
5113f6f70   김현기   kernel add
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
  /*
   * Copyright 2014 Cisco Systems, Inc.  All rights reserved.
   *
   * This program is free software; you may redistribute it and/or modify
   * it under the terms of the GNU General Public License as published by
   * the Free Software Foundation; version 2 of the License.
   *
   * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
   * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
   * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
   * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
   * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
   * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
   * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
   * SOFTWARE.
   */
  
  #ifndef __SNIC_DISC_H
  #define __SNIC_DISC_H
  
  #include "snic_fwint.h"
  
  enum snic_disc_state {
  	SNIC_DISC_NONE,
  	SNIC_DISC_INIT,
  	SNIC_DISC_PENDING,
  	SNIC_DISC_DONE
  };
  
  struct snic;
  struct snic_disc {
  	struct list_head tgt_list;
  	enum snic_disc_state state;
  	struct mutex mutex;
  	u16	disc_id;
  	u8	req_cnt;
  	u32	nxt_tgt_id;
  	u32	rtgt_cnt;
  	u8	*rtgt_info;
  	struct delayed_work disc_timeout;
  	void (*cb)(struct snic *);
  };
  
  #define SNIC_TGT_NAM_LEN	16
  
  enum snic_tgt_state {
  	SNIC_TGT_STAT_NONE,
  	SNIC_TGT_STAT_INIT,
  	SNIC_TGT_STAT_ONLINE,	/* Target is Online */
  	SNIC_TGT_STAT_OFFLINE,	/* Target is Offline */
  	SNIC_TGT_STAT_DEL,
  };
  
  struct snic_tgt_priv {
  	struct list_head list;
  	enum snic_tgt_type typ;
  	u16 disc_id;
  	char *name[SNIC_TGT_NAM_LEN];
  
  	union {
  		/*DAS Target specific info */
  		/*SAN Target specific info */
  		u8 dummmy;
  	} u;
  };
  
  /* snic tgt flags */
  #define SNIC_TGT_SCAN_PENDING	0x01
  
  struct snic_tgt {
  	struct list_head list;
  	u16	id;
  	u16	channel;
  	u32	flags;
  	u32	scsi_tgt_id;
  	enum snic_tgt_state state;
  	struct device dev;
  	struct work_struct scan_work;
  	struct work_struct del_work;
  	struct snic_tgt_priv tdata;
  };
  
  
  struct snic_fw_req;
  
  void snic_disc_init(struct snic_disc *);
  int snic_disc_start(struct snic *);
  void snic_disc_term(struct snic *);
  int snic_report_tgt_cmpl_handler(struct snic *, struct snic_fw_req *);
  int snic_tgtinfo_cmpl_handler(struct snic *snic, struct snic_fw_req *fwreq);
  void snic_process_report_tgts_rsp(struct work_struct *);
  void snic_handle_tgt_disc(struct work_struct *);
  void snic_handle_disc(struct work_struct *);
  void snic_tgt_dev_release(struct device *);
  void snic_tgt_del_all(struct snic *);
  
  #define dev_to_tgt(d) \
  	container_of(d, struct snic_tgt, dev)
  
  static inline int
  is_snic_target(struct device *dev)
  {
  	return dev->release == snic_tgt_dev_release;
  }
  
  #define starget_to_tgt(st)	\
  	(is_snic_target(((struct scsi_target *) st)->dev.parent) ? \
  		dev_to_tgt(st->dev.parent) : NULL)
  
  #define snic_tgt_to_shost(t)	\
  	dev_to_shost(t->dev.parent)
  
  static inline int
  snic_tgt_chkready(struct snic_tgt *tgt)
  {
  	if (tgt->state == SNIC_TGT_STAT_ONLINE)
  		return 0;
  	else
  		return DID_NO_CONNECT << 16;
  }
  
  const char *snic_tgt_state_to_str(int);
  int snic_tgt_scsi_abort_io(struct snic_tgt *);
  #endif /* end of  __SNIC_DISC_H */