xref: /freebsd/usr.sbin/ctladm/ctladm.8 (revision a4bcd20486f8c20cc875b39bc75aa0d5a047373f)
1.\"
2.\" Copyright (c) 2003 Silicon Graphics International Corp.
3.\" Copyright (c) 2015-2020 Alexander Motin <mav@FreeBSD.org>
4.\" Copyright (c) 2018 Marcelo Araujo <araujo@FreeBSD.org>
5.\" All rights reserved.
6.\"
7.\" Redistribution and use in source and binary forms, with or without
8.\" modification, are permitted provided that the following conditions
9.\" are met:
10.\" 1. Redistributions of source code must retain the above copyright
11.\"    notice, this list of conditions, and the following disclaimer,
12.\"    without modification.
13.\" 2. Redistributions in binary form must reproduce at minimum a disclaimer
14.\"    substantially similar to the "NO WARRANTY" disclaimer below
15.\"    ("Disclaimer") and any redistribution must be conditioned upon
16.\"    including a substantially similar Disclaimer requirement for further
17.\"    binary redistribution.
18.\"
19.\" NO WARRANTY
20.\" THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21.\" "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22.\" LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
23.\" A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24.\" HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
28.\" STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
29.\" IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30.\" POSSIBILITY OF SUCH DAMAGES.
31.\"
32.\" ctladm utility man page.
33.\"
34.\" Author: Ken Merry <ken@FreeBSD.org>
35.\"
36.\" $Id: //depot/users/kenm/FreeBSD-test2/usr.sbin/ctladm/ctladm.8#3 $
37.\" $FreeBSD$
38.\"
39.Dd August 6, 2020
40.Dt CTLADM 8
41.Os
42.Sh NAME
43.Nm ctladm
44.Nd CAM Target Layer control utility
45.Sh SYNOPSIS
46.Nm
47.Aq Ar command
48.Op lun
49.Op generic args
50.Op command args
51.Nm
52.Ic tur
53.Aq lun
54.Op general options
55.Nm
56.Ic inquiry
57.Aq lun
58.Op general options
59.Nm
60.Ic reqsense
61.Aq lun
62.Op general options
63.Nm
64.Ic reportluns
65.Aq lun
66.Op general options
67.Nm
68.Ic read
69.Aq lun
70.Op general options
71.Aq Fl l Ar lba
72.Aq Fl d Ar datalen
73.Aq Fl f Ar file|-
74.Aq Fl b Ar blocksize_bytes
75.Op Fl c Ar cdbsize
76.Op Fl N
77.Nm
78.Ic write
79.Aq lun
80.Op general options
81.Aq Fl l Ar lba
82.Aq Fl d Ar datalen
83.Aq Fl f Ar file|-
84.Aq Fl b Ar blocksize_bytes
85.Op Fl c Ar cdbsize
86.Op Fl N
87.Nm
88.Ic readcap
89.Aq lun
90.Op general options
91.Op Fl c Ar cdbsize
92.Nm
93.Ic modesense
94.Aq lun
95.Aq Fl m Ar page | Fl l
96.Op Fl P Ar pc
97.Op Fl d
98.Op Fl S Ar subpage
99.Op Fl c Ar size
100.Nm
101.Ic start
102.Aq lun
103.Op general options
104.Op Fl i
105.Op Fl o
106.Nm
107.Ic stop
108.Aq lun
109.Op general options
110.Op Fl i
111.Op Fl o
112.Nm
113.Ic synccache
114.Aq lun
115.Op general options
116.Op Fl l Ar lba
117.Op Fl b Ar blockcount
118.Op Fl r
119.Op Fl i
120.Op Fl c Ar cdbsize
121.Nm
122.Ic lunlist
123.Nm
124.Ic delay
125.Aq lun
126.Aq Fl l Ar datamove|done
127.Aq Fl t Ar secs
128.Op Fl T Ar oneshot|cont
129.Nm
130.Ic inject
131.Aq Fl i Ar action
132.Aq Fl p Ar pattern
133.Op Fl r Ar lba,len
134.Op Fl s Ar len fmt Op Ar args
135.Op Fl c
136.Op Fl d Ar delete_id
137.Nm
138.Ic create
139.Aq Fl b Ar backend
140.Op Fl B Ar blocksize
141.Op Fl d Ar device_id
142.Op Fl l Ar lun_id
143.Op Fl o Ar name=value
144.Op Fl s Ar size_bytes
145.Op Fl S Ar serial_num
146.Op Fl t Ar device_type
147.Nm
148.Ic remove
149.Aq Fl b Ar backend
150.Aq Fl l Ar lun_id
151.Op Fl o Ar name=value
152.Nm
153.Ic modify
154.Aq Fl b Ar backend
155.Aq Fl l Ar lun_id
156.Op Fl o Ar name=value
157.Aq Fl s Ar size_bytes
158.Nm
159.Ic devlist
160.Op Fl b Ar backend
161.Op Fl v
162.Op Fl x
163.Nm
164.Ic port
165.Op Fl c
166.Op Fl o Ar on|off
167.Op Fl w Ar wwpn
168.Op Fl W Ar wwnn
169.Op Fl O Ar pp|vp
170.Op Fl p Ar targ_port
171.Op Fl r Ar targ_port
172.Op Fl t Ar fe_type
173.Nm
174.Ic portlist
175.Op Fl f Ar frontend
176.Op Fl i
177.Op Fl l
178.Op Fl p Ar targ_port
179.Op Fl q
180.Op Fl v
181.Op Fl x
182.Nm
183.Ic lunmap
184.Aq Fl p Ar targ_port
185.Op Fl l Ar pLUN
186.Op Fl L Ar cLUN
187.Nm
188.Ic dumpooa
189.Nm
190.Ic dumpstructs
191.Nm
192.Ic islist
193.Op Fl v
194.Op Fl x
195.Nm
196.Ic islogout
197.Aq Fl a | Fl c Ar connection-id | Fl i Ar name | Fl p Ar portal
198.Nm
199.Ic isterminate
200.Aq Fl a | Fl c Ar connection-id | Fl i Ar name | Fl p Ar portal
201.Nm
202.Ic help
203.Sh DESCRIPTION
204The
205.Nm
206utility is designed to provide a way to access and control the CAM Target
207Layer (CTL).
208It provides a way to send
209.Tn SCSI
210commands to the CTL layer, and also provides
211some meta-commands that utilize
212.Tn SCSI
213commands.
214(For instance, the
215.Ic lunlist
216command is implemented using the
217.Tn SCSI
218REPORT LUNS and INQUIRY commands.)
219.Pp
220The
221.Nm
222utility has a number of primary functions, many of which require a device
223identifier.
224The device identifier takes the following form:
225.Bl -tag -width 14n
226.It lun
227Specify the LUN number to operate on.
228.El
229Many of the primary functions of the
230.Nm
231utility take the following optional arguments:
232.Bl -tag -width 10n
233.It Fl C Ar retries
234Specify the number of times to retry a command in the event of failure.
235.It Fl D Ar device
236Specify the device to open.
237This allows opening a device other than the default device,
238.Pa /dev/cam/ctl ,
239to be opened for sending commands.
240.It Fl I Ar id
241Specify the initiator number to use.
242By default,
243.Nm
244will use 7 as the initiator number.
245.El
246.Pp
247Primary commands:
248.Bl -tag -width 11n
249.It Ic tur
250Send the
251.Tn SCSI
252TEST UNIT READY command to the device and report whether or not it is
253ready.
254.It Ic inquiry
255Send the
256.Tn SCSI
257INQUIRY command to the device and display some of the returned inquiry
258data.
259.It Ic reqsense
260Send the
261.Tn SCSI
262REQUEST SENSE command to the device and display the returned sense
263information.
264.It Ic reportluns
265Send the
266.Tn SCSI
267REPORT LUNS command to the device and display supported LUNs.
268.It Ic read
269Send a
270.Tn SCSI
271READ command to the device, and write the requested data to a file or
272stdout.
273.Bl -tag -width 12n
274.It Fl l Ar lba
275Specify the starting Logical Block Address for the READ.
276This can be specified in decimal, octal (starting with 0),
277hexadecimal (starting with 0x) or any other base supported by
278.Xr strtoull 3 .
279.It Fl d Ar datalen
280Specify the length, in 512 byte blocks, of the READ request.
281.It Fl f Ar file
282Specify the destination for the data read by the READ command.
283Either a filename or
284.Sq -
285for stdout may be specified.
286.It Fl c Ar cdbsize
287Specify the minimum
288.Tn SCSI
289CDB (Command Data Block) size to be used for the READ request.
290Allowable values are 6, 10, 12 and 16.
291Depending upon the LBA and amount of data requested, a larger CDB
292size may be used to satisfy the request.  (e.g., for LBAs above 0xffffffff,
293READ(16) must be used to satisfy the request.)
294.It Fl b Ar blocksize
295Specify the blocksize of the underlying
296.Tn SCSI
297device, so the transfer length
298can be calculated accurately.
299The blocksize can be obtained via the
300.Tn SCSI
301READ CAPACITY command.
302.It Fl N
303Do not copy data to
304.Nm
305from the kernel when doing a read, just execute the command without copying
306data.
307This is to be used for performance testing.
308.El
309.It Ic write
310Read data from a file or stdin, and write the data to the device using the
311.Tn SCSI
312WRITE command.
313.Bl -tag -width 12n
314.It Fl l Ar lba
315Specify the starting Logical Block Address for the WRITE.
316This can be specified in decimal, octal (starting with 0), hexadecimal
317(starting with 0x) or any other base supported by
318.Xr strtoull 3 .
319.It Fl d Ar atalen
320Specify the length, in 512 byte blocks, of the WRITE request.
321.It Fl f Ar file
322Specify the source for the data to be written by the WRITE command.
323Either a filename or
324.Sq -
325for stdin may be specified.
326.It Fl c Ar cdbsize
327Specify the minimum
328.Tn SCSI
329CDB (Command Data Block) size to be used for the READ request.
330Allowable values are 6, 10, 12 and 16.
331Depending upon the LBA and amount of data requested, a larger CDB size
332may be used to satisfy the request.  (e.g., for LBAs above 0xffffffff, READ(16)
333must be used to satisfy the request.)
334.It Fl b Ar blocksize
335Specify the blocksize of the underlying
336.Tn SCSI
337device, so the transfer length
338can be calculated accurately.
339The blocksize can be obtained via the
340.Tn SCSI
341READ CAPACITY command.
342.It Fl N
343Do not copy data to
344.Nm
345to the kernel when doing a write, just execute the command without copying
346data.
347This is to be used for performance testing.
348.El
349.It Ic readcap
350Send the
351.Tn SCSI
352READ CAPACITY command to the device and display the device size and device
353block size.
354By default, READ CAPACITY(10) is used.
355If the device returns a maximum LBA of 0xffffffff, however,
356.Nm
357will automatically issue a READ CAPACITY(16), which is implemented as a
358service action of the SERVICE ACTION IN(16) opcode.
359The user can specify the minimum CDB size with the
360.Fl c
361argument.
362Valid values for the
363.Fl c
364option are 10 and 16.
365If a 10 byte CDB is specified, the request will be automatically reissued
366with a 16 byte CDB if the maximum LBA returned is 0xffffffff.
367.It Ic modesense
368Send a
369.Tn SCSI
370MODE SENSE command to the device, and display the requested mode page(s) or
371page list.
372.Bl -tag -width 10n
373.It Fl m Ar page
374Specify the mode page to display.
375This option and the
376.Fl l
377option are mutually exclusive.
378One of the two must be specified, though.
379Mode page numbers may be specified in decimal or hexadecimal.
380.It Fl l
381Request that the list of mode pages supported by the device be returned.
382This option and the
383.Fl m
384option are mutually exclusive.
385One of the two must be specified, though.
386.It Fl P Ar pc
387Specify the mode page control value.
388Possible values are:
389.Bl -tag -width 2n -compact
390.It 0
391Current values.
392.It 1
393Changeable value bitmask.
394.It 2
395Default values.
396.It 3
397Saved values.
398.El
399.It Fl d
400Disable block descriptors when sending the mode sense request.
401.It Fl S Ar subpage
402Specify the subpage used with the mode sense request.
403.It Fl c Ar cdbsize
404Specify the CDB size used for the mode sense request.
405Supported values are 6 and 10.
406.El
407.It Ic start
408Send the
409.Tn SCSI
410START STOP UNIT command to the specified LUN with the start
411bit set.
412.Bl -tag -width 4n
413.It Fl i
414Set the immediate bit in the CDB.
415Note that CTL does not support the immediate bit, so this is primarily
416useful for making sure that CTL returns the proper error.
417.El
418.It Ic stop
419Send the
420.Tn SCSI
421START STOP UNIT command to the specified LUN with the start
422bit cleared.
423We use an ordered tag to stop the LUN, so we can guarantee that all pending
424I/O executes before it is stopped.
425(CTL guarantees this anyway, but
426.Nm
427sends an ordered tag for completeness.)
428.Bl -tag -width 4n
429.It Fl i
430Set the immediate bit in the CDB.
431Note that CTL does not support the immediate bit, so this is primarily
432useful for making sure that CTL returns the proper error.
433.El
434.It Ic synccache
435Send the
436.Tn SCSI
437SYNCHRONIZE CACHE command to the device.
438By default, SYNCHRONIZE CACHE(10) is used.
439If the specified starting LBA is greater than 0xffffffff or the length is
440greater than 0xffff, though, SYNCHRONIZE CACHE(16) will be used.
441The 16 byte command will also be used if the user specifies a 16 byte CDB with the
442.Fl c
443argument.
444.Bl -tag -width 14n
445.It Fl l Ar lba
446Specify the starting LBA of the cache region to synchronize.
447This option is a no-op for CTL.
448If you send a SYNCHRONIZE CACHE command, it will sync the cache for the entire LUN.
449.It Fl b Ar blockcount
450Specify the length of the cache region to synchronize.
451This option is a no-op for CTL.
452If you send a SYNCHRONIZE CACHE command, it will sync the cache for the entire LUN.
453.It Fl r
454Specify relative addressing for the starting LBA.
455CTL does not support relative addressing, since it only works for linked commands,
456and CTL does not support linked commands.
457.It Fl i
458Tell the target to return status immediately after issuing the SYNCHRONIZE CACHE
459command rather than waiting for the cache to finish syncing.
460CTL does not support this bit.
461.It Fl c Ar cdbsize
462Specify the minimum CDB size.
463Valid values are 10 and 16 bytes.
464.El
465.It Ic lunlist
466List all LUNs registered with CTL.
467Because this command uses the ioctl port, it will only work when the FETDs
468(Front End Target Drivers) are enabled.
469This command is the equivalent of doing a REPORT LUNS on one LUN and then
470an INQUIRY on each LUN in the system.
471.It Ic delay
472Delay commands at the given location.
473There are two places where commands may be delayed currently: before data is transferred
474.Pq Dq datamove
475and just prior to sending status to the host
476.Pq Dq done .
477One of the two must be supplied as an argument to the
478.Fl l
479option.
480The
481.Fl t
482option must also be specified.
483.Bl -tag -width 12n
484.It Fl l Ar delayloc
485Delay command(s) at the specified location.
486This can either be at the data movement stage (datamove) or prior to
487command completion (done).
488.It Fl t Ar delaytime
489Delay command(s) for the specified number of seconds.
490This must be specified.
491If set to 0, it will clear out any previously set delay for this particular
492location (datamove or done).
493.It Fl T Ar delaytype
494Specify the delay type.
495By default, the
496.Ic delay
497option will delay the next command sent to the given LUN.
498With the
499.Fl T Ar cont
500option, every command will be delayed by the specified period of time.
501With the
502.Fl T Ar oneshot
503the next command sent to the given LUN will be delayed and all subsequent
504commands will be completed normally.
505This is the default.
506.El
507.It Ic inject
508Inject the specified type of error for the LUN specified, when a command
509that matches the given pattern is seen.
510The sense data returned is in either fixed or descriptor format, depending
511upon the status of the D_SENSE bit in the control mode page (page 0xa) for
512the LUN.
513.Pp
514Errors are only injected for commands that have not already failed for
515other reasons.
516By default, only the first command matching the pattern specified is
517returned with the supplied error.
518.Pp
519If the
520.Fl c
521flag is specified, all commands matching the pattern will be returned with
522the specified error until the error injection command is deleted with
523.Fl d
524flag.
525.Bl -tag -width 17n
526.It Fl i Ar action
527Specify the error to return:
528.Bl -tag -width 10n
529.It aborted
530Return the next matching command on the specified LUN with the sense key
531ABORTED COMMAND (0x0b), and the ASC/ASCQ 0x45,0x00 ("Select or reselect
532failure").
533.It mediumerr
534Return the next matching command on the specified LUN with the sense key
535MEDIUM ERROR (0x03) and the ASC/ASCQ 0x11,0x00 ("Unrecovered read error") for
536reads, or ASC/ASCQ 0x0c,0x02 ("Write error - auto reallocation failed")
537for write errors.
538.It ua
539Return the next matching command on the specified LUN with the sense key
540UNIT ATTENTION (0x06) and the ASC/ASCQ 0x29,0x00 ("POWER ON, RESET, OR BUS
541DEVICE RESET OCCURRED").
542.It custom
543Return the next matching command on the specified LUN with the supplied
544sense data.
545The
546.Fl s
547argument must be specified.
548.El
549.It Fl p Ar pattern
550Specify which commands should be returned with the given error.
551.Bl -tag -width 10n
552.It read
553The error should apply to READ(6), READ(10), READ(12), READ(16), etc.
554.It write
555The error should apply to WRITE(6), WRITE(10), WRITE(12), WRITE(16), WRITE
556AND VERIFY(10), etc.
557.It rw
558The error should apply to both read and write type commands.
559.It readcap
560The error should apply to READ CAPACITY(10) and READ CAPACITY(16) commands.
561.It tur
562The error should apply to TEST UNIT READY commands.
563.It any
564The error should apply to any command.
565.El
566.It Fl r Ar lba,len
567Specify the starting lba and length of the range of LBAs which should
568trigger an error.
569This option is only applies when read and/or write patterns are specified.
570If used with other command types, the error will never be triggered.
571.It Fl s Ar len fmt Op Ar args
572Specify the sense data that is to be returned for custom actions.
573If the format is
574.Sq - ,
575len bytes of sense data will be read from standard input and written to the
576sense buffer.
577If len is longer than 252 bytes (the maximum allowable
578.Tn SCSI
579sense data length), it will be truncated to that length.
580The sense data format is described in
581.Xr cam_cdbparse 3 .
582.It Fl c
583The error injection should be persistent, instead of happening once.
584Persistent errors must be deleted with the
585.Fl d
586argument.
587.It Fl d Ar delete_id
588Delete the specified error injection serial number.
589The serial number is returned when the error is injected.
590.El
591.It Ic port
592Perform one of several CTL frontend port operations.
593Either get a list of frontend ports
594.Pq Fl l ,
595turn one or more frontends on
596or off
597.Pq Fl o Ar on|off ,
598or set the World Wide Node Name
599.Pq Fl w Ar wwnn
600or World Wide Port Name
601.Pq Fl W Ar wwpn
602for a given port.
603One of
604.Fl l ,
605.Fl o ,
606or
607.Fl w
608or
609.Fl W
610must be specified.
611The WWNN and WWPN may both be specified at the same time, but cannot be
612combined with enabling/disabling or listing ports.
613.Bl -tag -width 12n
614.It Fl c
615Create new frontend port using free pp and vp=0.
616.It Fl o Ar on|off
617Turn the specified CTL frontend ports on or off.
618If no port number or port type is specified, all ports are turned on or
619off.
620.It Fl O Ar pp|vp
621Specify generic options on the ioctl frontend port.
622At present, only pp and vp port numbers can be set.
623.It Fl p Ar targ_port
624Specify the frontend port number.
625The port numbers can be found in the frontend port list.
626.It Fl r
627Remove port specified with
628.Pq Fl p Ar targ_port .
629.It Fl t Ar fe_type
630Specify the frontend type.
631Currently defined port types are
632.Dq fc
633(Fibre Channel),
634.Dq scsi
635(Parallel SCSI),
636.Dq ioctl
637(CTL ioctl interface),
638and
639.Dq internal
640(CTL CAM SIM).
641.It Fl w Ar wwnn
642Set the World Wide Node Name for the given port.
643The
644.Fl n
645argument must be specified, since this is only possible to implement on a
646single port.
647As a general rule, the WWNN should be the same across all ports on the
648system.
649.It Fl W Ar wwpn
650Set the World Wide Port Name for the given port.
651The
652.Fl n
653argument must be specified, since this is only possible to implement on a
654single port.
655As a general rule, the WWPN must be different for every port in the system.
656.El
657.It Ic portlist
658List CTL frontend ports.
659.Bl -tag -width 12n
660.It Fl f Ar frontend
661Specify the frontend type.
662.It Fl i
663Report target and connected initiators addresses.
664.It Fl l
665Report LUN mapping.
666.It Fl p Ar targ_port
667Specify the frontend port number.
668.It Fl q
669Omit the header in the port list output.
670.It Fl v
671Enable verbose output (report all port options).
672.It Fl x
673Output the port list in XML format.
674.El
675.It Ic lunmap
676Change LUN mapping for specified port.
677If both
678.Ar pLUN
679and
680.Ar cLUN
681are specified -- LUN will be mapped.
682If
683.Ar pLUN
684is specified, but
685.Ar cLUN
686is not -- LUN will be unmapped.
687If neither
688.Ar pLUN
689nor
690.Ar cLUN
691are specified -- LUN mapping will be disabled, exposing all CTL LUNs.
692.Bl -tag -width 12n
693.It Fl p Ar targ_port
694Specify the frontend port number.
695.It Fl l Ar pLUN
696LUN number visible by specified port.
697.It Fl L Ar cLUN
698CTL LUN number.
699.El
700.It Ic dumpooa
701Dump the OOA (Order Of Arrival) queue for each LUN registered with CTL.
702.It Ic dumpstructs
703Dump the CTL structures to the console.
704.It Ic create
705Create a new LUN.
706The backend must be specified, and depending upon the backend requested,
707some of the other options may be required.
708If the LUN is created successfully, the LUN configuration will be
709displayed.
710If LUN creation fails, a message will be displayed describing the failure.
711.Bl -tag -width 14n
712.It Fl b Ar backend
713The
714.Fl b
715flag is required.
716This specifies the name backend to use when creating the LUN.
717Examples are
718.Dq ramdisk
719and
720.Dq block .
721.It Fl B Ar blocksize
722Specify the blocksize of the backend in bytes.
723.It Fl d Ar device_id
724Specify the LUN-associated string to use in the
725.Tn SCSI
726INQUIRY VPD page 0x83 data.
727.It Fl l Ar lun_id
728Request that a particular LUN number be assigned.
729If the requested LUN number is not available, the request will fail.
730.It Fl o Ar name=value
731Specify a backend-specific name/value pair.
732Multiple
733.Fl o
734arguments may be specified.
735Refer to the backend documentation for arguments that may be used.
736.It Fl s Ar size_bytes
737Specify the size of the LUN in bytes.
738Some backends may allow setting the size (e.g. the ramdisk backend) and for
739others the size may be implicit (e.g. the block backend).
740.It Fl S Ar serial_num
741Specify the serial number to be used in the
742.Tn SCSI
743INQUIRY VPD page 0x80 data.
744.It Fl t Ar device_type
745Specify the numeric SCSI device type to use when creating the LUN.
746If this flag is not used, the type of LUN created is backend-specific.
747Not all LUN types are supported.
748Currently CTL supports Direct Access (type 0), Processor (type 3)
749and CD/DVD (type 5) LUNs.
750The backend requested may or may not support all of the LUN types that CTL
751supports.
752.El
753.It Ic remove
754Remove a LUN.
755The backend must be specified, and the LUN number must also be specified.
756Backend-specific options may also be specified with the
757.Fl o
758flag.
759.Bl -tag -width 14n
760.It Fl b Ar backend
761Specify the backend that owns the LUN to be removed.
762Examples are
763.Dq ramdisk
764and
765.Dq block .
766.It Fl l Ar lun_id
767Specify the LUN number to remove.
768.It Fl o Ar name=value
769Specify a backend-specific name/value pair.
770Multiple
771.Fl o
772arguments may be specified.
773Refer to the backend documentation for arguments that may be used.
774.El
775.It Ic modify
776Modify a LUN size.
777The backend, the LUN number, and the size must be specified.
778.Bl -tag -width 14n
779.It Fl b Ar backend
780Specify the backend that owns the LUN to be modified.
781Examples are
782.Dq ramdisk
783and
784.Dq block .
785.It Fl l Ar lun_id
786Specify the LUN number to modify.
787.It Fl o Ar name=value
788Specify a backend-specific name/value pair.
789Multiple
790.Fl o
791arguments may be specified.
792Refer to the backend documentation for arguments that may be used.
793.It Fl s Ar size_bytes
794Specify the size of the LUN in bytes.
795For the
796.Dq block
797backend, an
798.Dq auto
799keyword may be passed instead; this will make CTL use the size of backing
800file or device.
801.El
802.It Ic devlist
803Get a list of all configured LUNs.
804This also includes the LUN size and blocksize, serial number and device ID.
805.Bl -tag -width 11n
806.It Fl b Ar backend
807Specify the backend.
808This restricts the LUN list to the named backend.
809Examples are
810.Dq ramdisk
811and
812.Dq block .
813.It Fl v
814Be verbose.
815This will also display any backend-specific LUN attributes in addition to
816the standard per-LUN information.
817.It Fl x
818Dump the raw XML.
819The LUN list information from the kernel comes in XML format, and this
820option allows the display of the raw XML data.
821This option and the
822.Fl v
823and
824.Fl b
825options are mutually exclusive.
826If you specify
827.Fl x ,
828the entire LUN database is displayed in XML format.
829.El
830.It Ic islist
831Get a list of currently running iSCSI sessions.
832This includes initiator and target names and the unique connection IDs.
833.Bl -tag -width 11n
834.It Fl v
835Verbose mode.
836.It Fl x
837Dump the raw XML.
838The sessions list information from the kernel comes in XML format, and this
839option allows the display of the raw XML data.
840.El
841.It Ic islogout
842Ask the initiator to log out iSCSI sessions matching criteria.
843.Bl -tag -width 11n
844.It Fl a
845Log out all sessions.
846.It Fl c
847Specify connection ID.
848.It Fl i
849Specify initiator name.
850.It Fl p
851Specify initiator portal (hostname or IP address).
852.El
853.It Ic isterminate
854Forcibly terminate iSCSI sessions matching criteria.
855.Bl -tag -width 11n
856.It Fl a
857Terminate all sessions.
858.It Fl c
859Specify connection ID.
860.It Fl i
861Specify initiator name.
862.It Fl p
863Specify initiator portal (hostname or IP address).
864.El
865.It Ic help
866Display
867.Nm
868usage information.
869.El
870.Sh OPTIONS
871Number of additional configuration options may be specified for LUNs.
872Some options are global, others are backend-specific.
873.Pp
874Global options:
875.Bl -tag -width 12n
876.It Va vendor
877Specifies LUN vendor string up to 8 chars.
878.It Va product
879Specifies LUN product string up to 16 chars.
880.It Va revision
881Specifies LUN revision string up to 4 chars.
882.It Va scsiname
883Specifies LUN SCSI name string.
884.It Va eui
885Specifies LUN EUI-64 identifier.
886.It Va naa
887Specifies LUN NAA identifier.
888.It Va uuid
889Specifies LUN locally assigned RFC 4122 UUID identifier.
890EUI, NAA or UUID identifier should be set to UNIQUE value to allow
891EXTENDED COPY command access the LUN.
892Non-unique LUN identifiers may lead to data corruption.
893Some initiators may not support later introduced UUID identifiers.
894.It Va ident_info
895Specified LUN identification information (string or 0x + hex).
896.It Va text_ident_info
897Specified LUN text identification information (UTF-8 string).
898.It Va ha_role
899Setting to "primary" or "secondary" overrides default role of the node
900in HA cluster, set by kern.cam.ctl.ha_role sysctl.
901.It Va insecure_tpc
902Setting to "on" allows EXTENDED COPY command sent to this LUN access
903other LUNs on this host, not accessible otherwise.
904This allows to offload copying between different iSCSI targets residing
905on the same host in trusted environments.
906.It Va readcache
907Set to "off", disables read caching for the LUN, if supported by the backend.
908.It Va readonly
909Set to "on", blocks all media write operations to the LUN, reporting it
910as write protected.
911.It Va removable
912Set to "on", makes LUN removable.
913.It Va reordering
914Set to "unrestricted", allows target to process commands with SIMPLE task
915attribute in arbitrary order.
916Any data integrity exposures related to command sequence order shall be
917explicitly handled by the application client through the selection of
918appropriate commands and task attributes.
919The default value is "restricted".
920It improves data integrity, but may introduce some additional delays.
921.It Va serseq
922Set to "on" to serialize consecutive reads/writes.
923Set to "read" to serialize consecutive reads.
924Set to "off" to allow them be issued in parallel.
925Parallel issue of consecutive operations may confuse logic of the
926backing file system, hurting performance; but it may improve performance
927of backing stores without prefetch/write-back.
928.It Va pblocksize
929.It Va pblockoffset
930Specify physical block size and offset of the device.
931.It Va ublocksize
932.It Va ublockoffset
933Specify UNMAP block size and offset of the device.
934.It Va rpm
935Specifies medium rotation rate of the device: 0 -- not reported,
9361 -- non-rotating (SSD), >1024 -- value in revolutions per minute.
937.It Va formfactor
938Specifies nominal form factor of the device: 0 -- not reported, 1 -- 5.25",
9392 -- 3.5", 3 -- 2.5", 4 -- 1.8", 5 -- less then 1.8".
940.It Va temperature
941.It Va reftemperature
942Specify current and reference (maximum) temperatures of the device.
943.It Va provisioning_type
944When UNMAP support is enabled, this option specifies provisioning type:
945"resource", "thin" or "unknown".
946Default value is "thin".
947Logical units without UNMAP support are reported as fully provisioned.
948.It Va unmap
949Setting to "on" or "off" controls UNMAP support for the logical unit.
950Default value is "on" if supported by the backend.
951.It Va unmap_max_lba
952.It Va unmap_max_descr
953Specify maximum allowed number of LBAs and block descriptors per UNMAP
954command to report in Block Limits VPD page.
955.It Va write_same_max_lba
956Specify maximum allowed number of LBAs per WRITE SAME command to report
957in Block Limits VPD page.
958.It Va avail-threshold
959.It Va used-threshold
960.It Va pool-avail-threshold
961.It Va pool-used-threshold
962Set per-LUN/-pool thin provisioning soft thresholds.
963LUN will establish UNIT ATTENTION condition if its or pool available space
964get below configured avail values, or its or pool used space get above
965configured used values.
966Pool thresholds are working only for ZVOL-backed LUNs.
967.It Va writecache
968Set to "off", disables write caching for the LUN, if supported by the backend.
969.El
970.Pp
971Options specific for block backend:
972.Bl -tag -width 12n
973.It Va file
974Specifies file or device name to use for backing store.
975.It Va num_threads
976Specifies number of backend threads to use for this LUN.
977.El
978.Pp
979Options specific for ramdisk backend:
980.Bl -tag -width 12n
981.It Va capacity
982Specifies capacity of backing store (maximum RAM for data).
983The default value is zero, that disables backing store completely,
984making all writes go to nowhere, while all reads return zeroes.
985.El
986.Sh EXAMPLES
987.Pp
988Send a
989.Tn SCSI
990TEST UNIT READY command to LUN 1.
991.Pp
992.Dl ctladm tur 1
993.Pp
994Display the list of mode pages supported by LUN 1.
995.Pp
996.Dl ctladm modesense 1 -l
997.Pp
998Display the saved version of the Control mode page (page 10) on LUN 0.
999Disable fetching block descriptors, and use a 10 byte MODE SENSE command
1000instead of the default 6 byte command.
1001.Pp
1002.Dl ctladm modesense 0 -m 10 -P 3 -d -c 10
1003.Pp
1004Read the first 512 byte block from LUN 2 and dump it to the file
1005.Bd -literal
1006.Dl ctladm read 2 -l 0 -d 1 -b 512 -f - > foo
1007.Ed
1008.Pp
1009Read 10240 bytes from the file
1010.Pa /tmp/bar
1011and write it to LUN 3.
1012starting at LBA 0xff432140.
1013.Pp
1014.Bd -literal
1015.Dl ctladm write 3 -l 0xff432140 -d 20 -b 512 -f /tmp/bar
1016.Ed
1017.Pp
1018Create a LUN with the
1019.Dq fake
1020ramdisk as a backing store.
1021The LUN will claim to have a size of approximately 10 terabytes,
1022while having no real data store (all written data are lost).
1023.Pp
1024.Dl ctladm create -b ramdisk -s 10485760000000000
1025.Pp
1026Create a thin provisioned LUN with a ramdisk as a backing store.
1027The LUN will have maximal backing store capacity of 10 gigabytes,
1028while reporting size of 10 terabytes,
1029.Pp
1030.Dl ctladm create -b ramdisk -s 10T -o capacity=10G
1031.Pp
1032Create a LUN using the block backend, and specify the file
1033.Pa src/usr.sbin/ctladm/ctladm.8
1034as the backing store.
1035The size of the LUN will be derived from the size of the file.
1036.Pp
1037.Dl ctladm create -b block -o file=src/usr.sbin/ctladm/ctladm.8
1038.Pp
1039Create a LUN using the block backend, specify the file
1040.Pa src/usr.sbin/ctladm/ctladm.8
1041as the backing store, and specify the
1042.Tn SCSI
1043VPD page 0x80 and 0x83 serial number
1044.Fl ( S )
1045and device ID
1046.Fl ( d ) .
1047.Pp
1048.Dl ctladm create -b block -o file=src/usr.sbin/ctladm/ctladm.8 -S MYSERIAL321 -d MYDEVID123
1049.Pp
1050Use to specify generic options on ioctl frontend port, now it is
1051only possible to set pp and/or vp port number.
1052.Pp
1053.Dl ctladm port -c -O pp=11 -O vp=12
1054.Pp
1055Remove specified targ_port.
1056.Pp
1057.Dl ctladm port -r -p 4
1058.Pp
1059.Pp
1060Remove LUN 12, which is handled by the block backend, from the system.
1061.Pp
1062.Dl ctladm remove -b block -l 12
1063.Pp
1064List configured LUNs in the system, along with their backend and serial
1065number.
1066This works when the Front End Target Drivers are enabled or disabled.
1067.Pp
1068.Dl ctladm devlist
1069.Pp
1070List all LUNs in the system, along with their inquiry data and device type.
1071This only works when the FETDs are enabled, since the commands go through the
1072ioctl port.
1073.Pp
1074.Dl ctladm lunlist
1075.Pp
1076Inject a medium error on LUN 6 for every read that covers the first 512
1077blocks of the LUN.
1078.Pp
1079.Dl ctladm inject 6 -i mediumerr -p read -r 0,512 -c
1080.Pp
1081Inject a custom error on LUN 6 for the next TEST UNIT READY command only.
1082This will result in a sense key of NOT READY (0x02), and an ASC/ASCQ of
10830x04,0x02 ("Logical unit not ready, initializing command required").
1084.Pp
1085.Bd -literal -offset indent
1086ctladm inject 6 -i custom -p tur -s 18 "f0 0 02 s12 04 02"
1087.Ed
1088.Sh SEE ALSO
1089.Xr cam 3 ,
1090.Xr cam_cdbparse 3 ,
1091.Xr cam 4 ,
1092.Xr ctl 4 ,
1093.Xr xpt 4 ,
1094.Xr camcontrol 8 ,
1095.Xr ctld 8 ,
1096.Xr ctlstat 8
1097.Sh HISTORY
1098The
1099.Nm
1100utility was originally written during the Winter/Spring of 2003 as an
1101interface to CTL.
1102.Sh AUTHORS
1103.An Ken Merry Aq Mt ken@FreeBSD.org
1104