404

[ Avaa Bypassed ]




Upload:

Command:

botdev@18.222.106.93: ~ $
/*
 * Copyright (c) 2011-2012 Intel Corporation.  All rights reserved.
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms and conditions of the GNU General Public License,
 * version 2, as published by the Free Software Foundation.
 *
 * This program is distributed in the hope 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.,
 * 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA.
 *
 * Maintained at www.Open-FCoE.org
 */

#ifndef FCOE_SYSFS
#define FCOE_SYSFS

#include <linux/if_ether.h>
#include <linux/device.h>
#include <scsi/fc/fc_fcoe.h>

struct fcoe_ctlr_device;
struct fcoe_fcf_device;

struct fcoe_sysfs_function_template {
	void (*get_fcoe_ctlr_link_fail)(struct fcoe_ctlr_device *);
	void (*get_fcoe_ctlr_vlink_fail)(struct fcoe_ctlr_device *);
	void (*get_fcoe_ctlr_miss_fka)(struct fcoe_ctlr_device *);
	void (*get_fcoe_ctlr_symb_err)(struct fcoe_ctlr_device *);
	void (*get_fcoe_ctlr_err_block)(struct fcoe_ctlr_device *);
	void (*get_fcoe_ctlr_fcs_error)(struct fcoe_ctlr_device *);
	void (*set_fcoe_ctlr_mode)(struct fcoe_ctlr_device *);
	int  (*set_fcoe_ctlr_enabled)(struct fcoe_ctlr_device *);
	void (*get_fcoe_fcf_selected)(struct fcoe_fcf_device *);
	void (*get_fcoe_fcf_vlan_id)(struct fcoe_fcf_device *);
};

#define dev_to_ctlr(d)					\
	container_of((d), struct fcoe_ctlr_device, dev)

enum fip_conn_type {
	FIP_CONN_TYPE_UNKNOWN,
	FIP_CONN_TYPE_FABRIC,
	FIP_CONN_TYPE_VN2VN,
};

enum ctlr_enabled_state {
	FCOE_CTLR_ENABLED,
	FCOE_CTLR_DISABLED,
	FCOE_CTLR_UNUSED,
};

struct fcoe_ctlr_device {
	u32				id;

	struct device			dev;
	struct fcoe_sysfs_function_template *f;

	struct list_head		fcfs;
	char				work_q_name[20];
	struct workqueue_struct		*work_q;
	char				devloss_work_q_name[20];
	struct workqueue_struct		*devloss_work_q;
	struct mutex			lock;

	int                             fcf_dev_loss_tmo;
	enum fip_conn_type              mode;

	enum ctlr_enabled_state         enabled;

	/* expected in host order for displaying */
	struct fcoe_fc_els_lesb         lesb;
};

static inline void *fcoe_ctlr_device_priv(const struct fcoe_ctlr_device *ctlr)
{
	return (void *)(ctlr + 1);
}

/* fcf states */
enum fcf_state {
	FCOE_FCF_STATE_UNKNOWN,
	FCOE_FCF_STATE_DISCONNECTED,
	FCOE_FCF_STATE_CONNECTED,
	FCOE_FCF_STATE_DELETED,
};

struct fcoe_fcf_device {
	u32		    id;
	struct device	    dev;
	struct list_head    peers;
	struct work_struct  delete_work;
	struct delayed_work dev_loss_work;
	u32		    dev_loss_tmo;
	void                *priv;
	enum fcf_state      state;

	u64                 fabric_name;
	u64                 switch_name;
	u32                 fc_map;
	u16                 vfid;
	u8                  mac[ETH_ALEN];
	u8                  priority;
	u32                 fka_period;
	u8                  selected;
	u16                 vlan_id;
};

#define dev_to_fcf(d)					\
	container_of((d), struct fcoe_fcf_device, dev)
/* parentage should never be missing */
#define fcoe_fcf_dev_to_ctlr_dev(x)		\
	dev_to_ctlr((x)->dev.parent)
#define fcoe_fcf_device_priv(x)			\
	((x)->priv)

struct fcoe_ctlr_device *fcoe_ctlr_device_add(struct device *parent,
			    struct fcoe_sysfs_function_template *f,
			    int priv_size);
void fcoe_ctlr_device_delete(struct fcoe_ctlr_device *);
struct fcoe_fcf_device *fcoe_fcf_device_add(struct fcoe_ctlr_device *,
					    struct fcoe_fcf_device *);
void fcoe_fcf_device_delete(struct fcoe_fcf_device *);

int __init fcoe_sysfs_setup(void);
void __exit fcoe_sysfs_teardown(void);

#endif /* FCOE_SYSFS */

Filemanager

Name Type Size Permission Actions
fc Folder 0755
fc_encode.h File 21.64 KB 0644
fc_frame.h File 6.9 KB 0644
fcoe_sysfs.h File 3.75 KB 0644
iscsi_if.h File 26.07 KB 0644
iscsi_proto.h File 16.06 KB 0644
iser.h File 2.34 KB 0644
libfc.h File 31.71 KB 0644
libfcoe.h File 14 KB 0644
libiscsi.h File 14.36 KB 0644
libiscsi_tcp.h File 4.32 KB 0644
libsas.h File 18.53 KB 0644
osd_attributes.h File 15.05 KB 0644
osd_initiator.h File 16.26 KB 0644
osd_ore.h File 5.36 KB 0644
osd_protocol.h File 17.57 KB 0644
osd_sec.h File 1.48 KB 0644
osd_sense.h File 9.89 KB 0644
osd_types.h File 1020 B 0644
sas.h File 13.22 KB 0644
sas_ata.h File 2.73 KB 0644
scsi.h File 8.8 KB 0644
scsi_bsg_iscsi.h File 2.83 KB 0644
scsi_cmnd.h File 9.62 KB 0644
scsi_common.h File 2.27 KB 0644
scsi_dbg.h File 2.19 KB 0644
scsi_device.h File 20.49 KB 0644
scsi_devinfo.h File 2.51 KB 0644
scsi_dh.h File 3.16 KB 0644
scsi_driver.h File 859 B 0644
scsi_eh.h File 1.64 KB 0644
scsi_host.h File 27.58 KB 0644
scsi_ioctl.h File 1.25 KB 0644
scsi_proto.h File 10.67 KB 0644
scsi_request.h File 667 B 0644
scsi_tcq.h File 1.03 KB 0644
scsi_transport.h File 3.22 KB 0644
scsi_transport_fc.h File 26.47 KB 0644
scsi_transport_iscsi.h File 17.25 KB 0644
scsi_transport_sas.h File 6.79 KB 0644
scsi_transport_spi.h File 7.2 KB 0644
scsi_transport_srp.h File 4.77 KB 0644
scsicam.h File 713 B 0644
sg.h File 12.13 KB 0644
srp.h File 6.1 KB 0644
viosrp.h File 6.07 KB 0644