Server IP : 185.86.78.101 / Your IP : 216.73.216.213 Web Server : Apache System : Linux 675867-vds-valikoshka1996.gmhost.pp.ua 5.4.0-150-generic #167-Ubuntu SMP Mon May 15 17:35:05 UTC 2023 x86_64 User : www ( 1000) PHP Version : 7.4.33 Disable Function : passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : OFF Directory : /lib/modules/5.4.0-29-generic/build/include/scsi/ |
Upload File : |
/* SPDX-License-Identifier: GPL-2.0-only */ /* * Transport specific attributes. * * Copyright (c) 2003 Silicon Graphics, Inc. All rights reserved. */ #ifndef SCSI_TRANSPORT_H #define SCSI_TRANSPORT_H #include <linux/transport_class.h> #include <linux/blkdev.h> #include <linux/bug.h> #include <scsi/scsi_host.h> #include <scsi/scsi_device.h> struct scsi_transport_template { /* the attribute containers */ struct transport_container host_attrs; struct transport_container target_attrs; struct transport_container device_attrs; /* * If set, called from sysfs and legacy procfs rescanning code. */ int (*user_scan)(struct Scsi_Host *, uint, uint, u64); /* 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; int device_private_offset; int target_size; int target_private_offset; int host_size; /* no private offset for the host; there's an alternative mechanism */ /* * True if the transport wants to use a host-based work-queue */ unsigned int create_work_queue : 1; /* * Allows a transport to override the default error handler. */ void (* eh_strategy_handler)(struct Scsi_Host *); }; #define transport_class_to_shost(tc) \ dev_to_shost((tc)->parent) /* 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; } void __scsi_init_queue(struct Scsi_Host *shost, struct request_queue *q); #endif /* SCSI_TRANSPORT_H */