Alexander Motin
96b5475b7a
Pass task management response information from CTL through CAM to isp(4),
...
utilizing previously unused arg field of struct ccb_notify_acknowledge.
This makes new QUERY TASK, QUERY TASK SET and QUERY ASYNC EVENT requests
really functional for CAM target mode drivers.
2016-05-20 10:26:12 +00:00
Edward Tomasz Napierala
f41492b00f
Add icl_conn_connect() ICL method, required for iSER.
...
Obtained from: Mellanox Technologies (earlier version)
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
2016-05-17 11:10:44 +00:00
Alexander Motin
8fadf66094
Fix previous commit to report proper error code.
...
MFC after: 2 weeks
2016-05-10 08:37:41 +00:00
Alexander Motin
38618bf430
Validate XCOPY range offsets and lengths.
...
MFC after: 2 weeks
2016-05-10 08:28:16 +00:00
Alexander Motin
e13f4248db
More XCOPY parameters validation.
...
MFC after: 2 weeks
2016-05-10 08:08:39 +00:00
Alexander Motin
3eb7651aad
Improve validation of some POPULATE TOKEN parameters.
...
MFC after: 2 weeks
2016-05-10 07:14:49 +00:00
Pedro F. Giffuni
1ffe58516c
sys/cam: spelling fixes in comments.
...
No functional change.
2016-04-29 21:05:48 +00:00
Pedro F. Giffuni
167e63e394
cam: unsign some types to match their definitions and avoid overflows.
...
numpatterns is u_int.
ctl:
CTL_NUM_MODE_PAGES comes from sizeof().
In struct:ctl_scsiio, kern_sg_entries is uint32_t.
MFC after: 2 weeks
2016-04-27 15:35:05 +00:00
Sean Bruno
bbea316cc8
Plug memory leak in ctl(4) when ctl_copyin_args() is called with a non-
...
null terminated ASCII string.
PR: 207626
Submitted by: cturt@hardenedbsd.org
MFC after: 2 days
2016-04-19 16:48:14 +00:00
Pedro F. Giffuni
74b8d63dcc
Cleanup unnecessary semicolons from the kernel.
...
Found with devel/coccinelle.
2016-04-10 23:07:00 +00:00
Warner Losh
a2531862b8
Move to new value for XPT_GET_SIM_KNOB to avoid clash with XPT_ATA_IO.
2016-03-10 06:25:05 +00:00
Alexander Motin
1a686265ee
Set bhsdi_target_transfer_tag to reserved value, which is 0xffffffff.
...
This should be a purely cosmetic change.
2016-03-04 19:57:11 +00:00
Edward Tomasz Napierala
c5805a3deb
Remove stray semicolons from the iSCSI code.
...
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
2016-02-10 17:55:39 +00:00
Alexander Motin
72cc93767c
Hide "soconnect() error" messages under bootverbose.
...
They can be too noisy.
2016-01-22 09:32:19 +00:00
Konstantin Belousov
ee1988938c
Convert sys/cam to use make_dev_s().
...
Reviewed by: hps, jhb
Sponsored by: The FreeBSD Foundation
MFC after: 3 weeks
Differential revision: https://reviews.freebsd.org/D4746
2016-01-07 20:22:55 +00:00
Mark Johnston
3616095801
Fix style issues around existing SDT probes.
...
- Use SDT_PROBE<N>() instead of SDT_PROBE(). This has no functional effect
at the moment, but will be needed for some future changes.
- Don't hardcode the module component of the probe identifier. This is
set automatically by the SDT framework.
MFC after: 1 week
2015-12-16 23:39:27 +00:00
Alexander Motin
1e6a6c096e
Set DS flag, required for LPB log page by spec.
...
MFC after: 1 week
2015-12-15 21:19:32 +00:00
Alexander Motin
2d80af4f4a
Fix panic when trying to sort unsupported command in OOA queue.
...
Handle unsupported commands as not conflicting/blocking.
2015-11-27 14:29:04 +00:00
Alexander Motin
9f72f0ee52
Add NULL check to make Coverity happy.
2015-11-14 14:56:01 +00:00
Alexander Motin
6bd364b523
Modify target port groups logic in CTL.
...
- Introduce "ha_shared" port option, which being set to "on" moves the
port into separate port group, shared between HA nodes. This allows to
better handle cases when iSCSI portals are bound to CARP address that can
dynamically move between nodes. Some initiators (at least VMware) don't
detect that after iSCSI reconnect they've attached to different SCSI port
from different port group, that totally breakes ALUA status parsing.
In theory, I believe, it should be enough to have different iSCSI portal
group tags on different nodes to make initiators detect this condition,
but it seems like VMware ignores those values, and even full LUN retaste
forced by UA does not help.
- Make CTL report up to three port groups: 1 -- non-HA mode or ports
with "ha_shared" option set, 2 -- HA node 1, 3 -- HA node 2.
- Report Transitioning state for all port groups when HA interlink is
connected, but neither of nodes is primary for the LUN.
MFC after: 2 weeks
2015-11-11 13:18:38 +00:00
Alexander Motin
5b9676b17b
Add two more KASSERTs.
2015-11-06 17:29:21 +00:00
Alexander Motin
10643dd70e
Don't try to replicate mode pages not present on this device.
...
MFC after: 3 days
2015-10-26 14:14:56 +00:00
Alexander Motin
59f063d549
Give CTL support for PIM_EXTLUNS when talking to CAM.
...
CTL itself still lives in flat LUN space, but it can generate extended
numbers if CAM SIM reports such capability.
2015-10-24 17:24:19 +00:00
Alexander Motin
c98d2b1f1e
Add partial support for QUERY TMF to CAM and isp(4).
...
This change allows to decode respective functions in isp(4) in target mode
and pass them through CAM to CTL. Unfortunately neither CAM nor isp(4)
support returning response info for those task management functions now.
On the other side I just have no initiator to test this functionality.
2015-10-23 18:34:18 +00:00
Alexander Motin
aeb1faa040
Fix LUN disable in CAM broken at r285155.
...
MFC after: 1 week
2015-10-23 10:39:43 +00:00
Alexander Motin
5124012aae
Make some panic strings mode informative.
2015-10-21 15:31:26 +00:00
Alexander Motin
361e885315
Remove lock upgrade attempt from ctl_be_block_open_file().
...
I am not sure what for it was done. Now open routine should automatically
fall back to read-only if open for writing is impossible. In such case
attempt to upgrade to write sounds strange.
MFC after: 1 week
2015-10-11 08:28:49 +00:00
Alexander Motin
3d5cb709bd
Add missing vnode lock in case of file modify request.
...
Submitted by: Richard Kojedzinszky
MFC after: 1 week
2015-10-08 07:34:30 +00:00
Alexander Motin
0952a19f7d
More aggressively fill WUT read pipeline.
...
On some tests I've measured 5% copy speedup from this.
2015-10-01 19:07:15 +00:00
Alexander Motin
6ac1446d0e
Make zero WUT use WRITE SAME with recently allowed NDOB flag.
2015-10-01 16:30:20 +00:00
Alexander Motin
f24b1dc90c
Implement SPC-3 exceptions to SPC-2 RESERVE and RELEASE behavior.
2015-10-01 12:57:37 +00:00
Alexander Motin
f53270c858
Unify PR variable names to reduce confusion.
2015-10-01 12:15:36 +00:00
Alexander Motin
f5a2bbe6d6
Use proper STAILQ_* macros where possible.
2015-09-30 20:38:35 +00:00
Alexander Motin
66b6967686
Really implement PREVENT ALLOW MEDIUM REMOVAL command.
2015-09-29 15:12:40 +00:00
Alexander Motin
7f3d6f1fe3
Don't report SYNC_NV bit set in SYNCHRONIZE CACHE as error.
...
While this bit is obsolete in SBC-3, behavior controlled by it is allowed
on device discretion.
2015-09-29 13:58:27 +00:00
Alexander Motin
862aedb0d6
Fix arguments order.
2015-09-29 12:53:41 +00:00
Alexander Motin
6908da41fa
Report that we can read all flavours of DVD. Why not?
2015-09-29 10:44:37 +00:00
Alexander Motin
d6e7f6e741
Add CD/DVD Capabilities and Mechanical Status Page.
...
This page is obsolete since MMC-4, but still used by some software.
2015-09-29 09:09:37 +00:00
Alexander Motin
648dfc1a29
Umplement media load/eject support for removable devices.
...
In case of block backend eject really closes the backing store, while
load tries to open it back. Failed store open is reported as no media.
2015-09-28 20:54:18 +00:00
Alexander Motin
91be33dc78
Add to CTL initial support for CDROMs and removable devices.
...
Relnotes: yes
2015-09-27 13:47:28 +00:00
Alexander Motin
2e33ae99cf
Allow LOG SENSE command on non-disk devices.
2015-09-26 13:51:29 +00:00
Alexander Motin
0b33261bbe
Remove concept of control device.
2015-09-26 12:53:55 +00:00
Alexander Motin
6bff2b5bff
Move ioctl frontend defines where they belong.
2015-09-26 11:56:28 +00:00
Alexander Motin
d3ab449cfa
Remove few more unused variables.
2015-09-26 11:39:54 +00:00
Alexander Motin
9c887a4f86
Remove some duplicate, legacy, dead and questionable code.
2015-09-26 11:28:45 +00:00
Alexander Motin
0bb9989c43
Pass to sobind() copy of the address, not the original.
2015-09-26 01:23:29 +00:00
Alexander Motin
86b7954b92
Properly lock LUN in ctl_failover_lun().
2015-09-25 22:45:23 +00:00
Alexander Motin
f44570f617
Fix bit masks changed for the wrong commands in r288221.
2015-09-25 19:46:34 +00:00
Alexander Motin
5d4dfee032
Constify ctl_serialize_table.
2015-09-25 18:49:25 +00:00
Alexander Motin
c30a4c1871
Remove some dead code found by Clang analyzer.
2015-09-25 18:15:34 +00:00