__  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ V /  | |__) | __ ___   ____ _| |_ ___  | (___ | |__   ___| | |
 | |\/| | '__|> <   |  ___/ '__| \ \ / / _` | __/ _ \  \___ \| '_ \ / _ \ | |
 | |  | | |_ / . \  | |   | |  | |\ V / (_| | ||  __/  ____) | | | |  __/ | |
 |_|  |_|_(_)_/ \_\ |_|   |_|  |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1
 if you need WebShell for Seo everyday contact me on Telegram
 Telegram Address : @jackleet
        
        
For_More_Tools: Telegram: @jackleet | Bulk Smtp support mail sender | Business Mail Collector | Mail Bouncer All Mail | Bulk Office Mail Validator | Html Letter private



Upload:

Command:

[email protected]: ~ $
/* SPDX-License-Identifier: GPL-2.0-or-later */
/*
 * Support for SATA devices on Serial Attached SCSI (SAS) controllers
 *
 * Copyright (C) 2006 IBM Corporation
 *
 * Written by: Darrick J. Wong <[email protected]>, IBM Corporation
 */

#ifndef _SAS_ATA_H_
#define _SAS_ATA_H_

#include <linux/libata.h>
#include <scsi/libsas.h>

#ifdef CONFIG_SCSI_SAS_ATA

static inline int dev_is_sata(struct domain_device *dev)
{
	return dev->dev_type == SAS_SATA_DEV || dev->dev_type == SAS_SATA_PM ||
	       dev->dev_type == SAS_SATA_PM_PORT || dev->dev_type == SAS_SATA_PENDING;
}

int sas_get_ata_info(struct domain_device *dev, struct ex_phy *phy);
int sas_ata_init(struct domain_device *dev);
void sas_ata_task_abort(struct sas_task *task);
void sas_ata_strategy_handler(struct Scsi_Host *shost);
void sas_ata_eh(struct Scsi_Host *shost, struct list_head *work_q);
void sas_ata_schedule_reset(struct domain_device *dev);
void sas_ata_wait_eh(struct domain_device *dev);
void sas_probe_sata(struct asd_sas_port *port);
void sas_suspend_sata(struct asd_sas_port *port);
void sas_resume_sata(struct asd_sas_port *port);
void sas_ata_end_eh(struct ata_port *ap);
void sas_ata_device_link_abort(struct domain_device *dev, bool force_reset);
int sas_execute_ata_cmd(struct domain_device *device, u8 *fis,
			int force_phy_id);
int smp_ata_check_ready_type(struct ata_link *link);
int sas_discover_sata(struct domain_device *dev);
int sas_ata_add_dev(struct domain_device *parent, struct ex_phy *phy,
		    struct domain_device *child, int phy_id);

extern const struct attribute_group sas_ata_sdev_attr_group;

#else

static inline void sas_ata_disabled_notice(void)
{
	pr_notice_once("ATA device seen but CONFIG_SCSI_SAS_ATA=N\n");
}

static inline int dev_is_sata(struct domain_device *dev)
{
	return 0;
}
static inline int sas_ata_init(struct domain_device *dev)
{
	return 0;
}
static inline void sas_ata_task_abort(struct sas_task *task)
{
}

static inline void sas_ata_strategy_handler(struct Scsi_Host *shost)
{
}

static inline void sas_ata_eh(struct Scsi_Host *shost, struct list_head *work_q)
{
}

static inline void sas_ata_schedule_reset(struct domain_device *dev)
{
}

static inline void sas_ata_wait_eh(struct domain_device *dev)
{
}

static inline void sas_probe_sata(struct asd_sas_port *port)
{
}

static inline void sas_suspend_sata(struct asd_sas_port *port)
{
}

static inline void sas_resume_sata(struct asd_sas_port *port)
{
}

static inline int sas_get_ata_info(struct domain_device *dev, struct ex_phy *phy)
{
	return 0;
}

static inline void sas_ata_end_eh(struct ata_port *ap)
{
}

static inline void sas_ata_device_link_abort(struct domain_device *dev,
					     bool force_reset)
{
}

static inline int sas_execute_ata_cmd(struct domain_device *device, u8 *fis,
				      int force_phy_id)
{
	return 0;
}

static inline int smp_ata_check_ready_type(struct ata_link *link)
{
	return 0;
}

static inline int sas_discover_sata(struct domain_device *dev)
{
	sas_ata_disabled_notice();
	return -ENXIO;
}

static inline int sas_ata_add_dev(struct domain_device *parent, struct ex_phy *phy,
				  struct domain_device *child, int phy_id)
{
	sas_ata_disabled_notice();
	return -ENODEV;
}

#define sas_ata_sdev_attr_group ((struct attribute_group) {})

#endif

#endif /* _SAS_ATA_H_ */

Filemanager

Name Type Size Permission Actions
fc Folder 0755
fc_frame.h File 7.03 KB 0644
fcoe_sysfs.h File 3.09 KB 0644
iscsi_if.h File 25.6 KB 0644
iscsi_proto.h File 15.54 KB 0644
iser.h File 2.34 KB 0644
libfc.h File 31.57 KB 0644
libfcoe.h File 13.83 KB 0644
libiscsi.h File 14.59 KB 0644
libiscsi_tcp.h File 3.8 KB 0644
libsas.h File 19.3 KB 0644
sas.h File 12.79 KB 0644
sas_ata.h File 3.22 KB 0644
scsi.h File 5.85 KB 0644
scsi_bsg_iscsi.h File 2.18 KB 0644
scsi_cmnd.h File 10.47 KB 0644
scsi_common.h File 2.68 KB 0644
scsi_dbg.h File 1.96 KB 0644
scsi_device.h File 23.69 KB 0644
scsi_devinfo.h File 3.9 KB 0644
scsi_dh.h File 2.54 KB 0644
scsi_driver.h File 1.18 KB 0644
scsi_eh.h File 1.58 KB 0644
scsi_host.h File 27.17 KB 0644
scsi_ioctl.h File 1.51 KB 0644
scsi_proto.h File 12.62 KB 0644
scsi_status.h File 2.64 KB 0644
scsi_tcq.h File 993 B 0644
scsi_transport.h File 2.55 KB 0644
scsi_transport_fc.h File 27.88 KB 0644
scsi_transport_iscsi.h File 17.27 KB 0644
scsi_transport_sas.h File 6.88 KB 0644
scsi_transport_spi.h File 6.53 KB 0644
scsi_transport_srp.h File 4.81 KB 0644
scsicam.h File 636 B 0644
sg.h File 14.75 KB 0644
srp.h File 6.86 KB 0644
viosrp.h File 5.48 KB 0644
Filemanager