Skip to content

wangl0320/tgt

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Introduction

The Linux target framework (tgt) is a user space SCSI target framework that supports the iSCSI and iSER transport protocols and that also supports multiple methods for accessing block storage. Tgt consists of a user-space daemon and user-space tools.

Currently, tgt supports the following SCSI transport protocols:

  • iSCSI software target driver for Ethernet NICs
  • iSER software target driver for Infiniband and RDMA NICs

Tgt supports the following methods for accessing local storage:

  • aio, the asynchronous I/O interface also known as libaio.
  • rdwr, smc and mmc, synchronous I/O based on the pread() and pwrite() system calls.
  • null, discards all data and reads zeroes.
  • ssc, SCSI tape support.
  • sg and bsg, SCSI pass-through.
  • glfs, the GlusterFS network filesystem.
  • rbd, Ceph's distributed-storage RADOS Block Device.
  • sheepdog, a distributed object storage system.

Tgt can emulate the following SCSI device types:

  • SBC: a virtual disk drive that can use a file to store the content.
  • SMC: a virtual media jukebox that can be controlled by the "mtx" tool.
  • MMC: a virtual DVD drive that can read DVD-ROM iso files and create burnable DVD+R. It can be combined with SMC to provide a fully operational DVD jukebox.
  • SSC: a virtual tape device (aka VTL) that can use a file to store the content.
  • OSD: a virtual object-based storage device that can use a file to store the content (in progress).

License

The code is released under the GNU General Public License version 2.

Requirements

Linux kernel version 2.6.22 or newer is recommended because tgt can get better performance with signalfd.

Target drivers have their own ways to build, configure, etc. Please find an appropriate documentation in the doc directory.

Developer Notes

The central communication channel for tgt development is the mailing list ([email protected]).

First, please read the following documents (in short, follow Linux kernel development rules):

https://www.kernel.org/doc/Documentation/CodingStyle https://www.kernel.org/doc/Documentation/SubmittingPatches

Then, check your patches with the patch style checker prior to submission (scripts/checkpatch.pl) like the following example.

fujita@arbre:~/git/tgt$ ./scripts/checkpatch.pl ~/0001-add-bidi-support.patch Your patch has no obvious style problems and is ready for submission.

Packages

No packages published

Languages

  • C 83.6%
  • Perl 13.0%
  • Shell 2.9%
  • Makefile 0.5%