target_core_sbc.c 36 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /*
  3. * SCSI Block Commands (SBC) parsing and emulation.
  4. *
  5. * (c) Copyright 2002-2013 Datera, Inc.
  6. *
  7. * Nicholas A. Bellinger <nab@kernel.org>
  8. */
  9. #include <linux/kernel.h>
  10. #include <linux/module.h>
  11. #include <linux/ratelimit.h>
  12. #include <linux/crc-t10dif.h>
  13. #include <linux/t10-pi.h>
  14. #include <linux/unaligned.h>
  15. #include <scsi/scsi_proto.h>
  16. #include <scsi/scsi_tcq.h>
  17. #include <target/target_core_base.h>
  18. #include <target/target_core_backend.h>
  19. #include <target/target_core_fabric.h>
  20. #include "target_core_internal.h"
  21. #include "target_core_ua.h"
  22. #include "target_core_alua.h"
  23. static sense_reason_t
  24. sbc_check_prot(struct se_device *, struct se_cmd *, unsigned char, u32, bool);
  25. static sense_reason_t sbc_execute_unmap(struct se_cmd *cmd);
  26. static sense_reason_t
  27. sbc_emulate_readcapacity(struct se_cmd *cmd)
  28. {
  29. struct se_device *dev = cmd->se_dev;
  30. unsigned char *cdb = cmd->t_task_cdb;
  31. unsigned long long blocks_long = dev->transport->get_blocks(dev);
  32. unsigned char *rbuf;
  33. unsigned char buf[8];
  34. u32 blocks;
  35. /*
  36. * SBC-2 says:
  37. * If the PMI bit is set to zero and the LOGICAL BLOCK
  38. * ADDRESS field is not set to zero, the device server shall
  39. * terminate the command with CHECK CONDITION status with
  40. * the sense key set to ILLEGAL REQUEST and the additional
  41. * sense code set to INVALID FIELD IN CDB.
  42. *
  43. * In SBC-3, these fields are obsolete, but some SCSI
  44. * compliance tests actually check this, so we might as well
  45. * follow SBC-2.
  46. */
  47. if (!(cdb[8] & 1) && !!(cdb[2] | cdb[3] | cdb[4] | cdb[5]))
  48. return TCM_INVALID_CDB_FIELD;
  49. if (blocks_long >= 0x00000000ffffffff)
  50. blocks = 0xffffffff;
  51. else
  52. blocks = (u32)blocks_long;
  53. put_unaligned_be32(blocks, &buf[0]);
  54. put_unaligned_be32(dev->dev_attrib.block_size, &buf[4]);
  55. rbuf = transport_kmap_data_sg(cmd);
  56. if (rbuf) {
  57. memcpy(rbuf, buf, min_t(u32, sizeof(buf), cmd->data_length));
  58. transport_kunmap_data_sg(cmd);
  59. }
  60. target_complete_cmd_with_length(cmd, SAM_STAT_GOOD, 8);
  61. return 0;
  62. }
  63. static sense_reason_t
  64. sbc_emulate_readcapacity_16(struct se_cmd *cmd)
  65. {
  66. struct se_device *dev = cmd->se_dev;
  67. struct se_session *sess = cmd->se_sess;
  68. int pi_prot_type = dev->dev_attrib.pi_prot_type;
  69. unsigned char *rbuf;
  70. unsigned char buf[32];
  71. unsigned long long blocks = dev->transport->get_blocks(dev);
  72. memset(buf, 0, sizeof(buf));
  73. put_unaligned_be64(blocks, &buf[0]);
  74. put_unaligned_be32(dev->dev_attrib.block_size, &buf[8]);
  75. /*
  76. * Set P_TYPE and PROT_EN bits for DIF support
  77. */
  78. if (sess->sup_prot_ops & (TARGET_PROT_DIN_PASS | TARGET_PROT_DOUT_PASS)) {
  79. /*
  80. * Only override a device's pi_prot_type if no T10-PI is
  81. * available, and sess_prot_type has been explicitly enabled.
  82. */
  83. if (!pi_prot_type)
  84. pi_prot_type = sess->sess_prot_type;
  85. if (pi_prot_type)
  86. buf[12] = (pi_prot_type - 1) << 1 | 0x1;
  87. }
  88. if (dev->transport->get_lbppbe)
  89. buf[13] = dev->transport->get_lbppbe(dev) & 0x0f;
  90. if (dev->transport->get_alignment_offset_lbas) {
  91. u16 lalba = dev->transport->get_alignment_offset_lbas(dev);
  92. put_unaligned_be16(lalba, &buf[14]);
  93. }
  94. /*
  95. * Set Thin Provisioning Enable bit following sbc3r22 in section
  96. * READ CAPACITY (16) byte 14 if emulate_tpu or emulate_tpws is enabled.
  97. */
  98. if (dev->dev_attrib.emulate_tpu || dev->dev_attrib.emulate_tpws) {
  99. buf[14] |= 0x80;
  100. /*
  101. * LBPRZ signifies that zeroes will be read back from an LBA after
  102. * an UNMAP or WRITE SAME w/ unmap bit (sbc3r36 5.16.2)
  103. */
  104. if (dev->dev_attrib.unmap_zeroes_data)
  105. buf[14] |= 0x40;
  106. }
  107. rbuf = transport_kmap_data_sg(cmd);
  108. if (rbuf) {
  109. memcpy(rbuf, buf, min_t(u32, sizeof(buf), cmd->data_length));
  110. transport_kunmap_data_sg(cmd);
  111. }
  112. target_complete_cmd_with_length(cmd, SAM_STAT_GOOD, 32);
  113. return 0;
  114. }
  115. static sense_reason_t
  116. sbc_emulate_startstop(struct se_cmd *cmd)
  117. {
  118. unsigned char *cdb = cmd->t_task_cdb;
  119. /*
  120. * See sbc3r36 section 5.25
  121. * Immediate bit should be set since there is nothing to complete
  122. * POWER CONDITION MODIFIER 0h
  123. */
  124. if (!(cdb[1] & 1) || cdb[2] || cdb[3])
  125. return TCM_INVALID_CDB_FIELD;
  126. /*
  127. * See sbc3r36 section 5.25
  128. * POWER CONDITION 0h START_VALID - process START and LOEJ
  129. */
  130. if (cdb[4] >> 4 & 0xf)
  131. return TCM_INVALID_CDB_FIELD;
  132. /*
  133. * See sbc3r36 section 5.25
  134. * LOEJ 0h - nothing to load or unload
  135. * START 1h - we are ready
  136. */
  137. if (!(cdb[4] & 1) || (cdb[4] & 2) || (cdb[4] & 4))
  138. return TCM_INVALID_CDB_FIELD;
  139. target_complete_cmd(cmd, SAM_STAT_GOOD);
  140. return 0;
  141. }
  142. sector_t sbc_get_write_same_sectors(struct se_cmd *cmd)
  143. {
  144. u32 num_blocks;
  145. if (cmd->t_task_cdb[0] == WRITE_SAME)
  146. num_blocks = get_unaligned_be16(&cmd->t_task_cdb[7]);
  147. else if (cmd->t_task_cdb[0] == WRITE_SAME_16)
  148. num_blocks = get_unaligned_be32(&cmd->t_task_cdb[10]);
  149. else /* WRITE_SAME_32 via VARIABLE_LENGTH_CMD */
  150. num_blocks = get_unaligned_be32(&cmd->t_task_cdb[28]);
  151. /*
  152. * Use the explicit range when non zero is supplied, otherwise calculate
  153. * the remaining range based on ->get_blocks() - starting LBA.
  154. */
  155. if (num_blocks)
  156. return num_blocks;
  157. return cmd->se_dev->transport->get_blocks(cmd->se_dev) -
  158. cmd->t_task_lba + 1;
  159. }
  160. EXPORT_SYMBOL(sbc_get_write_same_sectors);
  161. static sense_reason_t
  162. sbc_execute_write_same_unmap(struct se_cmd *cmd)
  163. {
  164. struct exec_cmd_ops *ops = cmd->protocol_data;
  165. sector_t nolb = sbc_get_write_same_sectors(cmd);
  166. sense_reason_t ret;
  167. if (nolb) {
  168. ret = ops->execute_unmap(cmd, cmd->t_task_lba, nolb);
  169. if (ret)
  170. return ret;
  171. }
  172. target_complete_cmd(cmd, SAM_STAT_GOOD);
  173. return 0;
  174. }
  175. static sense_reason_t
  176. sbc_emulate_noop(struct se_cmd *cmd)
  177. {
  178. target_complete_cmd(cmd, SAM_STAT_GOOD);
  179. return 0;
  180. }
  181. static inline u32 sbc_get_size(struct se_cmd *cmd, u32 sectors)
  182. {
  183. return cmd->se_dev->dev_attrib.block_size * sectors;
  184. }
  185. static inline u32 transport_get_sectors_6(unsigned char *cdb)
  186. {
  187. /*
  188. * Use 8-bit sector value. SBC-3 says:
  189. *
  190. * A TRANSFER LENGTH field set to zero specifies that 256
  191. * logical blocks shall be written. Any other value
  192. * specifies the number of logical blocks that shall be
  193. * written.
  194. */
  195. return cdb[4] ? : 256;
  196. }
  197. static inline u32 transport_get_sectors_10(unsigned char *cdb)
  198. {
  199. return get_unaligned_be16(&cdb[7]);
  200. }
  201. static inline u32 transport_get_sectors_12(unsigned char *cdb)
  202. {
  203. return get_unaligned_be32(&cdb[6]);
  204. }
  205. static inline u32 transport_get_sectors_16(unsigned char *cdb)
  206. {
  207. return get_unaligned_be32(&cdb[10]);
  208. }
  209. /*
  210. * Used for VARIABLE_LENGTH_CDB WRITE_32 and READ_32 variants
  211. */
  212. static inline u32 transport_get_sectors_32(unsigned char *cdb)
  213. {
  214. return get_unaligned_be32(&cdb[28]);
  215. }
  216. static inline u32 transport_lba_21(unsigned char *cdb)
  217. {
  218. return get_unaligned_be24(&cdb[1]) & 0x1fffff;
  219. }
  220. static inline u32 transport_lba_32(unsigned char *cdb)
  221. {
  222. return get_unaligned_be32(&cdb[2]);
  223. }
  224. static inline unsigned long long transport_lba_64(unsigned char *cdb)
  225. {
  226. return get_unaligned_be64(&cdb[2]);
  227. }
  228. static sense_reason_t
  229. sbc_setup_write_same(struct se_cmd *cmd, unsigned char flags,
  230. struct exec_cmd_ops *ops)
  231. {
  232. struct se_device *dev = cmd->se_dev;
  233. sector_t end_lba = dev->transport->get_blocks(dev) + 1;
  234. unsigned int sectors = sbc_get_write_same_sectors(cmd);
  235. sense_reason_t ret;
  236. if ((flags & 0x04) || (flags & 0x02)) {
  237. pr_err("WRITE_SAME PBDATA and LBDATA"
  238. " bits not supported for Block Discard"
  239. " Emulation\n");
  240. return TCM_UNSUPPORTED_SCSI_OPCODE;
  241. }
  242. if (sectors > cmd->se_dev->dev_attrib.max_write_same_len) {
  243. pr_warn("WRITE_SAME sectors: %u exceeds max_write_same_len: %u\n",
  244. sectors, cmd->se_dev->dev_attrib.max_write_same_len);
  245. return TCM_INVALID_CDB_FIELD;
  246. }
  247. /*
  248. * Sanity check for LBA wrap and request past end of device.
  249. */
  250. if (((cmd->t_task_lba + sectors) < cmd->t_task_lba) ||
  251. ((cmd->t_task_lba + sectors) > end_lba)) {
  252. pr_err("WRITE_SAME exceeds last lba %llu (lba %llu, sectors %u)\n",
  253. (unsigned long long)end_lba, cmd->t_task_lba, sectors);
  254. return TCM_ADDRESS_OUT_OF_RANGE;
  255. }
  256. /* We always have ANC_SUP == 0 so setting ANCHOR is always an error */
  257. if (flags & 0x10) {
  258. pr_warn("WRITE SAME with ANCHOR not supported\n");
  259. return TCM_INVALID_CDB_FIELD;
  260. }
  261. if (flags & 0x01) {
  262. pr_warn("WRITE SAME with NDOB not supported\n");
  263. return TCM_INVALID_CDB_FIELD;
  264. }
  265. /*
  266. * Special case for WRITE_SAME w/ UNMAP=1 that ends up getting
  267. * translated into block discard requests within backend code.
  268. */
  269. if (flags & 0x08) {
  270. if (!ops->execute_unmap)
  271. return TCM_UNSUPPORTED_SCSI_OPCODE;
  272. if (!dev->dev_attrib.emulate_tpws) {
  273. pr_err("Got WRITE_SAME w/ UNMAP=1, but backend device"
  274. " has emulate_tpws disabled\n");
  275. return TCM_UNSUPPORTED_SCSI_OPCODE;
  276. }
  277. cmd->execute_cmd = sbc_execute_write_same_unmap;
  278. return 0;
  279. }
  280. if (!ops->execute_write_same)
  281. return TCM_UNSUPPORTED_SCSI_OPCODE;
  282. ret = sbc_check_prot(dev, cmd, flags >> 5, sectors, true);
  283. if (ret)
  284. return ret;
  285. cmd->execute_cmd = ops->execute_write_same;
  286. return 0;
  287. }
  288. static sense_reason_t
  289. sbc_execute_rw(struct se_cmd *cmd)
  290. {
  291. struct exec_cmd_ops *ops = cmd->protocol_data;
  292. return ops->execute_rw(cmd, cmd->t_data_sg, cmd->t_data_nents,
  293. cmd->data_direction);
  294. }
  295. static sense_reason_t compare_and_write_post(struct se_cmd *cmd, bool success,
  296. int *post_ret)
  297. {
  298. struct se_device *dev = cmd->se_dev;
  299. sense_reason_t ret = TCM_NO_SENSE;
  300. spin_lock_irq(&cmd->t_state_lock);
  301. if (success) {
  302. *post_ret = 1;
  303. if (cmd->scsi_status == SAM_STAT_CHECK_CONDITION)
  304. ret = TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE;
  305. }
  306. spin_unlock_irq(&cmd->t_state_lock);
  307. /*
  308. * Unlock ->caw_sem originally obtained during sbc_compare_and_write()
  309. * before the original READ I/O submission.
  310. */
  311. up(&dev->caw_sem);
  312. return ret;
  313. }
  314. /*
  315. * compare @cmp_len bytes of @read_sgl with @cmp_sgl. On miscompare, fill
  316. * @miscmp_off and return TCM_MISCOMPARE_VERIFY.
  317. */
  318. static sense_reason_t
  319. compare_and_write_do_cmp(struct scatterlist *read_sgl, unsigned int read_nents,
  320. struct scatterlist *cmp_sgl, unsigned int cmp_nents,
  321. unsigned int cmp_len, unsigned int *miscmp_off)
  322. {
  323. unsigned char *buf = NULL;
  324. struct scatterlist *sg;
  325. sense_reason_t ret;
  326. unsigned int offset;
  327. size_t rc;
  328. int sg_cnt;
  329. buf = kzalloc(cmp_len, GFP_KERNEL);
  330. if (!buf) {
  331. ret = TCM_OUT_OF_RESOURCES;
  332. goto out;
  333. }
  334. rc = sg_copy_to_buffer(cmp_sgl, cmp_nents, buf, cmp_len);
  335. if (!rc) {
  336. pr_err("sg_copy_to_buffer() failed for compare_and_write\n");
  337. ret = TCM_OUT_OF_RESOURCES;
  338. goto out;
  339. }
  340. /*
  341. * Compare SCSI READ payload against verify payload
  342. */
  343. offset = 0;
  344. ret = TCM_NO_SENSE;
  345. for_each_sg(read_sgl, sg, read_nents, sg_cnt) {
  346. unsigned int len = min(sg->length, cmp_len);
  347. unsigned char *addr = kmap_atomic(sg_page(sg));
  348. if (memcmp(addr, buf + offset, len)) {
  349. unsigned int i;
  350. for (i = 0; i < len && addr[i] == buf[offset + i]; i++)
  351. ;
  352. *miscmp_off = offset + i;
  353. pr_warn("Detected MISCOMPARE at offset %u\n",
  354. *miscmp_off);
  355. ret = TCM_MISCOMPARE_VERIFY;
  356. }
  357. kunmap_atomic(addr);
  358. if (ret != TCM_NO_SENSE)
  359. goto out;
  360. offset += len;
  361. cmp_len -= len;
  362. if (!cmp_len)
  363. break;
  364. }
  365. pr_debug("COMPARE AND WRITE read data matches compare data\n");
  366. out:
  367. kfree(buf);
  368. return ret;
  369. }
  370. static sense_reason_t compare_and_write_callback(struct se_cmd *cmd, bool success,
  371. int *post_ret)
  372. {
  373. struct se_device *dev = cmd->se_dev;
  374. struct sg_table write_tbl = { };
  375. struct scatterlist *write_sg;
  376. struct sg_mapping_iter m;
  377. unsigned int len;
  378. unsigned int block_size = dev->dev_attrib.block_size;
  379. unsigned int compare_len = (cmd->t_task_nolb * block_size);
  380. unsigned int miscmp_off = 0;
  381. sense_reason_t ret = TCM_NO_SENSE;
  382. int i;
  383. if (!success) {
  384. /*
  385. * Handle early failure in transport_generic_request_failure(),
  386. * which will not have taken ->caw_sem yet..
  387. */
  388. if (!cmd->t_data_sg || !cmd->t_bidi_data_sg)
  389. return TCM_NO_SENSE;
  390. /*
  391. * The command has been stopped or aborted so
  392. * we don't have to perform the write operation.
  393. */
  394. WARN_ON(!(cmd->transport_state &
  395. (CMD_T_ABORTED | CMD_T_STOP)));
  396. goto out;
  397. }
  398. /*
  399. * Handle special case for zero-length COMPARE_AND_WRITE
  400. */
  401. if (!cmd->data_length)
  402. goto out;
  403. /*
  404. * Immediately exit + release dev->caw_sem if command has already
  405. * been failed with a non-zero SCSI status.
  406. */
  407. if (cmd->scsi_status) {
  408. pr_debug("compare_and_write_callback: non zero scsi_status:"
  409. " 0x%02x\n", cmd->scsi_status);
  410. *post_ret = 1;
  411. if (cmd->scsi_status == SAM_STAT_CHECK_CONDITION)
  412. ret = TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE;
  413. goto out;
  414. }
  415. ret = compare_and_write_do_cmp(cmd->t_bidi_data_sg,
  416. cmd->t_bidi_data_nents,
  417. cmd->t_data_sg,
  418. cmd->t_data_nents,
  419. compare_len,
  420. &miscmp_off);
  421. if (ret == TCM_MISCOMPARE_VERIFY) {
  422. /*
  423. * SBC-4 r15: 5.3 COMPARE AND WRITE command
  424. * In the sense data (see 4.18 and SPC-5) the offset from the
  425. * start of the Data-Out Buffer to the first byte of data that
  426. * was not equal shall be reported in the INFORMATION field.
  427. */
  428. cmd->sense_info = miscmp_off;
  429. goto out;
  430. } else if (ret)
  431. goto out;
  432. if (sg_alloc_table(&write_tbl, cmd->t_data_nents, GFP_KERNEL) < 0) {
  433. pr_err("Unable to allocate compare_and_write sg\n");
  434. ret = TCM_OUT_OF_RESOURCES;
  435. goto out;
  436. }
  437. write_sg = write_tbl.sgl;
  438. i = 0;
  439. len = compare_len;
  440. sg_miter_start(&m, cmd->t_data_sg, cmd->t_data_nents, SG_MITER_TO_SG);
  441. /*
  442. * Currently assumes NoLB=1 and SGLs are PAGE_SIZE..
  443. */
  444. while (len) {
  445. sg_miter_next(&m);
  446. if (block_size < PAGE_SIZE) {
  447. sg_set_page(&write_sg[i], m.page, block_size,
  448. m.piter.sg->offset + block_size);
  449. } else {
  450. sg_miter_next(&m);
  451. sg_set_page(&write_sg[i], m.page, block_size,
  452. m.piter.sg->offset);
  453. }
  454. len -= block_size;
  455. i++;
  456. }
  457. sg_miter_stop(&m);
  458. /*
  459. * Save the original SGL + nents values before updating to new
  460. * assignments, to be released in transport_free_pages() ->
  461. * transport_reset_sgl_orig()
  462. */
  463. cmd->t_data_sg_orig = cmd->t_data_sg;
  464. cmd->t_data_sg = write_sg;
  465. cmd->t_data_nents_orig = cmd->t_data_nents;
  466. cmd->t_data_nents = 1;
  467. cmd->sam_task_attr = TCM_HEAD_TAG;
  468. cmd->transport_complete_callback = compare_and_write_post;
  469. /*
  470. * Now reset ->execute_cmd() to the normal sbc_execute_rw() handler
  471. * for submitting the adjusted SGL to write instance user-data.
  472. */
  473. cmd->execute_cmd = sbc_execute_rw;
  474. spin_lock_irq(&cmd->t_state_lock);
  475. cmd->t_state = TRANSPORT_PROCESSING;
  476. cmd->transport_state |= CMD_T_ACTIVE | CMD_T_SENT;
  477. spin_unlock_irq(&cmd->t_state_lock);
  478. __target_execute_cmd(cmd, false);
  479. return ret;
  480. out:
  481. /*
  482. * In the MISCOMPARE or failure case, unlock ->caw_sem obtained in
  483. * sbc_compare_and_write() before the original READ I/O submission.
  484. */
  485. up(&dev->caw_sem);
  486. sg_free_table(&write_tbl);
  487. return ret;
  488. }
  489. static sense_reason_t
  490. sbc_compare_and_write(struct se_cmd *cmd)
  491. {
  492. struct exec_cmd_ops *ops = cmd->protocol_data;
  493. struct se_device *dev = cmd->se_dev;
  494. sense_reason_t ret;
  495. int rc;
  496. /*
  497. * Submit the READ first for COMPARE_AND_WRITE to perform the
  498. * comparision using SGLs at cmd->t_bidi_data_sg..
  499. */
  500. rc = down_interruptible(&dev->caw_sem);
  501. if (rc != 0) {
  502. cmd->transport_complete_callback = NULL;
  503. return TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE;
  504. }
  505. /*
  506. * Reset cmd->data_length to individual block_size in order to not
  507. * confuse backend drivers that depend on this value matching the
  508. * size of the I/O being submitted.
  509. */
  510. cmd->data_length = cmd->t_task_nolb * dev->dev_attrib.block_size;
  511. ret = ops->execute_rw(cmd, cmd->t_bidi_data_sg, cmd->t_bidi_data_nents,
  512. DMA_FROM_DEVICE);
  513. if (ret) {
  514. cmd->transport_complete_callback = NULL;
  515. up(&dev->caw_sem);
  516. return ret;
  517. }
  518. /*
  519. * Unlock of dev->caw_sem to occur in compare_and_write_callback()
  520. * upon MISCOMPARE, or in compare_and_write_done() upon completion
  521. * of WRITE instance user-data.
  522. */
  523. return TCM_NO_SENSE;
  524. }
  525. static int
  526. sbc_set_prot_op_checks(u8 protect, bool fabric_prot, enum target_prot_type prot_type,
  527. bool is_write, struct se_cmd *cmd)
  528. {
  529. if (is_write) {
  530. cmd->prot_op = fabric_prot ? TARGET_PROT_DOUT_STRIP :
  531. protect ? TARGET_PROT_DOUT_PASS :
  532. TARGET_PROT_DOUT_INSERT;
  533. switch (protect) {
  534. case 0x0:
  535. case 0x3:
  536. cmd->prot_checks = 0;
  537. break;
  538. case 0x1:
  539. case 0x5:
  540. cmd->prot_checks = TARGET_DIF_CHECK_GUARD;
  541. if (prot_type == TARGET_DIF_TYPE1_PROT)
  542. cmd->prot_checks |= TARGET_DIF_CHECK_REFTAG;
  543. break;
  544. case 0x2:
  545. if (prot_type == TARGET_DIF_TYPE1_PROT)
  546. cmd->prot_checks = TARGET_DIF_CHECK_REFTAG;
  547. break;
  548. case 0x4:
  549. cmd->prot_checks = TARGET_DIF_CHECK_GUARD;
  550. break;
  551. default:
  552. pr_err("Unsupported protect field %d\n", protect);
  553. return -EINVAL;
  554. }
  555. } else {
  556. cmd->prot_op = fabric_prot ? TARGET_PROT_DIN_INSERT :
  557. protect ? TARGET_PROT_DIN_PASS :
  558. TARGET_PROT_DIN_STRIP;
  559. switch (protect) {
  560. case 0x0:
  561. case 0x1:
  562. case 0x5:
  563. cmd->prot_checks = TARGET_DIF_CHECK_GUARD;
  564. if (prot_type == TARGET_DIF_TYPE1_PROT)
  565. cmd->prot_checks |= TARGET_DIF_CHECK_REFTAG;
  566. break;
  567. case 0x2:
  568. if (prot_type == TARGET_DIF_TYPE1_PROT)
  569. cmd->prot_checks = TARGET_DIF_CHECK_REFTAG;
  570. break;
  571. case 0x3:
  572. cmd->prot_checks = 0;
  573. break;
  574. case 0x4:
  575. cmd->prot_checks = TARGET_DIF_CHECK_GUARD;
  576. break;
  577. default:
  578. pr_err("Unsupported protect field %d\n", protect);
  579. return -EINVAL;
  580. }
  581. }
  582. return 0;
  583. }
  584. static sense_reason_t
  585. sbc_check_prot(struct se_device *dev, struct se_cmd *cmd, unsigned char protect,
  586. u32 sectors, bool is_write)
  587. {
  588. int sp_ops = cmd->se_sess->sup_prot_ops;
  589. int pi_prot_type = dev->dev_attrib.pi_prot_type;
  590. bool fabric_prot = false;
  591. if (!cmd->t_prot_sg || !cmd->t_prot_nents) {
  592. if (unlikely(protect &&
  593. !dev->dev_attrib.pi_prot_type && !cmd->se_sess->sess_prot_type)) {
  594. pr_err("CDB contains protect bit, but device + fabric does"
  595. " not advertise PROTECT=1 feature bit\n");
  596. return TCM_INVALID_CDB_FIELD;
  597. }
  598. if (cmd->prot_pto)
  599. return TCM_NO_SENSE;
  600. }
  601. switch (dev->dev_attrib.pi_prot_type) {
  602. case TARGET_DIF_TYPE3_PROT:
  603. cmd->reftag_seed = 0xffffffff;
  604. break;
  605. case TARGET_DIF_TYPE2_PROT:
  606. if (protect)
  607. return TCM_INVALID_CDB_FIELD;
  608. cmd->reftag_seed = cmd->t_task_lba;
  609. break;
  610. case TARGET_DIF_TYPE1_PROT:
  611. cmd->reftag_seed = cmd->t_task_lba;
  612. break;
  613. case TARGET_DIF_TYPE0_PROT:
  614. /*
  615. * See if the fabric supports T10-PI, and the session has been
  616. * configured to allow export PROTECT=1 feature bit with backend
  617. * devices that don't support T10-PI.
  618. */
  619. fabric_prot = is_write ?
  620. !!(sp_ops & (TARGET_PROT_DOUT_PASS | TARGET_PROT_DOUT_STRIP)) :
  621. !!(sp_ops & (TARGET_PROT_DIN_PASS | TARGET_PROT_DIN_INSERT));
  622. if (fabric_prot && cmd->se_sess->sess_prot_type) {
  623. pi_prot_type = cmd->se_sess->sess_prot_type;
  624. break;
  625. }
  626. if (!protect)
  627. return TCM_NO_SENSE;
  628. fallthrough;
  629. default:
  630. pr_err("Unable to determine pi_prot_type for CDB: 0x%02x "
  631. "PROTECT: 0x%02x\n", cmd->t_task_cdb[0], protect);
  632. return TCM_INVALID_CDB_FIELD;
  633. }
  634. if (sbc_set_prot_op_checks(protect, fabric_prot, pi_prot_type, is_write, cmd))
  635. return TCM_INVALID_CDB_FIELD;
  636. cmd->prot_type = pi_prot_type;
  637. cmd->prot_length = dev->prot_length * sectors;
  638. /**
  639. * In case protection information exists over the wire
  640. * we modify command data length to describe pure data.
  641. * The actual transfer length is data length + protection
  642. * length
  643. **/
  644. if (protect)
  645. cmd->data_length = sectors * dev->dev_attrib.block_size;
  646. pr_debug("%s: prot_type=%d, data_length=%d, prot_length=%d "
  647. "prot_op=%d prot_checks=%d\n",
  648. __func__, cmd->prot_type, cmd->data_length, cmd->prot_length,
  649. cmd->prot_op, cmd->prot_checks);
  650. return TCM_NO_SENSE;
  651. }
  652. static int
  653. sbc_check_dpofua(struct se_device *dev, struct se_cmd *cmd, unsigned char *cdb)
  654. {
  655. if (cdb[1] & 0x10) {
  656. /* see explanation in spc_emulate_modesense */
  657. if (!target_check_fua(dev)) {
  658. pr_err("Got CDB: 0x%02x with DPO bit set, but device"
  659. " does not advertise support for DPO\n", cdb[0]);
  660. return -EINVAL;
  661. }
  662. }
  663. if (cdb[1] & 0x8) {
  664. if (!target_check_fua(dev)) {
  665. pr_err("Got CDB: 0x%02x with FUA bit set, but device"
  666. " does not advertise support for FUA write\n",
  667. cdb[0]);
  668. return -EINVAL;
  669. }
  670. cmd->se_cmd_flags |= SCF_FUA;
  671. }
  672. return 0;
  673. }
  674. sense_reason_t
  675. sbc_parse_cdb(struct se_cmd *cmd, struct exec_cmd_ops *ops)
  676. {
  677. struct se_device *dev = cmd->se_dev;
  678. unsigned char *cdb = cmd->t_task_cdb;
  679. unsigned int size;
  680. u32 sectors = 0;
  681. sense_reason_t ret;
  682. cmd->protocol_data = ops;
  683. switch (cdb[0]) {
  684. case READ_6:
  685. sectors = transport_get_sectors_6(cdb);
  686. cmd->t_task_lba = transport_lba_21(cdb);
  687. cmd->se_cmd_flags |= SCF_SCSI_DATA_CDB;
  688. cmd->execute_cmd = sbc_execute_rw;
  689. break;
  690. case READ_10:
  691. sectors = transport_get_sectors_10(cdb);
  692. cmd->t_task_lba = transport_lba_32(cdb);
  693. if (sbc_check_dpofua(dev, cmd, cdb))
  694. return TCM_INVALID_CDB_FIELD;
  695. ret = sbc_check_prot(dev, cmd, cdb[1] >> 5, sectors, false);
  696. if (ret)
  697. return ret;
  698. cmd->se_cmd_flags |= SCF_SCSI_DATA_CDB;
  699. cmd->execute_cmd = sbc_execute_rw;
  700. break;
  701. case READ_12:
  702. sectors = transport_get_sectors_12(cdb);
  703. cmd->t_task_lba = transport_lba_32(cdb);
  704. if (sbc_check_dpofua(dev, cmd, cdb))
  705. return TCM_INVALID_CDB_FIELD;
  706. ret = sbc_check_prot(dev, cmd, cdb[1] >> 5, sectors, false);
  707. if (ret)
  708. return ret;
  709. cmd->se_cmd_flags |= SCF_SCSI_DATA_CDB;
  710. cmd->execute_cmd = sbc_execute_rw;
  711. break;
  712. case READ_16:
  713. sectors = transport_get_sectors_16(cdb);
  714. cmd->t_task_lba = transport_lba_64(cdb);
  715. if (sbc_check_dpofua(dev, cmd, cdb))
  716. return TCM_INVALID_CDB_FIELD;
  717. ret = sbc_check_prot(dev, cmd, cdb[1] >> 5, sectors, false);
  718. if (ret)
  719. return ret;
  720. cmd->se_cmd_flags |= SCF_SCSI_DATA_CDB;
  721. cmd->execute_cmd = sbc_execute_rw;
  722. break;
  723. case WRITE_6:
  724. sectors = transport_get_sectors_6(cdb);
  725. cmd->t_task_lba = transport_lba_21(cdb);
  726. cmd->se_cmd_flags |= SCF_SCSI_DATA_CDB;
  727. cmd->execute_cmd = sbc_execute_rw;
  728. break;
  729. case WRITE_10:
  730. case WRITE_VERIFY:
  731. sectors = transport_get_sectors_10(cdb);
  732. cmd->t_task_lba = transport_lba_32(cdb);
  733. if (sbc_check_dpofua(dev, cmd, cdb))
  734. return TCM_INVALID_CDB_FIELD;
  735. ret = sbc_check_prot(dev, cmd, cdb[1] >> 5, sectors, true);
  736. if (ret)
  737. return ret;
  738. cmd->se_cmd_flags |= SCF_SCSI_DATA_CDB;
  739. cmd->execute_cmd = sbc_execute_rw;
  740. break;
  741. case WRITE_12:
  742. sectors = transport_get_sectors_12(cdb);
  743. cmd->t_task_lba = transport_lba_32(cdb);
  744. if (sbc_check_dpofua(dev, cmd, cdb))
  745. return TCM_INVALID_CDB_FIELD;
  746. ret = sbc_check_prot(dev, cmd, cdb[1] >> 5, sectors, true);
  747. if (ret)
  748. return ret;
  749. cmd->se_cmd_flags |= SCF_SCSI_DATA_CDB;
  750. cmd->execute_cmd = sbc_execute_rw;
  751. break;
  752. case WRITE_16:
  753. case WRITE_VERIFY_16:
  754. sectors = transport_get_sectors_16(cdb);
  755. cmd->t_task_lba = transport_lba_64(cdb);
  756. if (sbc_check_dpofua(dev, cmd, cdb))
  757. return TCM_INVALID_CDB_FIELD;
  758. ret = sbc_check_prot(dev, cmd, cdb[1] >> 5, sectors, true);
  759. if (ret)
  760. return ret;
  761. cmd->se_cmd_flags |= SCF_SCSI_DATA_CDB;
  762. cmd->execute_cmd = sbc_execute_rw;
  763. break;
  764. case VARIABLE_LENGTH_CMD:
  765. {
  766. u16 service_action = get_unaligned_be16(&cdb[8]);
  767. switch (service_action) {
  768. case WRITE_SAME_32:
  769. sectors = transport_get_sectors_32(cdb);
  770. if (!sectors) {
  771. pr_err("WSNZ=1, WRITE_SAME w/sectors=0 not"
  772. " supported\n");
  773. return TCM_INVALID_CDB_FIELD;
  774. }
  775. size = sbc_get_size(cmd, 1);
  776. cmd->t_task_lba = get_unaligned_be64(&cdb[12]);
  777. ret = sbc_setup_write_same(cmd, cdb[10], ops);
  778. if (ret)
  779. return ret;
  780. break;
  781. default:
  782. pr_err("VARIABLE_LENGTH_CMD service action"
  783. " 0x%04x not supported\n", service_action);
  784. return TCM_UNSUPPORTED_SCSI_OPCODE;
  785. }
  786. break;
  787. }
  788. case COMPARE_AND_WRITE:
  789. if (!dev->dev_attrib.emulate_caw) {
  790. pr_err_ratelimited("se_device %s/%s (vpd_unit_serial %s) reject COMPARE_AND_WRITE\n",
  791. dev->se_hba->backend->ops->name,
  792. config_item_name(&dev->dev_group.cg_item),
  793. dev->t10_wwn.unit_serial);
  794. return TCM_UNSUPPORTED_SCSI_OPCODE;
  795. }
  796. sectors = cdb[13];
  797. /*
  798. * Currently enforce COMPARE_AND_WRITE for a single sector
  799. */
  800. if (sectors > 1) {
  801. pr_err("COMPARE_AND_WRITE contains NoLB: %u greater"
  802. " than 1\n", sectors);
  803. return TCM_INVALID_CDB_FIELD;
  804. }
  805. if (sbc_check_dpofua(dev, cmd, cdb))
  806. return TCM_INVALID_CDB_FIELD;
  807. /*
  808. * Double size because we have two buffers, note that
  809. * zero is not an error..
  810. */
  811. size = 2 * sbc_get_size(cmd, sectors);
  812. cmd->t_task_lba = get_unaligned_be64(&cdb[2]);
  813. cmd->t_task_nolb = sectors;
  814. cmd->se_cmd_flags |= SCF_SCSI_DATA_CDB | SCF_COMPARE_AND_WRITE;
  815. cmd->execute_cmd = sbc_compare_and_write;
  816. cmd->transport_complete_callback = compare_and_write_callback;
  817. break;
  818. case READ_CAPACITY:
  819. size = READ_CAP_LEN;
  820. cmd->execute_cmd = sbc_emulate_readcapacity;
  821. break;
  822. case SERVICE_ACTION_IN_16:
  823. switch (cmd->t_task_cdb[1] & 0x1f) {
  824. case SAI_READ_CAPACITY_16:
  825. cmd->execute_cmd = sbc_emulate_readcapacity_16;
  826. break;
  827. case SAI_REPORT_REFERRALS:
  828. cmd->execute_cmd = target_emulate_report_referrals;
  829. break;
  830. default:
  831. pr_err("Unsupported SA: 0x%02x\n",
  832. cmd->t_task_cdb[1] & 0x1f);
  833. return TCM_INVALID_CDB_FIELD;
  834. }
  835. size = get_unaligned_be32(&cdb[10]);
  836. break;
  837. case SYNCHRONIZE_CACHE:
  838. case SYNCHRONIZE_CACHE_16:
  839. if (cdb[0] == SYNCHRONIZE_CACHE) {
  840. sectors = transport_get_sectors_10(cdb);
  841. cmd->t_task_lba = transport_lba_32(cdb);
  842. } else {
  843. sectors = transport_get_sectors_16(cdb);
  844. cmd->t_task_lba = transport_lba_64(cdb);
  845. }
  846. if (ops->execute_sync_cache) {
  847. cmd->execute_cmd = ops->execute_sync_cache;
  848. goto check_lba;
  849. }
  850. size = 0;
  851. cmd->execute_cmd = sbc_emulate_noop;
  852. break;
  853. case UNMAP:
  854. if (!ops->execute_unmap)
  855. return TCM_UNSUPPORTED_SCSI_OPCODE;
  856. if (!dev->dev_attrib.emulate_tpu) {
  857. pr_err("Got UNMAP, but backend device has"
  858. " emulate_tpu disabled\n");
  859. return TCM_UNSUPPORTED_SCSI_OPCODE;
  860. }
  861. size = get_unaligned_be16(&cdb[7]);
  862. cmd->execute_cmd = sbc_execute_unmap;
  863. break;
  864. case WRITE_SAME_16:
  865. sectors = transport_get_sectors_16(cdb);
  866. if (!sectors) {
  867. pr_err("WSNZ=1, WRITE_SAME w/sectors=0 not supported\n");
  868. return TCM_INVALID_CDB_FIELD;
  869. }
  870. size = sbc_get_size(cmd, 1);
  871. cmd->t_task_lba = get_unaligned_be64(&cdb[2]);
  872. ret = sbc_setup_write_same(cmd, cdb[1], ops);
  873. if (ret)
  874. return ret;
  875. break;
  876. case WRITE_SAME:
  877. sectors = transport_get_sectors_10(cdb);
  878. if (!sectors) {
  879. pr_err("WSNZ=1, WRITE_SAME w/sectors=0 not supported\n");
  880. return TCM_INVALID_CDB_FIELD;
  881. }
  882. size = sbc_get_size(cmd, 1);
  883. cmd->t_task_lba = get_unaligned_be32(&cdb[2]);
  884. /*
  885. * Follow sbcr26 with WRITE_SAME (10) and check for the existence
  886. * of byte 1 bit 3 UNMAP instead of original reserved field
  887. */
  888. ret = sbc_setup_write_same(cmd, cdb[1], ops);
  889. if (ret)
  890. return ret;
  891. break;
  892. case VERIFY:
  893. case VERIFY_16:
  894. size = 0;
  895. if (cdb[0] == VERIFY) {
  896. sectors = transport_get_sectors_10(cdb);
  897. cmd->t_task_lba = transport_lba_32(cdb);
  898. } else {
  899. sectors = transport_get_sectors_16(cdb);
  900. cmd->t_task_lba = transport_lba_64(cdb);
  901. }
  902. cmd->execute_cmd = sbc_emulate_noop;
  903. goto check_lba;
  904. case REZERO_UNIT:
  905. case SEEK_6:
  906. case SEEK_10:
  907. /*
  908. * There are still clients out there which use these old SCSI-2
  909. * commands. This mainly happens when running VMs with legacy
  910. * guest systems, connected via SCSI command pass-through to
  911. * iSCSI targets. Make them happy and return status GOOD.
  912. */
  913. size = 0;
  914. cmd->execute_cmd = sbc_emulate_noop;
  915. break;
  916. case START_STOP:
  917. size = 0;
  918. cmd->execute_cmd = sbc_emulate_startstop;
  919. break;
  920. default:
  921. ret = spc_parse_cdb(cmd, &size);
  922. if (ret)
  923. return ret;
  924. }
  925. /* reject any command that we don't have a handler for */
  926. if (!cmd->execute_cmd)
  927. return TCM_UNSUPPORTED_SCSI_OPCODE;
  928. if (cmd->se_cmd_flags & SCF_SCSI_DATA_CDB) {
  929. unsigned long long end_lba;
  930. check_lba:
  931. end_lba = dev->transport->get_blocks(dev) + 1;
  932. if (((cmd->t_task_lba + sectors) < cmd->t_task_lba) ||
  933. ((cmd->t_task_lba + sectors) > end_lba)) {
  934. pr_err("cmd exceeds last lba %llu "
  935. "(lba %llu, sectors %u)\n",
  936. end_lba, cmd->t_task_lba, sectors);
  937. return TCM_ADDRESS_OUT_OF_RANGE;
  938. }
  939. if (!(cmd->se_cmd_flags & SCF_COMPARE_AND_WRITE))
  940. size = sbc_get_size(cmd, sectors);
  941. }
  942. return target_cmd_size_check(cmd, size);
  943. }
  944. EXPORT_SYMBOL(sbc_parse_cdb);
  945. u32 sbc_get_device_type(struct se_device *dev)
  946. {
  947. return TYPE_DISK;
  948. }
  949. EXPORT_SYMBOL(sbc_get_device_type);
  950. static sense_reason_t
  951. sbc_execute_unmap(struct se_cmd *cmd)
  952. {
  953. struct exec_cmd_ops *ops = cmd->protocol_data;
  954. struct se_device *dev = cmd->se_dev;
  955. unsigned char *buf, *ptr = NULL;
  956. sector_t lba;
  957. int size;
  958. u32 range;
  959. sense_reason_t ret = 0;
  960. int dl, bd_dl;
  961. /* We never set ANC_SUP */
  962. if (cmd->t_task_cdb[1])
  963. return TCM_INVALID_CDB_FIELD;
  964. if (cmd->data_length == 0) {
  965. target_complete_cmd(cmd, SAM_STAT_GOOD);
  966. return 0;
  967. }
  968. if (cmd->data_length < 8) {
  969. pr_warn("UNMAP parameter list length %u too small\n",
  970. cmd->data_length);
  971. return TCM_PARAMETER_LIST_LENGTH_ERROR;
  972. }
  973. buf = transport_kmap_data_sg(cmd);
  974. if (!buf)
  975. return TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE;
  976. dl = get_unaligned_be16(&buf[0]);
  977. bd_dl = get_unaligned_be16(&buf[2]);
  978. size = cmd->data_length - 8;
  979. if (bd_dl > size)
  980. pr_warn("UNMAP parameter list length %u too small, ignoring bd_dl %u\n",
  981. cmd->data_length, bd_dl);
  982. else
  983. size = bd_dl;
  984. if (size / 16 > dev->dev_attrib.max_unmap_block_desc_count) {
  985. ret = TCM_INVALID_PARAMETER_LIST;
  986. goto err;
  987. }
  988. /* First UNMAP block descriptor starts at 8 byte offset */
  989. ptr = &buf[8];
  990. pr_debug("UNMAP: Sub: %s Using dl: %u bd_dl: %u size: %u"
  991. " ptr: %p\n", dev->transport->name, dl, bd_dl, size, ptr);
  992. while (size >= 16) {
  993. lba = get_unaligned_be64(&ptr[0]);
  994. range = get_unaligned_be32(&ptr[8]);
  995. pr_debug("UNMAP: Using lba: %llu and range: %u\n",
  996. (unsigned long long)lba, range);
  997. if (range > dev->dev_attrib.max_unmap_lba_count) {
  998. ret = TCM_INVALID_PARAMETER_LIST;
  999. goto err;
  1000. }
  1001. if (lba + range > dev->transport->get_blocks(dev) + 1) {
  1002. ret = TCM_ADDRESS_OUT_OF_RANGE;
  1003. goto err;
  1004. }
  1005. if (range) {
  1006. ret = ops->execute_unmap(cmd, lba, range);
  1007. if (ret)
  1008. goto err;
  1009. }
  1010. ptr += 16;
  1011. size -= 16;
  1012. }
  1013. err:
  1014. transport_kunmap_data_sg(cmd);
  1015. if (!ret)
  1016. target_complete_cmd(cmd, SAM_STAT_GOOD);
  1017. return ret;
  1018. }
  1019. void
  1020. sbc_dif_generate(struct se_cmd *cmd)
  1021. {
  1022. struct se_device *dev = cmd->se_dev;
  1023. struct t10_pi_tuple *sdt;
  1024. struct scatterlist *dsg = cmd->t_data_sg, *psg;
  1025. sector_t sector = cmd->t_task_lba;
  1026. void *daddr, *paddr;
  1027. int i, j, offset = 0;
  1028. unsigned int block_size = dev->dev_attrib.block_size;
  1029. for_each_sg(cmd->t_prot_sg, psg, cmd->t_prot_nents, i) {
  1030. paddr = kmap_atomic(sg_page(psg)) + psg->offset;
  1031. daddr = kmap_atomic(sg_page(dsg)) + dsg->offset;
  1032. for (j = 0; j < psg->length;
  1033. j += sizeof(*sdt)) {
  1034. __u16 crc;
  1035. unsigned int avail;
  1036. if (offset >= dsg->length) {
  1037. offset -= dsg->length;
  1038. kunmap_atomic(daddr - dsg->offset);
  1039. dsg = sg_next(dsg);
  1040. if (!dsg) {
  1041. kunmap_atomic(paddr - psg->offset);
  1042. return;
  1043. }
  1044. daddr = kmap_atomic(sg_page(dsg)) + dsg->offset;
  1045. }
  1046. sdt = paddr + j;
  1047. avail = min(block_size, dsg->length - offset);
  1048. crc = crc_t10dif(daddr + offset, avail);
  1049. if (avail < block_size) {
  1050. kunmap_atomic(daddr - dsg->offset);
  1051. dsg = sg_next(dsg);
  1052. if (!dsg) {
  1053. kunmap_atomic(paddr - psg->offset);
  1054. return;
  1055. }
  1056. daddr = kmap_atomic(sg_page(dsg)) + dsg->offset;
  1057. offset = block_size - avail;
  1058. crc = crc_t10dif_update(crc, daddr, offset);
  1059. } else {
  1060. offset += block_size;
  1061. }
  1062. sdt->guard_tag = cpu_to_be16(crc);
  1063. if (cmd->prot_type == TARGET_DIF_TYPE1_PROT)
  1064. sdt->ref_tag = cpu_to_be32(sector & 0xffffffff);
  1065. sdt->app_tag = 0;
  1066. pr_debug("DIF %s INSERT sector: %llu guard_tag: 0x%04x"
  1067. " app_tag: 0x%04x ref_tag: %u\n",
  1068. (cmd->data_direction == DMA_TO_DEVICE) ?
  1069. "WRITE" : "READ", (unsigned long long)sector,
  1070. sdt->guard_tag, sdt->app_tag,
  1071. be32_to_cpu(sdt->ref_tag));
  1072. sector++;
  1073. }
  1074. kunmap_atomic(daddr - dsg->offset);
  1075. kunmap_atomic(paddr - psg->offset);
  1076. }
  1077. }
  1078. static sense_reason_t
  1079. sbc_dif_v1_verify(struct se_cmd *cmd, struct t10_pi_tuple *sdt,
  1080. __u16 crc, sector_t sector, unsigned int ei_lba)
  1081. {
  1082. __be16 csum;
  1083. if (!(cmd->prot_checks & TARGET_DIF_CHECK_GUARD))
  1084. goto check_ref;
  1085. csum = cpu_to_be16(crc);
  1086. if (sdt->guard_tag != csum) {
  1087. pr_err("DIFv1 checksum failed on sector %llu guard tag 0x%04x"
  1088. " csum 0x%04x\n", (unsigned long long)sector,
  1089. be16_to_cpu(sdt->guard_tag), be16_to_cpu(csum));
  1090. return TCM_LOGICAL_BLOCK_GUARD_CHECK_FAILED;
  1091. }
  1092. check_ref:
  1093. if (!(cmd->prot_checks & TARGET_DIF_CHECK_REFTAG))
  1094. return 0;
  1095. if (cmd->prot_type == TARGET_DIF_TYPE1_PROT &&
  1096. be32_to_cpu(sdt->ref_tag) != (sector & 0xffffffff)) {
  1097. pr_err("DIFv1 Type 1 reference failed on sector: %llu tag: 0x%08x"
  1098. " sector MSB: 0x%08x\n", (unsigned long long)sector,
  1099. be32_to_cpu(sdt->ref_tag), (u32)(sector & 0xffffffff));
  1100. return TCM_LOGICAL_BLOCK_REF_TAG_CHECK_FAILED;
  1101. }
  1102. if (cmd->prot_type == TARGET_DIF_TYPE2_PROT &&
  1103. be32_to_cpu(sdt->ref_tag) != ei_lba) {
  1104. pr_err("DIFv1 Type 2 reference failed on sector: %llu tag: 0x%08x"
  1105. " ei_lba: 0x%08x\n", (unsigned long long)sector,
  1106. be32_to_cpu(sdt->ref_tag), ei_lba);
  1107. return TCM_LOGICAL_BLOCK_REF_TAG_CHECK_FAILED;
  1108. }
  1109. return 0;
  1110. }
  1111. void sbc_dif_copy_prot(struct se_cmd *cmd, unsigned int sectors, bool read,
  1112. struct scatterlist *sg, int sg_off)
  1113. {
  1114. struct se_device *dev = cmd->se_dev;
  1115. struct scatterlist *psg;
  1116. void *paddr, *addr;
  1117. unsigned int i, len, left;
  1118. unsigned int offset = sg_off;
  1119. if (!sg)
  1120. return;
  1121. left = sectors * dev->prot_length;
  1122. for_each_sg(cmd->t_prot_sg, psg, cmd->t_prot_nents, i) {
  1123. unsigned int psg_len, copied = 0;
  1124. paddr = kmap_atomic(sg_page(psg)) + psg->offset;
  1125. psg_len = min(left, psg->length);
  1126. while (psg_len) {
  1127. len = min(psg_len, sg->length - offset);
  1128. addr = kmap_atomic(sg_page(sg)) + sg->offset + offset;
  1129. if (read)
  1130. memcpy(paddr + copied, addr, len);
  1131. else
  1132. memcpy(addr, paddr + copied, len);
  1133. left -= len;
  1134. offset += len;
  1135. copied += len;
  1136. psg_len -= len;
  1137. kunmap_atomic(addr - sg->offset - offset);
  1138. if (offset >= sg->length) {
  1139. sg = sg_next(sg);
  1140. offset = 0;
  1141. }
  1142. }
  1143. kunmap_atomic(paddr - psg->offset);
  1144. }
  1145. }
  1146. EXPORT_SYMBOL(sbc_dif_copy_prot);
  1147. sense_reason_t
  1148. sbc_dif_verify(struct se_cmd *cmd, sector_t start, unsigned int sectors,
  1149. unsigned int ei_lba, struct scatterlist *psg, int psg_off)
  1150. {
  1151. struct se_device *dev = cmd->se_dev;
  1152. struct t10_pi_tuple *sdt;
  1153. struct scatterlist *dsg = cmd->t_data_sg;
  1154. sector_t sector = start;
  1155. void *daddr, *paddr;
  1156. int i;
  1157. sense_reason_t rc;
  1158. int dsg_off = 0;
  1159. unsigned int block_size = dev->dev_attrib.block_size;
  1160. for (; psg && sector < start + sectors; psg = sg_next(psg)) {
  1161. paddr = kmap_atomic(sg_page(psg)) + psg->offset;
  1162. daddr = kmap_atomic(sg_page(dsg)) + dsg->offset;
  1163. for (i = psg_off; i < psg->length &&
  1164. sector < start + sectors;
  1165. i += sizeof(*sdt)) {
  1166. __u16 crc;
  1167. unsigned int avail;
  1168. if (dsg_off >= dsg->length) {
  1169. dsg_off -= dsg->length;
  1170. kunmap_atomic(daddr - dsg->offset);
  1171. dsg = sg_next(dsg);
  1172. if (!dsg) {
  1173. kunmap_atomic(paddr - psg->offset);
  1174. return 0;
  1175. }
  1176. daddr = kmap_atomic(sg_page(dsg)) + dsg->offset;
  1177. }
  1178. sdt = paddr + i;
  1179. pr_debug("DIF READ sector: %llu guard_tag: 0x%04x"
  1180. " app_tag: 0x%04x ref_tag: %u\n",
  1181. (unsigned long long)sector, sdt->guard_tag,
  1182. sdt->app_tag, be32_to_cpu(sdt->ref_tag));
  1183. if (sdt->app_tag == T10_PI_APP_ESCAPE) {
  1184. dsg_off += block_size;
  1185. goto next;
  1186. }
  1187. avail = min(block_size, dsg->length - dsg_off);
  1188. crc = crc_t10dif(daddr + dsg_off, avail);
  1189. if (avail < block_size) {
  1190. kunmap_atomic(daddr - dsg->offset);
  1191. dsg = sg_next(dsg);
  1192. if (!dsg) {
  1193. kunmap_atomic(paddr - psg->offset);
  1194. return 0;
  1195. }
  1196. daddr = kmap_atomic(sg_page(dsg)) + dsg->offset;
  1197. dsg_off = block_size - avail;
  1198. crc = crc_t10dif_update(crc, daddr, dsg_off);
  1199. } else {
  1200. dsg_off += block_size;
  1201. }
  1202. rc = sbc_dif_v1_verify(cmd, sdt, crc, sector, ei_lba);
  1203. if (rc) {
  1204. kunmap_atomic(daddr - dsg->offset);
  1205. kunmap_atomic(paddr - psg->offset);
  1206. cmd->sense_info = sector;
  1207. return rc;
  1208. }
  1209. next:
  1210. sector++;
  1211. ei_lba++;
  1212. }
  1213. psg_off = 0;
  1214. kunmap_atomic(daddr - dsg->offset);
  1215. kunmap_atomic(paddr - psg->offset);
  1216. }
  1217. return 0;
  1218. }
  1219. EXPORT_SYMBOL(sbc_dif_verify);