Alexander Motin
0c05f0dc16
Replicate initiators WWPNs and names between HA peers.
2015-09-17 21:51:11 +00:00
Alexander Motin
54713bce25
Replicate port->init_devid to HA peer.
2015-09-17 20:36:34 +00:00
Alexander Motin
6213882769
When reporting TPT UA, report which of thresholds was reached.
2015-09-17 17:00:36 +00:00
Alexander Motin
042e9bdc41
Report number of failed XCOPY segment.
2015-09-17 14:22:52 +00:00
Alexander Motin
7f7bb97a0f
Report proper medium error code for VERIFY commands.
2015-09-17 12:52:18 +00:00
Alexander Motin
83981e319d
Fix reading after end of file for file-backed LUNs.
...
If backing file is smaller then the LUN size, we have to explicitly clear
the rest of the buffer to not leak some random data from previous I/Os.
2015-09-16 21:43:51 +00:00
Alexander Motin
d6043e4643
Make COMPARE AND WRITE report offset of difference.
2015-09-16 18:33:04 +00:00
Alexander Motin
5c5fb901eb
Frontends don't need to set errors themselves.
2015-09-16 13:25:35 +00:00
Alexander Motin
e2c3044b13
Don't flap the HA link if sysctl is reset to the same value.
2015-09-16 09:59:05 +00:00
Alexander Motin
18e87f95f7
Fix completion/error status reporting.
2015-09-15 10:42:53 +00:00
Alexander Motin
923863546a
Close potential race between datamove and HA failover.
2015-09-15 09:36:46 +00:00
Alexander Motin
d0f25804a7
Implement data/status aggregation for secondary HA node.
...
For short read requests this reduces latency by 30%, reporting command
completion after two interlink roundtrips instead of full three.
2015-09-14 15:21:23 +00:00
Alexander Motin
3ed019a919
Implement data/status aggregation for camsim backend.
...
This is almost pointless for primary HA node, but useful for secondary,
where between fe_datamove and fe_done calls goes another link roundtrip.
2015-09-14 15:15:32 +00:00
Alexander Motin
7b6660c9aa
Remove CTL_PRIV_LBA_LEN from HA messages.
...
Previously it was used for statistics, but now just a 16 extra bytes.
2015-09-14 09:56:01 +00:00
Alexander Motin
ceff31dc0c
Implement QUERY TASK, QUERY TASK SET and QUERY ASYNC EVENT.
...
Now we support most of SAM-5 task management.
2015-09-14 08:01:05 +00:00
Alexander Motin
bb978da493
Map CLEAR TASK SET and I_T NEXUS RESET for iSCSI.
...
The last should not be called without iSCSIProtocolLevel negotiation.
2015-09-13 20:40:00 +00:00
Alexander Motin
4cbc0bc5ae
Implement iSCSI TARGET COLD RESET task management function.
...
Implement it as CTL_TASK_TARGET_RESET plus termination of all sessions.
2015-09-13 20:22:18 +00:00
Alexander Motin
6187d4722a
Improve read-only support.
2015-09-13 16:49:41 +00:00
Alexander Motin
6b56dd0cfa
Reannounce port to HA peer if LUN map changed after online.
2015-09-13 15:31:55 +00:00
Alexander Motin
cfa0987386
Report INQUIRY DATA HAS CHANGED for related LUNs on port on-/offline.
2015-09-13 14:52:31 +00:00
Alexander Motin
eebde34629
Report CTL_UA_LUN_CHANGE on LUN map change.
2015-09-13 14:04:42 +00:00
Alexander Motin
844c2a3a94
Make TARGET RESET respect LUN mapping.
2015-09-13 13:00:20 +00:00
Alexander Motin
84e2fad15a
Check for obsolete NUL bin in CSCD descriptor.
2015-09-12 20:45:09 +00:00
Alexander Motin
051481a24e
Add HA support for CTL_TASK_I_T_NEXUS_RESET.
2015-09-12 20:06:22 +00:00
Alexander Motin
0a4c638188
Fix false CTL_UA_RES_RELEASE on secondary HA node.
2015-09-12 18:29:05 +00:00
Alexander Motin
a65a997fd9
Improve XCOPY error reporting.
2015-09-12 16:30:01 +00:00
Alexander Motin
238b6b7c75
Report that we have no limit on POPULATE TOKEN segment size.
2015-09-12 14:20:11 +00:00
Alexander Motin
eed0d596cf
Correct RTPG bitmask.
2015-09-12 13:53:41 +00:00
Alexander Motin
e184d2576a
Some HA polishing.
2015-09-12 12:46:04 +00:00
Alexander Motin
d36c617616
CTL documentation update, mostly for HA.
2015-09-12 10:23:23 +00:00
Alexander Motin
572846e089
Make ctld restart on primary HA node less invasive for secondary.
2015-09-11 14:47:35 +00:00
Alexander Motin
ee4ad294d2
Close races between device close and request processing.
...
All requests arriving for processing after OFFLINE flag set are rejected
with BUSY status. Races around OFFLINE flag setting are closed by calling
taskqueue_drain_all().
2015-09-11 14:33:05 +00:00
Alexander Motin
3236151ea8
Reference/release devices on every I/O, rather on open/close.
...
While this may be slower, it allows device destruction to complete,
rather then block waiting for indefinitely long time.
2015-09-11 12:50:52 +00:00
Alexander Motin
7ac58230ea
Reimplement CTL High Availability.
...
CTL HA functionality was originally implemented by Copan many years ago,
but large part of the sources was never published. This change includes
clean room implementation of the missing code and fixes for many bugs.
This code supports dual-node HA with ALUA in four modes:
- Active/Unavailable without interlink between nodes;
- Active/Standby with second node handling only basic LUN discovery and
reservation, synchronizing with the first node through the interlink;
- Active/Active with both nodes processing commands and accessing the
backing storage, synchronizing with the first node through the interlink;
- Active/Active with second node working as proxy, transfering all
commands to the first node for execution through the interlink.
Unlike original Copan's implementation, depending on specific hardware,
this code uses simple custom TCP-based protocol for interlink. It has
no authentication, so it should never be enabled on public interfaces.
The code may still need some polishing, but generally it is functional.
Relnotes: yes
Sponsored by: iXsystems, Inc.
2015-09-10 12:40:31 +00:00
Alexander Motin
fb606ebabc
Remove unused target and initiator IDs.
2015-09-10 10:46:21 +00:00
Alexander Motin
3f326305fc
Disable CTL_IO_DELAY feature.
...
It is too developer-oriented to be enabled by default.
2015-09-10 09:27:22 +00:00
Alexander Motin
a3977bea20
Allow LUN options modification via CTL_LUNREQ_MODIFY.
...
Not all changes take effect, but that is a different question.
2015-09-06 11:23:01 +00:00
Alexander Motin
0bcd4ab6ba
Move setting of media parameters inside open routines.
...
This is preparation for possibility to open/close media several times
per LUN life cycle. While there, rename variables to reduce confusion.
As additional bonus this allows to open read-only media, such as ZFS
snapshots.
2015-09-06 09:54:56 +00:00
Alexander Motin
bd236ba5c0
Remove some dead code.
2015-09-04 09:19:01 +00:00
Alexander Motin
420abfcecd
Small UA cleanup.
2015-09-03 12:56:57 +00:00
Alexander Motin
8be6a2df51
Fix copy-paste bug introduced in r275458.
...
MFC after: 3 days
2015-09-03 12:15:14 +00:00
Alexander Motin
1b7849d0f2
Make most of port methods optional and remove bunch of dummies.
2015-09-01 16:28:06 +00:00
Alexander Motin
7278725be5
Remove 600 bytes of port_priv from struct ctl_io_hdr.
...
This field used only for camtgt frontend, and once it any way preallocates
all requests, let it preallocate this memory too, not bothering core code.
2015-08-29 15:33:31 +00:00
Alexander Motin
f6295033c1
Fix type bug introduced at r286811.
2015-08-27 21:16:24 +00:00
Alexander Motin
a15bbf1508
Polish sizes processing.
2015-08-15 18:22:16 +00:00
Alexander Motin
67ceb24bca
Move "ioctl" CAM frontend into separate file.
...
It has nothing to share with too huge ctl.c other then device descriptor,
but even that may be counted as design error that may be fixed later.
At some point we may even want to have several ioctl ports.
2015-08-15 15:42:21 +00:00
Alexander Motin
2f444d157b
Drop "internal" CTL frontend.
...
Its idea was to be a simple initiator and execute several commands from
kernel level, but FreeBSD never had consumer for that functionality,
while its implementation polluted many unrelated places..
2015-08-15 13:34:38 +00:00
Alexander Motin
4ddb055594
Remove verbose CTL messages.
...
Reporting SCSI errors to console is often useless, pollutes logs and may
affect performance. For debugging there is kern.cam.ctl.debug sysctl
MFC after: 1 week
2015-08-09 09:54:29 +00:00
Alexander Motin
3301406331
Add more ifdefs to fix build with GCC after r286406.
2015-08-07 14:12:51 +00:00
Marcelo Araujo
8b3ae99560
Wrap some unused functions with notyet, it is necessary to be able to
...
build the modules/ctl directly.
Remove a dead MALLOC_DEFINE.
Differential Revision: D3329
Reviewed by: mav
Sponsored by: gandi.net
2015-08-07 08:30:43 +00:00