spapr_vscsi.c 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982
  1. /*
  2. * QEMU PowerPC pSeries Logical Partition (aka sPAPR) hardware System Emulator
  3. *
  4. * PAPR Virtual SCSI, aka ibmvscsi
  5. *
  6. * Copyright (c) 2010,2011 Benjamin Herrenschmidt, IBM Corporation.
  7. *
  8. * Permission is hereby granted, free of charge, to any person obtaining a copy
  9. * of this software and associated documentation files (the "Software"), to deal
  10. * in the Software without restriction, including without limitation the rights
  11. * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  12. * copies of the Software, and to permit persons to whom the Software is
  13. * furnished to do so, subject to the following conditions:
  14. *
  15. * The above copyright notice and this permission notice shall be included in
  16. * all copies or substantial portions of the Software.
  17. *
  18. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  19. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  20. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
  21. * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  22. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  23. * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  24. * THE SOFTWARE.
  25. *
  26. * TODO:
  27. *
  28. * - Cleanups :-)
  29. * - Sort out better how to assign devices to VSCSI instances
  30. * - Fix residual counts
  31. * - Add indirect descriptors support
  32. * - Maybe do autosense (PAPR seems to mandate it, linux doesn't care)
  33. */
  34. #include "hw.h"
  35. #include "scsi.h"
  36. #include "scsi-defs.h"
  37. #include "srp.h"
  38. #include "hw/qdev.h"
  39. #include "hw/spapr.h"
  40. #include "hw/spapr_vio.h"
  41. #include "hw/ppc-viosrp.h"
  42. #include <libfdt.h>
  43. /*#define DEBUG_VSCSI*/
  44. #ifdef DEBUG_VSCSI
  45. #define dprintf(fmt, ...) \
  46. do { fprintf(stderr, fmt, ## __VA_ARGS__); } while (0)
  47. #else
  48. #define dprintf(fmt, ...) \
  49. do { } while (0)
  50. #endif
  51. /*
  52. * Virtual SCSI device
  53. */
  54. /* Random numbers */
  55. #define VSCSI_MAX_SECTORS 4096
  56. #define VSCSI_REQ_LIMIT 24
  57. #define SCSI_SENSE_BUF_SIZE 96
  58. #define SRP_RSP_SENSE_DATA_LEN 18
  59. typedef union vscsi_crq {
  60. struct viosrp_crq s;
  61. uint8_t raw[16];
  62. } vscsi_crq;
  63. typedef struct vscsi_req {
  64. vscsi_crq crq;
  65. union viosrp_iu iu;
  66. /* SCSI request tracking */
  67. SCSIRequest *sreq;
  68. uint32_t qtag; /* qemu tag != srp tag */
  69. int lun;
  70. int active;
  71. long data_len;
  72. int writing;
  73. int senselen;
  74. uint8_t sense[SCSI_SENSE_BUF_SIZE];
  75. /* RDMA related bits */
  76. uint8_t dma_fmt;
  77. struct srp_direct_buf ext_desc;
  78. struct srp_direct_buf *cur_desc;
  79. struct srp_indirect_buf *ind_desc;
  80. int local_desc;
  81. int total_desc;
  82. } vscsi_req;
  83. typedef struct {
  84. VIOsPAPRDevice vdev;
  85. SCSIBus bus;
  86. vscsi_req reqs[VSCSI_REQ_LIMIT];
  87. } VSCSIState;
  88. static struct vscsi_req *vscsi_get_req(VSCSIState *s)
  89. {
  90. vscsi_req *req;
  91. int i;
  92. for (i = 0; i < VSCSI_REQ_LIMIT; i++) {
  93. req = &s->reqs[i];
  94. if (!req->active) {
  95. memset(req, 0, sizeof(*req));
  96. req->qtag = i;
  97. req->active = 1;
  98. return req;
  99. }
  100. }
  101. return NULL;
  102. }
  103. static void vscsi_put_req(vscsi_req *req)
  104. {
  105. if (req->sreq != NULL) {
  106. scsi_req_unref(req->sreq);
  107. }
  108. req->sreq = NULL;
  109. req->active = 0;
  110. }
  111. static SCSIDevice *vscsi_device_find(SCSIBus *bus, uint64_t srp_lun, int *lun)
  112. {
  113. int channel = 0, id = 0;
  114. retry:
  115. switch (srp_lun >> 62) {
  116. case 0:
  117. if ((srp_lun >> 56) != 0) {
  118. channel = (srp_lun >> 56) & 0x3f;
  119. id = (srp_lun >> 48) & 0xff;
  120. srp_lun <<= 16;
  121. goto retry;
  122. }
  123. *lun = (srp_lun >> 48) & 0xff;
  124. break;
  125. case 1:
  126. *lun = (srp_lun >> 48) & 0x3fff;
  127. break;
  128. case 2:
  129. channel = (srp_lun >> 53) & 0x7;
  130. id = (srp_lun >> 56) & 0x3f;
  131. *lun = (srp_lun >> 48) & 0x1f;
  132. break;
  133. case 3:
  134. *lun = -1;
  135. return NULL;
  136. default:
  137. abort();
  138. }
  139. return scsi_device_find(bus, channel, id, *lun);
  140. }
  141. static int vscsi_send_iu(VSCSIState *s, vscsi_req *req,
  142. uint64_t length, uint8_t format)
  143. {
  144. long rc, rc1;
  145. /* First copy the SRP */
  146. rc = spapr_vio_dma_write(&s->vdev, req->crq.s.IU_data_ptr,
  147. &req->iu, length);
  148. if (rc) {
  149. fprintf(stderr, "vscsi_send_iu: DMA write failure !\n");
  150. }
  151. req->crq.s.valid = 0x80;
  152. req->crq.s.format = format;
  153. req->crq.s.reserved = 0x00;
  154. req->crq.s.timeout = cpu_to_be16(0x0000);
  155. req->crq.s.IU_length = cpu_to_be16(length);
  156. req->crq.s.IU_data_ptr = req->iu.srp.rsp.tag; /* right byte order */
  157. if (rc == 0) {
  158. req->crq.s.status = 0x99; /* Just needs to be non-zero */
  159. } else {
  160. req->crq.s.status = 0x00;
  161. }
  162. rc1 = spapr_vio_send_crq(&s->vdev, req->crq.raw);
  163. if (rc1) {
  164. fprintf(stderr, "vscsi_send_iu: Error sending response\n");
  165. return rc1;
  166. }
  167. return rc;
  168. }
  169. static void vscsi_makeup_sense(VSCSIState *s, vscsi_req *req,
  170. uint8_t key, uint8_t asc, uint8_t ascq)
  171. {
  172. req->senselen = SRP_RSP_SENSE_DATA_LEN;
  173. /* Valid bit and 'current errors' */
  174. req->sense[0] = (0x1 << 7 | 0x70);
  175. /* Sense key */
  176. req->sense[2] = key;
  177. /* Additional sense length */
  178. req->sense[7] = 0xa; /* 10 bytes */
  179. /* Additional sense code */
  180. req->sense[12] = asc;
  181. req->sense[13] = ascq;
  182. }
  183. static int vscsi_send_rsp(VSCSIState *s, vscsi_req *req,
  184. uint8_t status, int32_t res_in, int32_t res_out)
  185. {
  186. union viosrp_iu *iu = &req->iu;
  187. uint64_t tag = iu->srp.rsp.tag;
  188. int total_len = sizeof(iu->srp.rsp);
  189. dprintf("VSCSI: Sending resp status: 0x%x, "
  190. "res_in: %d, res_out: %d\n", status, res_in, res_out);
  191. memset(iu, 0, sizeof(struct srp_rsp));
  192. iu->srp.rsp.opcode = SRP_RSP;
  193. iu->srp.rsp.req_lim_delta = cpu_to_be32(1);
  194. iu->srp.rsp.tag = tag;
  195. /* Handle residuals */
  196. if (res_in < 0) {
  197. iu->srp.rsp.flags |= SRP_RSP_FLAG_DIUNDER;
  198. res_in = -res_in;
  199. } else if (res_in) {
  200. iu->srp.rsp.flags |= SRP_RSP_FLAG_DIOVER;
  201. }
  202. if (res_out < 0) {
  203. iu->srp.rsp.flags |= SRP_RSP_FLAG_DOUNDER;
  204. res_out = -res_out;
  205. } else if (res_out) {
  206. iu->srp.rsp.flags |= SRP_RSP_FLAG_DOOVER;
  207. }
  208. iu->srp.rsp.data_in_res_cnt = cpu_to_be32(res_in);
  209. iu->srp.rsp.data_out_res_cnt = cpu_to_be32(res_out);
  210. /* We don't do response data */
  211. /* iu->srp.rsp.flags &= ~SRP_RSP_FLAG_RSPVALID; */
  212. iu->srp.rsp.resp_data_len = cpu_to_be32(0);
  213. /* Handle success vs. failure */
  214. iu->srp.rsp.status = status;
  215. if (status) {
  216. iu->srp.rsp.sol_not = (iu->srp.cmd.sol_not & 0x04) >> 2;
  217. if (req->senselen) {
  218. req->iu.srp.rsp.flags |= SRP_RSP_FLAG_SNSVALID;
  219. req->iu.srp.rsp.sense_data_len = cpu_to_be32(req->senselen);
  220. memcpy(req->iu.srp.rsp.data, req->sense, req->senselen);
  221. total_len += req->senselen;
  222. }
  223. } else {
  224. iu->srp.rsp.sol_not = (iu->srp.cmd.sol_not & 0x02) >> 1;
  225. }
  226. vscsi_send_iu(s, req, total_len, VIOSRP_SRP_FORMAT);
  227. return 0;
  228. }
  229. static inline void vscsi_swap_desc(struct srp_direct_buf *desc)
  230. {
  231. desc->va = be64_to_cpu(desc->va);
  232. desc->len = be32_to_cpu(desc->len);
  233. }
  234. static int vscsi_srp_direct_data(VSCSIState *s, vscsi_req *req,
  235. uint8_t *buf, uint32_t len)
  236. {
  237. struct srp_direct_buf *md = req->cur_desc;
  238. uint32_t llen;
  239. int rc = 0;
  240. dprintf("VSCSI: direct segment 0x%x bytes, va=0x%llx desc len=0x%x\n",
  241. len, (unsigned long long)md->va, md->len);
  242. llen = MIN(len, md->len);
  243. if (llen) {
  244. if (req->writing) { /* writing = to device = reading from memory */
  245. rc = spapr_vio_dma_read(&s->vdev, md->va, buf, llen);
  246. } else {
  247. rc = spapr_vio_dma_write(&s->vdev, md->va, buf, llen);
  248. }
  249. }
  250. md->len -= llen;
  251. md->va += llen;
  252. if (rc) {
  253. return -1;
  254. }
  255. return llen;
  256. }
  257. static int vscsi_srp_indirect_data(VSCSIState *s, vscsi_req *req,
  258. uint8_t *buf, uint32_t len)
  259. {
  260. struct srp_direct_buf *td = &req->ind_desc->table_desc;
  261. struct srp_direct_buf *md = req->cur_desc;
  262. int rc = 0;
  263. uint32_t llen, total = 0;
  264. dprintf("VSCSI: indirect segment 0x%x bytes, td va=0x%llx len=0x%x\n",
  265. len, (unsigned long long)td->va, td->len);
  266. /* While we have data ... */
  267. while (len) {
  268. /* If we have a descriptor but it's empty, go fetch a new one */
  269. if (md && md->len == 0) {
  270. /* More local available, use one */
  271. if (req->local_desc) {
  272. md = ++req->cur_desc;
  273. --req->local_desc;
  274. --req->total_desc;
  275. td->va += sizeof(struct srp_direct_buf);
  276. } else {
  277. md = req->cur_desc = NULL;
  278. }
  279. }
  280. /* No descriptor at hand, fetch one */
  281. if (!md) {
  282. if (!req->total_desc) {
  283. dprintf("VSCSI: Out of descriptors !\n");
  284. break;
  285. }
  286. md = req->cur_desc = &req->ext_desc;
  287. dprintf("VSCSI: Reading desc from 0x%llx\n",
  288. (unsigned long long)td->va);
  289. rc = spapr_vio_dma_read(&s->vdev, td->va, md,
  290. sizeof(struct srp_direct_buf));
  291. if (rc) {
  292. dprintf("VSCSI: spapr_vio_dma_read -> %d reading ext_desc\n",
  293. rc);
  294. break;
  295. }
  296. vscsi_swap_desc(md);
  297. td->va += sizeof(struct srp_direct_buf);
  298. --req->total_desc;
  299. }
  300. dprintf("VSCSI: [desc va=0x%llx,len=0x%x] remaining=0x%x\n",
  301. (unsigned long long)md->va, md->len, len);
  302. /* Perform transfer */
  303. llen = MIN(len, md->len);
  304. if (req->writing) { /* writing = to device = reading from memory */
  305. rc = spapr_vio_dma_read(&s->vdev, md->va, buf, llen);
  306. } else {
  307. rc = spapr_vio_dma_write(&s->vdev, md->va, buf, llen);
  308. }
  309. if (rc) {
  310. dprintf("VSCSI: spapr_vio_dma_r/w(%d) -> %d\n", req->writing, rc);
  311. break;
  312. }
  313. dprintf("VSCSI: data: %02x %02x %02x %02x...\n",
  314. buf[0], buf[1], buf[2], buf[3]);
  315. len -= llen;
  316. buf += llen;
  317. total += llen;
  318. md->va += llen;
  319. md->len -= llen;
  320. }
  321. return rc ? -1 : total;
  322. }
  323. static int vscsi_srp_transfer_data(VSCSIState *s, vscsi_req *req,
  324. int writing, uint8_t *buf, uint32_t len)
  325. {
  326. int err = 0;
  327. switch (req->dma_fmt) {
  328. case SRP_NO_DATA_DESC:
  329. dprintf("VSCSI: no data desc transfer, skipping 0x%x bytes\n", len);
  330. break;
  331. case SRP_DATA_DESC_DIRECT:
  332. err = vscsi_srp_direct_data(s, req, buf, len);
  333. break;
  334. case SRP_DATA_DESC_INDIRECT:
  335. err = vscsi_srp_indirect_data(s, req, buf, len);
  336. break;
  337. }
  338. return err;
  339. }
  340. /* Bits from linux srp */
  341. static int data_out_desc_size(struct srp_cmd *cmd)
  342. {
  343. int size = 0;
  344. uint8_t fmt = cmd->buf_fmt >> 4;
  345. switch (fmt) {
  346. case SRP_NO_DATA_DESC:
  347. break;
  348. case SRP_DATA_DESC_DIRECT:
  349. size = sizeof(struct srp_direct_buf);
  350. break;
  351. case SRP_DATA_DESC_INDIRECT:
  352. size = sizeof(struct srp_indirect_buf) +
  353. sizeof(struct srp_direct_buf)*cmd->data_out_desc_cnt;
  354. break;
  355. default:
  356. break;
  357. }
  358. return size;
  359. }
  360. static int vscsi_preprocess_desc(vscsi_req *req)
  361. {
  362. struct srp_cmd *cmd = &req->iu.srp.cmd;
  363. int offset, i;
  364. offset = cmd->add_cdb_len & ~3;
  365. if (req->writing) {
  366. req->dma_fmt = cmd->buf_fmt >> 4;
  367. } else {
  368. offset += data_out_desc_size(cmd);
  369. req->dma_fmt = cmd->buf_fmt & ((1U << 4) - 1);
  370. }
  371. switch (req->dma_fmt) {
  372. case SRP_NO_DATA_DESC:
  373. break;
  374. case SRP_DATA_DESC_DIRECT:
  375. req->cur_desc = (struct srp_direct_buf *)(cmd->add_data + offset);
  376. req->total_desc = req->local_desc = 1;
  377. vscsi_swap_desc(req->cur_desc);
  378. dprintf("VSCSI: using direct RDMA %s, 0x%x bytes MD: 0x%llx\n",
  379. req->writing ? "write" : "read",
  380. req->cur_desc->len, (unsigned long long)req->cur_desc->va);
  381. break;
  382. case SRP_DATA_DESC_INDIRECT:
  383. req->ind_desc = (struct srp_indirect_buf *)(cmd->add_data + offset);
  384. vscsi_swap_desc(&req->ind_desc->table_desc);
  385. req->total_desc = req->ind_desc->table_desc.len /
  386. sizeof(struct srp_direct_buf);
  387. req->local_desc = req->writing ? cmd->data_out_desc_cnt :
  388. cmd->data_in_desc_cnt;
  389. for (i = 0; i < req->local_desc; i++) {
  390. vscsi_swap_desc(&req->ind_desc->desc_list[i]);
  391. }
  392. req->cur_desc = req->local_desc ? &req->ind_desc->desc_list[0] : NULL;
  393. dprintf("VSCSI: using indirect RDMA %s, 0x%x bytes %d descs "
  394. "(%d local) VA: 0x%llx\n",
  395. req->writing ? "read" : "write",
  396. be32_to_cpu(req->ind_desc->len),
  397. req->total_desc, req->local_desc,
  398. (unsigned long long)req->ind_desc->table_desc.va);
  399. break;
  400. default:
  401. fprintf(stderr,
  402. "vscsi_preprocess_desc: Unknown format %x\n", req->dma_fmt);
  403. return -1;
  404. }
  405. return 0;
  406. }
  407. /* Callback to indicate that the SCSI layer has completed a transfer. */
  408. static void vscsi_transfer_data(SCSIRequest *sreq, uint32_t len)
  409. {
  410. VSCSIState *s = DO_UPCAST(VSCSIState, vdev.qdev, sreq->bus->qbus.parent);
  411. vscsi_req *req = sreq->hba_private;
  412. uint8_t *buf;
  413. int rc = 0;
  414. dprintf("VSCSI: SCSI xfer complete tag=0x%x len=0x%x, req=%p\n",
  415. sreq->tag, len, req);
  416. if (req == NULL) {
  417. fprintf(stderr, "VSCSI: Can't find request for tag 0x%x\n", sreq->tag);
  418. return;
  419. }
  420. if (len) {
  421. buf = scsi_req_get_buf(sreq);
  422. rc = vscsi_srp_transfer_data(s, req, req->writing, buf, len);
  423. }
  424. if (rc < 0) {
  425. fprintf(stderr, "VSCSI: RDMA error rc=%d!\n", rc);
  426. vscsi_makeup_sense(s, req, HARDWARE_ERROR, 0, 0);
  427. scsi_req_abort(req->sreq, CHECK_CONDITION);
  428. return;
  429. }
  430. /* Start next chunk */
  431. req->data_len -= rc;
  432. scsi_req_continue(sreq);
  433. }
  434. /* Callback to indicate that the SCSI layer has completed a transfer. */
  435. static void vscsi_command_complete(SCSIRequest *sreq, uint32_t status, size_t resid)
  436. {
  437. VSCSIState *s = DO_UPCAST(VSCSIState, vdev.qdev, sreq->bus->qbus.parent);
  438. vscsi_req *req = sreq->hba_private;
  439. int32_t res_in = 0, res_out = 0;
  440. dprintf("VSCSI: SCSI cmd complete, r=0x%x tag=0x%x status=0x%x, req=%p\n",
  441. reason, sreq->tag, status, req);
  442. if (req == NULL) {
  443. fprintf(stderr, "VSCSI: Can't find request for tag 0x%x\n", sreq->tag);
  444. return;
  445. }
  446. if (status == CHECK_CONDITION) {
  447. req->senselen = scsi_req_get_sense(req->sreq, req->sense,
  448. sizeof(req->sense));
  449. dprintf("VSCSI: Sense data, %d bytes:\n", len);
  450. dprintf(" %02x %02x %02x %02x %02x %02x %02x %02x\n",
  451. req->sense[0], req->sense[1], req->sense[2], req->sense[3],
  452. req->sense[4], req->sense[5], req->sense[6], req->sense[7]);
  453. dprintf(" %02x %02x %02x %02x %02x %02x %02x %02x\n",
  454. req->sense[8], req->sense[9], req->sense[10], req->sense[11],
  455. req->sense[12], req->sense[13], req->sense[14], req->sense[15]);
  456. }
  457. dprintf("VSCSI: Command complete err=%d\n", status);
  458. if (status == 0) {
  459. /* We handle overflows, not underflows for normal commands,
  460. * but hopefully nobody cares
  461. */
  462. if (req->writing) {
  463. res_out = req->data_len;
  464. } else {
  465. res_in = req->data_len;
  466. }
  467. }
  468. vscsi_send_rsp(s, req, status, res_in, res_out);
  469. vscsi_put_req(req);
  470. }
  471. static void vscsi_request_cancelled(SCSIRequest *sreq)
  472. {
  473. vscsi_req *req = sreq->hba_private;
  474. vscsi_put_req(req);
  475. }
  476. static void vscsi_process_login(VSCSIState *s, vscsi_req *req)
  477. {
  478. union viosrp_iu *iu = &req->iu;
  479. struct srp_login_rsp *rsp = &iu->srp.login_rsp;
  480. uint64_t tag = iu->srp.rsp.tag;
  481. dprintf("VSCSI: Got login, sendin response !\n");
  482. /* TODO handle case that requested size is wrong and
  483. * buffer format is wrong
  484. */
  485. memset(iu, 0, sizeof(struct srp_login_rsp));
  486. rsp->opcode = SRP_LOGIN_RSP;
  487. /* Don't advertise quite as many request as we support to
  488. * keep room for management stuff etc...
  489. */
  490. rsp->req_lim_delta = cpu_to_be32(VSCSI_REQ_LIMIT-2);
  491. rsp->tag = tag;
  492. rsp->max_it_iu_len = cpu_to_be32(sizeof(union srp_iu));
  493. rsp->max_ti_iu_len = cpu_to_be32(sizeof(union srp_iu));
  494. /* direct and indirect */
  495. rsp->buf_fmt = cpu_to_be16(SRP_BUF_FORMAT_DIRECT | SRP_BUF_FORMAT_INDIRECT);
  496. vscsi_send_iu(s, req, sizeof(*rsp), VIOSRP_SRP_FORMAT);
  497. }
  498. static void vscsi_inquiry_no_target(VSCSIState *s, vscsi_req *req)
  499. {
  500. uint8_t *cdb = req->iu.srp.cmd.cdb;
  501. uint8_t resp_data[36];
  502. int rc, len, alen;
  503. /* We dont do EVPD. Also check that page_code is 0 */
  504. if ((cdb[1] & 0x01) || (cdb[1] & 0x01) || cdb[2] != 0) {
  505. /* Send INVALID FIELD IN CDB */
  506. vscsi_makeup_sense(s, req, ILLEGAL_REQUEST, 0x24, 0);
  507. vscsi_send_rsp(s, req, CHECK_CONDITION, 0, 0);
  508. return;
  509. }
  510. alen = cdb[3];
  511. alen = (alen << 8) | cdb[4];
  512. len = MIN(alen, 36);
  513. /* Fake up inquiry using PQ=3 */
  514. memset(resp_data, 0, 36);
  515. resp_data[0] = 0x7f; /* Not capable of supporting a device here */
  516. resp_data[2] = 0x06; /* SPS-4 */
  517. resp_data[3] = 0x02; /* Resp data format */
  518. resp_data[4] = 36 - 5; /* Additional length */
  519. resp_data[7] = 0x10; /* Sync transfers */
  520. memcpy(&resp_data[16], "QEMU EMPTY ", 16);
  521. memcpy(&resp_data[8], "QEMU ", 8);
  522. req->writing = 0;
  523. vscsi_preprocess_desc(req);
  524. rc = vscsi_srp_transfer_data(s, req, 0, resp_data, len);
  525. if (rc < 0) {
  526. vscsi_makeup_sense(s, req, HARDWARE_ERROR, 0, 0);
  527. vscsi_send_rsp(s, req, CHECK_CONDITION, 0, 0);
  528. } else {
  529. vscsi_send_rsp(s, req, 0, 36 - rc, 0);
  530. }
  531. }
  532. static int vscsi_queue_cmd(VSCSIState *s, vscsi_req *req)
  533. {
  534. union srp_iu *srp = &req->iu.srp;
  535. SCSIDevice *sdev;
  536. int n, lun;
  537. sdev = vscsi_device_find(&s->bus, be64_to_cpu(srp->cmd.lun), &lun);
  538. if (!sdev) {
  539. dprintf("VSCSI: Command for lun %08" PRIx64 " with no drive\n", be64_to_cpu(srp->cmd.lun));
  540. if (srp->cmd.cdb[0] == INQUIRY) {
  541. vscsi_inquiry_no_target(s, req);
  542. } else {
  543. vscsi_makeup_sense(s, req, ILLEGAL_REQUEST, 0x24, 0x00);
  544. vscsi_send_rsp(s, req, CHECK_CONDITION, 0, 0);
  545. } return 1;
  546. }
  547. req->lun = lun;
  548. req->sreq = scsi_req_new(sdev, req->qtag, lun, srp->cmd.cdb, req);
  549. n = scsi_req_enqueue(req->sreq);
  550. dprintf("VSCSI: Queued command tag 0x%x CMD 0x%x ID %d LUN %d ret: %d\n",
  551. req->qtag, srp->cmd.cdb[0], id, lun, n);
  552. if (n) {
  553. /* Transfer direction must be set before preprocessing the
  554. * descriptors
  555. */
  556. req->writing = (n < 1);
  557. /* Preprocess RDMA descriptors */
  558. vscsi_preprocess_desc(req);
  559. /* Get transfer direction and initiate transfer */
  560. if (n > 0) {
  561. req->data_len = n;
  562. } else if (n < 0) {
  563. req->data_len = -n;
  564. }
  565. scsi_req_continue(req->sreq);
  566. }
  567. /* Don't touch req here, it may have been recycled already */
  568. return 0;
  569. }
  570. static int vscsi_process_tsk_mgmt(VSCSIState *s, vscsi_req *req)
  571. {
  572. union viosrp_iu *iu = &req->iu;
  573. int fn;
  574. fprintf(stderr, "vscsi_process_tsk_mgmt %02x\n",
  575. iu->srp.tsk_mgmt.tsk_mgmt_func);
  576. switch (iu->srp.tsk_mgmt.tsk_mgmt_func) {
  577. #if 0 /* We really don't deal with these for now */
  578. case SRP_TSK_ABORT_TASK:
  579. fn = ABORT_TASK;
  580. break;
  581. case SRP_TSK_ABORT_TASK_SET:
  582. fn = ABORT_TASK_SET;
  583. break;
  584. case SRP_TSK_CLEAR_TASK_SET:
  585. fn = CLEAR_TASK_SET;
  586. break;
  587. case SRP_TSK_LUN_RESET:
  588. fn = LOGICAL_UNIT_RESET;
  589. break;
  590. case SRP_TSK_CLEAR_ACA:
  591. fn = CLEAR_ACA;
  592. break;
  593. #endif
  594. default:
  595. fn = 0;
  596. }
  597. if (fn) {
  598. /* XXX Send/Handle target task management */
  599. ;
  600. } else {
  601. vscsi_makeup_sense(s, req, ILLEGAL_REQUEST, 0x20, 0);
  602. vscsi_send_rsp(s, req, CHECK_CONDITION, 0, 0);
  603. }
  604. return !fn;
  605. }
  606. static int vscsi_handle_srp_req(VSCSIState *s, vscsi_req *req)
  607. {
  608. union srp_iu *srp = &req->iu.srp;
  609. int done = 1;
  610. uint8_t opcode = srp->rsp.opcode;
  611. switch (opcode) {
  612. case SRP_LOGIN_REQ:
  613. vscsi_process_login(s, req);
  614. break;
  615. case SRP_TSK_MGMT:
  616. done = vscsi_process_tsk_mgmt(s, req);
  617. break;
  618. case SRP_CMD:
  619. done = vscsi_queue_cmd(s, req);
  620. break;
  621. case SRP_LOGIN_RSP:
  622. case SRP_I_LOGOUT:
  623. case SRP_T_LOGOUT:
  624. case SRP_RSP:
  625. case SRP_CRED_REQ:
  626. case SRP_CRED_RSP:
  627. case SRP_AER_REQ:
  628. case SRP_AER_RSP:
  629. fprintf(stderr, "VSCSI: Unsupported opcode %02x\n", opcode);
  630. break;
  631. default:
  632. fprintf(stderr, "VSCSI: Unknown type %02x\n", opcode);
  633. }
  634. return done;
  635. }
  636. static int vscsi_send_adapter_info(VSCSIState *s, vscsi_req *req)
  637. {
  638. struct viosrp_adapter_info *sinfo;
  639. struct mad_adapter_info_data info;
  640. int rc;
  641. sinfo = &req->iu.mad.adapter_info;
  642. #if 0 /* What for ? */
  643. rc = spapr_vio_dma_read(&s->vdev, be64_to_cpu(sinfo->buffer),
  644. &info, be16_to_cpu(sinfo->common.length));
  645. if (rc) {
  646. fprintf(stderr, "vscsi_send_adapter_info: DMA read failure !\n");
  647. }
  648. #endif
  649. memset(&info, 0, sizeof(info));
  650. strcpy(info.srp_version, SRP_VERSION);
  651. memcpy(info.partition_name, "qemu", sizeof("qemu"));
  652. info.partition_number = cpu_to_be32(0);
  653. info.mad_version = cpu_to_be32(1);
  654. info.os_type = cpu_to_be32(2);
  655. info.port_max_txu[0] = cpu_to_be32(VSCSI_MAX_SECTORS << 9);
  656. rc = spapr_vio_dma_write(&s->vdev, be64_to_cpu(sinfo->buffer),
  657. &info, be16_to_cpu(sinfo->common.length));
  658. if (rc) {
  659. fprintf(stderr, "vscsi_send_adapter_info: DMA write failure !\n");
  660. }
  661. sinfo->common.status = rc ? cpu_to_be32(1) : 0;
  662. return vscsi_send_iu(s, req, sizeof(*sinfo), VIOSRP_MAD_FORMAT);
  663. }
  664. static int vscsi_handle_mad_req(VSCSIState *s, vscsi_req *req)
  665. {
  666. union mad_iu *mad = &req->iu.mad;
  667. switch (be32_to_cpu(mad->empty_iu.common.type)) {
  668. case VIOSRP_EMPTY_IU_TYPE:
  669. fprintf(stderr, "Unsupported EMPTY MAD IU\n");
  670. break;
  671. case VIOSRP_ERROR_LOG_TYPE:
  672. fprintf(stderr, "Unsupported ERROR LOG MAD IU\n");
  673. mad->error_log.common.status = cpu_to_be16(1);
  674. vscsi_send_iu(s, req, sizeof(mad->error_log), VIOSRP_MAD_FORMAT);
  675. break;
  676. case VIOSRP_ADAPTER_INFO_TYPE:
  677. vscsi_send_adapter_info(s, req);
  678. break;
  679. case VIOSRP_HOST_CONFIG_TYPE:
  680. mad->host_config.common.status = cpu_to_be16(1);
  681. vscsi_send_iu(s, req, sizeof(mad->host_config), VIOSRP_MAD_FORMAT);
  682. break;
  683. default:
  684. fprintf(stderr, "VSCSI: Unknown MAD type %02x\n",
  685. be32_to_cpu(mad->empty_iu.common.type));
  686. }
  687. return 1;
  688. }
  689. static void vscsi_got_payload(VSCSIState *s, vscsi_crq *crq)
  690. {
  691. vscsi_req *req;
  692. int done;
  693. req = vscsi_get_req(s);
  694. if (req == NULL) {
  695. fprintf(stderr, "VSCSI: Failed to get a request !\n");
  696. return;
  697. }
  698. /* We only support a limited number of descriptors, we know
  699. * the ibmvscsi driver uses up to 10 max, so it should fit
  700. * in our 256 bytes IUs. If not we'll have to increase the size
  701. * of the structure.
  702. */
  703. if (crq->s.IU_length > sizeof(union viosrp_iu)) {
  704. fprintf(stderr, "VSCSI: SRP IU too long (%d bytes) !\n",
  705. crq->s.IU_length);
  706. vscsi_put_req(req);
  707. return;
  708. }
  709. /* XXX Handle failure differently ? */
  710. if (spapr_vio_dma_read(&s->vdev, crq->s.IU_data_ptr, &req->iu,
  711. crq->s.IU_length)) {
  712. fprintf(stderr, "vscsi_got_payload: DMA read failure !\n");
  713. vscsi_put_req(req);
  714. return;
  715. }
  716. memcpy(&req->crq, crq, sizeof(vscsi_crq));
  717. if (crq->s.format == VIOSRP_MAD_FORMAT) {
  718. done = vscsi_handle_mad_req(s, req);
  719. } else {
  720. done = vscsi_handle_srp_req(s, req);
  721. }
  722. if (done) {
  723. vscsi_put_req(req);
  724. }
  725. }
  726. static int vscsi_do_crq(struct VIOsPAPRDevice *dev, uint8_t *crq_data)
  727. {
  728. VSCSIState *s = DO_UPCAST(VSCSIState, vdev, dev);
  729. vscsi_crq crq;
  730. memcpy(crq.raw, crq_data, 16);
  731. crq.s.timeout = be16_to_cpu(crq.s.timeout);
  732. crq.s.IU_length = be16_to_cpu(crq.s.IU_length);
  733. crq.s.IU_data_ptr = be64_to_cpu(crq.s.IU_data_ptr);
  734. dprintf("VSCSI: do_crq %02x %02x ...\n", crq.raw[0], crq.raw[1]);
  735. switch (crq.s.valid) {
  736. case 0xc0: /* Init command/response */
  737. /* Respond to initialization request */
  738. if (crq.s.format == 0x01) {
  739. memset(crq.raw, 0, 16);
  740. crq.s.valid = 0xc0;
  741. crq.s.format = 0x02;
  742. spapr_vio_send_crq(dev, crq.raw);
  743. }
  744. /* Note that in hotplug cases, we might get a 0x02
  745. * as a result of us emitting the init request
  746. */
  747. break;
  748. case 0xff: /* Link event */
  749. /* Not handled for now */
  750. break;
  751. case 0x80: /* Payloads */
  752. switch (crq.s.format) {
  753. case VIOSRP_SRP_FORMAT: /* AKA VSCSI request */
  754. case VIOSRP_MAD_FORMAT: /* AKA VSCSI response */
  755. vscsi_got_payload(s, &crq);
  756. break;
  757. case VIOSRP_OS400_FORMAT:
  758. case VIOSRP_AIX_FORMAT:
  759. case VIOSRP_LINUX_FORMAT:
  760. case VIOSRP_INLINE_FORMAT:
  761. fprintf(stderr, "vscsi_do_srq: Unsupported payload format %02x\n",
  762. crq.s.format);
  763. break;
  764. default:
  765. fprintf(stderr, "vscsi_do_srq: Unknown payload format %02x\n",
  766. crq.s.format);
  767. }
  768. break;
  769. default:
  770. fprintf(stderr, "vscsi_do_crq: unknown CRQ %02x %02x ...\n",
  771. crq.raw[0], crq.raw[1]);
  772. };
  773. return 0;
  774. }
  775. static const struct SCSIBusInfo vscsi_scsi_info = {
  776. .tcq = true,
  777. .max_channel = 7, /* logical unit addressing format */
  778. .max_target = 63,
  779. .max_lun = 31,
  780. .transfer_data = vscsi_transfer_data,
  781. .complete = vscsi_command_complete,
  782. .cancel = vscsi_request_cancelled
  783. };
  784. static void spapr_vscsi_reset(VIOsPAPRDevice *dev)
  785. {
  786. VSCSIState *s = DO_UPCAST(VSCSIState, vdev, dev);
  787. int i;
  788. memset(s->reqs, 0, sizeof(s->reqs));
  789. for (i = 0; i < VSCSI_REQ_LIMIT; i++) {
  790. s->reqs[i].qtag = i;
  791. }
  792. }
  793. static int spapr_vscsi_init(VIOsPAPRDevice *dev)
  794. {
  795. VSCSIState *s = DO_UPCAST(VSCSIState, vdev, dev);
  796. dev->crq.SendFunc = vscsi_do_crq;
  797. scsi_bus_new(&s->bus, &dev->qdev, &vscsi_scsi_info);
  798. if (!dev->qdev.hotplugged) {
  799. scsi_bus_legacy_handle_cmdline(&s->bus);
  800. }
  801. return 0;
  802. }
  803. void spapr_vscsi_create(VIOsPAPRBus *bus)
  804. {
  805. DeviceState *dev;
  806. dev = qdev_create(&bus->bus, "spapr-vscsi");
  807. qdev_init_nofail(dev);
  808. }
  809. static int spapr_vscsi_devnode(VIOsPAPRDevice *dev, void *fdt, int node_off)
  810. {
  811. int ret;
  812. ret = fdt_setprop_cell(fdt, node_off, "#address-cells", 2);
  813. if (ret < 0) {
  814. return ret;
  815. }
  816. ret = fdt_setprop_cell(fdt, node_off, "#size-cells", 0);
  817. if (ret < 0) {
  818. return ret;
  819. }
  820. return 0;
  821. }
  822. static Property spapr_vscsi_properties[] = {
  823. DEFINE_SPAPR_PROPERTIES(VSCSIState, vdev),
  824. DEFINE_PROP_END_OF_LIST(),
  825. };
  826. static void spapr_vscsi_class_init(ObjectClass *klass, void *data)
  827. {
  828. DeviceClass *dc = DEVICE_CLASS(klass);
  829. VIOsPAPRDeviceClass *k = VIO_SPAPR_DEVICE_CLASS(klass);
  830. k->init = spapr_vscsi_init;
  831. k->reset = spapr_vscsi_reset;
  832. k->devnode = spapr_vscsi_devnode;
  833. k->dt_name = "v-scsi";
  834. k->dt_type = "vscsi";
  835. k->dt_compatible = "IBM,v-scsi";
  836. k->signal_mask = 0x00000001;
  837. dc->props = spapr_vscsi_properties;
  838. k->rtce_window_size = 0x10000000;
  839. }
  840. static const TypeInfo spapr_vscsi_info = {
  841. .name = "spapr-vscsi",
  842. .parent = TYPE_VIO_SPAPR_DEVICE,
  843. .instance_size = sizeof(VSCSIState),
  844. .class_init = spapr_vscsi_class_init,
  845. };
  846. static void spapr_vscsi_register_types(void)
  847. {
  848. type_register_static(&spapr_vscsi_info);
  849. }
  850. type_init(spapr_vscsi_register_types)