spapr_vscsi.c 37 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287
  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 "qemu/osdep.h"
  35. #include "qemu/module.h"
  36. #include "cpu.h"
  37. #include "hw/scsi/scsi.h"
  38. #include "migration/vmstate.h"
  39. #include "scsi/constants.h"
  40. #include "srp.h"
  41. #include "hw/ppc/spapr.h"
  42. #include "hw/ppc/spapr_vio.h"
  43. #include "hw/qdev-properties.h"
  44. #include "viosrp.h"
  45. #include "trace.h"
  46. #include <libfdt.h>
  47. /*
  48. * Virtual SCSI device
  49. */
  50. /* Random numbers */
  51. #define VSCSI_MAX_SECTORS 4096
  52. #define VSCSI_REQ_LIMIT 24
  53. #define SRP_RSP_SENSE_DATA_LEN 18
  54. #define SRP_REPORT_LUNS_WLUN 0xc10100000000000ULL
  55. typedef union vscsi_crq {
  56. struct viosrp_crq s;
  57. uint8_t raw[16];
  58. } vscsi_crq;
  59. typedef struct vscsi_req {
  60. vscsi_crq crq;
  61. union viosrp_iu iu;
  62. /* SCSI request tracking */
  63. SCSIRequest *sreq;
  64. uint32_t qtag; /* qemu tag != srp tag */
  65. bool active;
  66. bool writing;
  67. bool dma_error;
  68. uint32_t data_len;
  69. uint32_t senselen;
  70. uint8_t sense[SCSI_SENSE_BUF_SIZE];
  71. /* RDMA related bits */
  72. uint8_t dma_fmt;
  73. uint16_t local_desc;
  74. uint16_t total_desc;
  75. uint16_t cdb_offset;
  76. uint16_t cur_desc_num;
  77. uint16_t cur_desc_offset;
  78. } vscsi_req;
  79. #define TYPE_VIO_SPAPR_VSCSI_DEVICE "spapr-vscsi"
  80. #define VIO_SPAPR_VSCSI_DEVICE(obj) \
  81. OBJECT_CHECK(VSCSIState, (obj), TYPE_VIO_SPAPR_VSCSI_DEVICE)
  82. typedef struct {
  83. SpaprVioDevice vdev;
  84. SCSIBus bus;
  85. vscsi_req reqs[VSCSI_REQ_LIMIT];
  86. } VSCSIState;
  87. static struct vscsi_req *vscsi_get_req(VSCSIState *s)
  88. {
  89. vscsi_req *req;
  90. int i;
  91. for (i = 0; i < VSCSI_REQ_LIMIT; i++) {
  92. req = &s->reqs[i];
  93. if (!req->active) {
  94. memset(req, 0, sizeof(*req));
  95. req->qtag = i;
  96. req->active = 1;
  97. return req;
  98. }
  99. }
  100. return NULL;
  101. }
  102. static struct vscsi_req *vscsi_find_req(VSCSIState *s, uint64_t srp_tag)
  103. {
  104. vscsi_req *req;
  105. int i;
  106. for (i = 0; i < VSCSI_REQ_LIMIT; i++) {
  107. req = &s->reqs[i];
  108. if (req->iu.srp.cmd.tag == srp_tag) {
  109. return req;
  110. }
  111. }
  112. return NULL;
  113. }
  114. static void vscsi_put_req(vscsi_req *req)
  115. {
  116. if (req->sreq != NULL) {
  117. scsi_req_unref(req->sreq);
  118. }
  119. req->sreq = NULL;
  120. req->active = 0;
  121. }
  122. static SCSIDevice *vscsi_device_find(SCSIBus *bus, uint64_t srp_lun, int *lun)
  123. {
  124. int channel = 0, id = 0;
  125. retry:
  126. switch (srp_lun >> 62) {
  127. case 0:
  128. if ((srp_lun >> 56) != 0) {
  129. channel = (srp_lun >> 56) & 0x3f;
  130. id = (srp_lun >> 48) & 0xff;
  131. srp_lun <<= 16;
  132. goto retry;
  133. }
  134. *lun = (srp_lun >> 48) & 0xff;
  135. break;
  136. case 1:
  137. *lun = (srp_lun >> 48) & 0x3fff;
  138. break;
  139. case 2:
  140. channel = (srp_lun >> 53) & 0x7;
  141. id = (srp_lun >> 56) & 0x3f;
  142. *lun = (srp_lun >> 48) & 0x1f;
  143. break;
  144. case 3:
  145. *lun = -1;
  146. return NULL;
  147. default:
  148. abort();
  149. }
  150. return scsi_device_find(bus, channel, id, *lun);
  151. }
  152. static int vscsi_send_iu(VSCSIState *s, vscsi_req *req,
  153. uint64_t length, uint8_t format)
  154. {
  155. long rc, rc1;
  156. /* First copy the SRP */
  157. rc = spapr_vio_dma_write(&s->vdev, req->crq.s.IU_data_ptr,
  158. &req->iu, length);
  159. if (rc) {
  160. fprintf(stderr, "vscsi_send_iu: DMA write failure !\n");
  161. }
  162. req->crq.s.valid = 0x80;
  163. req->crq.s.format = format;
  164. req->crq.s.reserved = 0x00;
  165. req->crq.s.timeout = cpu_to_be16(0x0000);
  166. req->crq.s.IU_length = cpu_to_be16(length);
  167. req->crq.s.IU_data_ptr = req->iu.srp.rsp.tag; /* right byte order */
  168. if (rc == 0) {
  169. req->crq.s.status = VIOSRP_OK;
  170. } else {
  171. req->crq.s.status = VIOSRP_ADAPTER_FAIL;
  172. }
  173. rc1 = spapr_vio_send_crq(&s->vdev, req->crq.raw);
  174. if (rc1) {
  175. fprintf(stderr, "vscsi_send_iu: Error sending response\n");
  176. return rc1;
  177. }
  178. return rc;
  179. }
  180. static void vscsi_makeup_sense(VSCSIState *s, vscsi_req *req,
  181. uint8_t key, uint8_t asc, uint8_t ascq)
  182. {
  183. req->senselen = SRP_RSP_SENSE_DATA_LEN;
  184. /* Valid bit and 'current errors' */
  185. req->sense[0] = (0x1 << 7 | 0x70);
  186. /* Sense key */
  187. req->sense[2] = key;
  188. /* Additional sense length */
  189. req->sense[7] = 0xa; /* 10 bytes */
  190. /* Additional sense code */
  191. req->sense[12] = asc;
  192. req->sense[13] = ascq;
  193. }
  194. static int vscsi_send_rsp(VSCSIState *s, vscsi_req *req,
  195. uint8_t status, int32_t res_in, int32_t res_out)
  196. {
  197. union viosrp_iu *iu = &req->iu;
  198. uint64_t tag = iu->srp.rsp.tag;
  199. int total_len = sizeof(iu->srp.rsp);
  200. uint8_t sol_not = iu->srp.cmd.sol_not;
  201. trace_spapr_vscsi_send_rsp(status, res_in, res_out);
  202. memset(iu, 0, sizeof(struct srp_rsp));
  203. iu->srp.rsp.opcode = SRP_RSP;
  204. iu->srp.rsp.req_lim_delta = cpu_to_be32(1);
  205. iu->srp.rsp.tag = tag;
  206. /* Handle residuals */
  207. if (res_in < 0) {
  208. iu->srp.rsp.flags |= SRP_RSP_FLAG_DIUNDER;
  209. res_in = -res_in;
  210. } else if (res_in) {
  211. iu->srp.rsp.flags |= SRP_RSP_FLAG_DIOVER;
  212. }
  213. if (res_out < 0) {
  214. iu->srp.rsp.flags |= SRP_RSP_FLAG_DOUNDER;
  215. res_out = -res_out;
  216. } else if (res_out) {
  217. iu->srp.rsp.flags |= SRP_RSP_FLAG_DOOVER;
  218. }
  219. iu->srp.rsp.data_in_res_cnt = cpu_to_be32(res_in);
  220. iu->srp.rsp.data_out_res_cnt = cpu_to_be32(res_out);
  221. /* We don't do response data */
  222. /* iu->srp.rsp.flags &= ~SRP_RSP_FLAG_RSPVALID; */
  223. iu->srp.rsp.resp_data_len = cpu_to_be32(0);
  224. /* Handle success vs. failure */
  225. iu->srp.rsp.status = status;
  226. if (status) {
  227. iu->srp.rsp.sol_not = (sol_not & 0x04) >> 2;
  228. if (req->senselen) {
  229. req->iu.srp.rsp.flags |= SRP_RSP_FLAG_SNSVALID;
  230. req->iu.srp.rsp.sense_data_len = cpu_to_be32(req->senselen);
  231. memcpy(req->iu.srp.rsp.data, req->sense, req->senselen);
  232. total_len += req->senselen;
  233. }
  234. } else {
  235. iu->srp.rsp.sol_not = (sol_not & 0x02) >> 1;
  236. }
  237. vscsi_send_iu(s, req, total_len, VIOSRP_SRP_FORMAT);
  238. return 0;
  239. }
  240. static inline struct srp_direct_buf vscsi_swap_desc(struct srp_direct_buf desc)
  241. {
  242. desc.va = be64_to_cpu(desc.va);
  243. desc.len = be32_to_cpu(desc.len);
  244. return desc;
  245. }
  246. static int vscsi_fetch_desc(VSCSIState *s, struct vscsi_req *req,
  247. unsigned n, unsigned buf_offset,
  248. struct srp_direct_buf *ret)
  249. {
  250. struct srp_cmd *cmd = &req->iu.srp.cmd;
  251. switch (req->dma_fmt) {
  252. case SRP_NO_DATA_DESC: {
  253. trace_spapr_vscsi_fetch_desc_no_data();
  254. return 0;
  255. }
  256. case SRP_DATA_DESC_DIRECT: {
  257. memcpy(ret, cmd->add_data + req->cdb_offset, sizeof(*ret));
  258. assert(req->cur_desc_num == 0);
  259. trace_spapr_vscsi_fetch_desc_direct();
  260. break;
  261. }
  262. case SRP_DATA_DESC_INDIRECT: {
  263. struct srp_indirect_buf *tmp = (struct srp_indirect_buf *)
  264. (cmd->add_data + req->cdb_offset);
  265. if (n < req->local_desc) {
  266. *ret = tmp->desc_list[n];
  267. trace_spapr_vscsi_fetch_desc_indirect(req->qtag, n,
  268. req->local_desc);
  269. } else if (n < req->total_desc) {
  270. int rc;
  271. struct srp_direct_buf tbl_desc = vscsi_swap_desc(tmp->table_desc);
  272. unsigned desc_offset = n * sizeof(struct srp_direct_buf);
  273. if (desc_offset >= tbl_desc.len) {
  274. trace_spapr_vscsi_fetch_desc_out_of_range(n, desc_offset);
  275. return -1;
  276. }
  277. rc = spapr_vio_dma_read(&s->vdev, tbl_desc.va + desc_offset,
  278. ret, sizeof(struct srp_direct_buf));
  279. if (rc) {
  280. trace_spapr_vscsi_fetch_desc_dma_read_error(rc);
  281. return -1;
  282. }
  283. trace_spapr_vscsi_fetch_desc_indirect_seg_ext(req->qtag, n,
  284. req->total_desc,
  285. tbl_desc.va,
  286. tbl_desc.len);
  287. } else {
  288. trace_spapr_vscsi_fetch_desc_out_of_desc();
  289. return 0;
  290. }
  291. break;
  292. }
  293. default:
  294. fprintf(stderr, "VSCSI: Unknown format %x\n", req->dma_fmt);
  295. return -1;
  296. }
  297. *ret = vscsi_swap_desc(*ret);
  298. if (buf_offset > ret->len) {
  299. trace_spapr_vscsi_fetch_desc_out_of_desc_boundary(buf_offset,
  300. req->cur_desc_num,
  301. ret->len);
  302. return -1;
  303. }
  304. ret->va += buf_offset;
  305. ret->len -= buf_offset;
  306. trace_spapr_vscsi_fetch_desc_done(req->cur_desc_num, req->cur_desc_offset,
  307. ret->va, ret->len);
  308. return ret->len ? 1 : 0;
  309. }
  310. static int vscsi_srp_direct_data(VSCSIState *s, vscsi_req *req,
  311. uint8_t *buf, uint32_t len)
  312. {
  313. struct srp_direct_buf md;
  314. uint32_t llen;
  315. int rc = 0;
  316. rc = vscsi_fetch_desc(s, req, req->cur_desc_num, req->cur_desc_offset, &md);
  317. if (rc < 0) {
  318. return -1;
  319. } else if (rc == 0) {
  320. return 0;
  321. }
  322. llen = MIN(len, md.len);
  323. if (llen) {
  324. if (req->writing) { /* writing = to device = reading from memory */
  325. rc = spapr_vio_dma_read(&s->vdev, md.va, buf, llen);
  326. } else {
  327. rc = spapr_vio_dma_write(&s->vdev, md.va, buf, llen);
  328. }
  329. }
  330. if (rc) {
  331. return -1;
  332. }
  333. req->cur_desc_offset += llen;
  334. return llen;
  335. }
  336. static int vscsi_srp_indirect_data(VSCSIState *s, vscsi_req *req,
  337. uint8_t *buf, uint32_t len)
  338. {
  339. struct srp_direct_buf md;
  340. int rc = 0;
  341. uint32_t llen, total = 0;
  342. trace_spapr_vscsi_srp_indirect_data(len);
  343. /* While we have data ... */
  344. while (len) {
  345. rc = vscsi_fetch_desc(s, req, req->cur_desc_num, req->cur_desc_offset, &md);
  346. if (rc < 0) {
  347. return -1;
  348. } else if (rc == 0) {
  349. break;
  350. }
  351. /* Perform transfer */
  352. llen = MIN(len, md.len);
  353. if (req->writing) { /* writing = to device = reading from memory */
  354. rc = spapr_vio_dma_read(&s->vdev, md.va, buf, llen);
  355. } else {
  356. rc = spapr_vio_dma_write(&s->vdev, md.va, buf, llen);
  357. }
  358. if (rc) {
  359. trace_spapr_vscsi_srp_indirect_data_rw(req->writing, rc);
  360. break;
  361. }
  362. trace_spapr_vscsi_srp_indirect_data_buf(buf[0], buf[1], buf[2], buf[3]);
  363. len -= llen;
  364. buf += llen;
  365. total += llen;
  366. /* Update current position in the current descriptor */
  367. req->cur_desc_offset += llen;
  368. if (md.len == llen) {
  369. /* Go to the next descriptor if the current one finished */
  370. ++req->cur_desc_num;
  371. req->cur_desc_offset = 0;
  372. }
  373. }
  374. return rc ? -1 : total;
  375. }
  376. static int vscsi_srp_transfer_data(VSCSIState *s, vscsi_req *req,
  377. int writing, uint8_t *buf, uint32_t len)
  378. {
  379. int err = 0;
  380. switch (req->dma_fmt) {
  381. case SRP_NO_DATA_DESC:
  382. trace_spapr_vscsi_srp_transfer_data(len);
  383. break;
  384. case SRP_DATA_DESC_DIRECT:
  385. err = vscsi_srp_direct_data(s, req, buf, len);
  386. break;
  387. case SRP_DATA_DESC_INDIRECT:
  388. err = vscsi_srp_indirect_data(s, req, buf, len);
  389. break;
  390. }
  391. return err;
  392. }
  393. /* Bits from linux srp */
  394. static int data_out_desc_size(struct srp_cmd *cmd)
  395. {
  396. int size = 0;
  397. uint8_t fmt = cmd->buf_fmt >> 4;
  398. switch (fmt) {
  399. case SRP_NO_DATA_DESC:
  400. break;
  401. case SRP_DATA_DESC_DIRECT:
  402. size = sizeof(struct srp_direct_buf);
  403. break;
  404. case SRP_DATA_DESC_INDIRECT:
  405. size = sizeof(struct srp_indirect_buf) +
  406. sizeof(struct srp_direct_buf)*cmd->data_out_desc_cnt;
  407. break;
  408. default:
  409. break;
  410. }
  411. return size;
  412. }
  413. static int vscsi_preprocess_desc(vscsi_req *req)
  414. {
  415. struct srp_cmd *cmd = &req->iu.srp.cmd;
  416. req->cdb_offset = cmd->add_cdb_len & ~3;
  417. if (req->writing) {
  418. req->dma_fmt = cmd->buf_fmt >> 4;
  419. } else {
  420. req->cdb_offset += data_out_desc_size(cmd);
  421. req->dma_fmt = cmd->buf_fmt & ((1U << 4) - 1);
  422. }
  423. switch (req->dma_fmt) {
  424. case SRP_NO_DATA_DESC:
  425. break;
  426. case SRP_DATA_DESC_DIRECT:
  427. req->total_desc = req->local_desc = 1;
  428. break;
  429. case SRP_DATA_DESC_INDIRECT: {
  430. struct srp_indirect_buf *ind_tmp = (struct srp_indirect_buf *)
  431. (cmd->add_data + req->cdb_offset);
  432. req->total_desc = be32_to_cpu(ind_tmp->table_desc.len) /
  433. sizeof(struct srp_direct_buf);
  434. req->local_desc = req->writing ? cmd->data_out_desc_cnt :
  435. cmd->data_in_desc_cnt;
  436. break;
  437. }
  438. default:
  439. fprintf(stderr,
  440. "vscsi_preprocess_desc: Unknown format %x\n", req->dma_fmt);
  441. return -1;
  442. }
  443. return 0;
  444. }
  445. /* Callback to indicate that the SCSI layer has completed a transfer. */
  446. static void vscsi_transfer_data(SCSIRequest *sreq, uint32_t len)
  447. {
  448. VSCSIState *s = VIO_SPAPR_VSCSI_DEVICE(sreq->bus->qbus.parent);
  449. vscsi_req *req = sreq->hba_private;
  450. uint8_t *buf;
  451. int rc = 0;
  452. trace_spapr_vscsi_transfer_data(sreq->tag, len, req);
  453. if (req == NULL) {
  454. fprintf(stderr, "VSCSI: Can't find request for tag 0x%x\n", sreq->tag);
  455. return;
  456. }
  457. if (len) {
  458. buf = scsi_req_get_buf(sreq);
  459. rc = vscsi_srp_transfer_data(s, req, req->writing, buf, len);
  460. }
  461. if (rc < 0) {
  462. fprintf(stderr, "VSCSI: RDMA error rc=%d!\n", rc);
  463. req->dma_error = true;
  464. scsi_req_cancel(req->sreq);
  465. return;
  466. }
  467. /* Start next chunk */
  468. req->data_len -= rc;
  469. scsi_req_continue(sreq);
  470. }
  471. /* Callback to indicate that the SCSI layer has completed a transfer. */
  472. static void vscsi_command_complete(SCSIRequest *sreq, uint32_t status, size_t resid)
  473. {
  474. VSCSIState *s = VIO_SPAPR_VSCSI_DEVICE(sreq->bus->qbus.parent);
  475. vscsi_req *req = sreq->hba_private;
  476. int32_t res_in = 0, res_out = 0;
  477. trace_spapr_vscsi_command_complete(sreq->tag, status, req);
  478. if (req == NULL) {
  479. fprintf(stderr, "VSCSI: Can't find request for tag 0x%x\n", sreq->tag);
  480. return;
  481. }
  482. if (status == CHECK_CONDITION) {
  483. req->senselen = scsi_req_get_sense(req->sreq, req->sense,
  484. sizeof(req->sense));
  485. trace_spapr_vscsi_command_complete_sense_data1(req->senselen,
  486. req->sense[0], req->sense[1], req->sense[2], req->sense[3],
  487. req->sense[4], req->sense[5], req->sense[6], req->sense[7]);
  488. trace_spapr_vscsi_command_complete_sense_data2(
  489. req->sense[8], req->sense[9], req->sense[10], req->sense[11],
  490. req->sense[12], req->sense[13], req->sense[14], req->sense[15]);
  491. }
  492. trace_spapr_vscsi_command_complete_status(status);
  493. if (status == 0) {
  494. /* We handle overflows, not underflows for normal commands,
  495. * but hopefully nobody cares
  496. */
  497. if (req->writing) {
  498. res_out = req->data_len;
  499. } else {
  500. res_in = req->data_len;
  501. }
  502. }
  503. vscsi_send_rsp(s, req, status, res_in, res_out);
  504. vscsi_put_req(req);
  505. }
  506. static void vscsi_request_cancelled(SCSIRequest *sreq)
  507. {
  508. vscsi_req *req = sreq->hba_private;
  509. if (req->dma_error) {
  510. VSCSIState *s = VIO_SPAPR_VSCSI_DEVICE(sreq->bus->qbus.parent);
  511. vscsi_makeup_sense(s, req, HARDWARE_ERROR, 0, 0);
  512. vscsi_send_rsp(s, req, CHECK_CONDITION, 0, 0);
  513. }
  514. vscsi_put_req(req);
  515. }
  516. static const VMStateDescription vmstate_spapr_vscsi_req = {
  517. .name = "spapr_vscsi_req",
  518. .version_id = 1,
  519. .minimum_version_id = 1,
  520. .fields = (VMStateField[]) {
  521. VMSTATE_BUFFER(crq.raw, vscsi_req),
  522. VMSTATE_BUFFER(iu.srp.reserved, vscsi_req),
  523. VMSTATE_UINT32(qtag, vscsi_req),
  524. VMSTATE_BOOL(active, vscsi_req),
  525. VMSTATE_UINT32(data_len, vscsi_req),
  526. VMSTATE_BOOL(writing, vscsi_req),
  527. VMSTATE_UINT32(senselen, vscsi_req),
  528. VMSTATE_BUFFER(sense, vscsi_req),
  529. VMSTATE_UINT8(dma_fmt, vscsi_req),
  530. VMSTATE_UINT16(local_desc, vscsi_req),
  531. VMSTATE_UINT16(total_desc, vscsi_req),
  532. VMSTATE_UINT16(cdb_offset, vscsi_req),
  533. /*Restart SCSI request from the beginning for now */
  534. /*VMSTATE_UINT16(cur_desc_num, vscsi_req),
  535. VMSTATE_UINT16(cur_desc_offset, vscsi_req),*/
  536. VMSTATE_END_OF_LIST()
  537. },
  538. };
  539. static void vscsi_save_request(QEMUFile *f, SCSIRequest *sreq)
  540. {
  541. vscsi_req *req = sreq->hba_private;
  542. assert(req->active);
  543. vmstate_save_state(f, &vmstate_spapr_vscsi_req, req, NULL);
  544. trace_spapr_vscsi_save_request(req->qtag, req->cur_desc_num,
  545. req->cur_desc_offset);
  546. }
  547. static void *vscsi_load_request(QEMUFile *f, SCSIRequest *sreq)
  548. {
  549. SCSIBus *bus = sreq->bus;
  550. VSCSIState *s = VIO_SPAPR_VSCSI_DEVICE(bus->qbus.parent);
  551. vscsi_req *req;
  552. int rc;
  553. assert(sreq->tag < VSCSI_REQ_LIMIT);
  554. req = &s->reqs[sreq->tag];
  555. assert(!req->active);
  556. memset(req, 0, sizeof(*req));
  557. rc = vmstate_load_state(f, &vmstate_spapr_vscsi_req, req, 1);
  558. if (rc) {
  559. fprintf(stderr, "VSCSI: failed loading request tag#%u\n", sreq->tag);
  560. return NULL;
  561. }
  562. assert(req->active);
  563. req->sreq = scsi_req_ref(sreq);
  564. trace_spapr_vscsi_load_request(req->qtag, req->cur_desc_num,
  565. req->cur_desc_offset);
  566. return req;
  567. }
  568. static void vscsi_process_login(VSCSIState *s, vscsi_req *req)
  569. {
  570. union viosrp_iu *iu = &req->iu;
  571. struct srp_login_rsp *rsp = &iu->srp.login_rsp;
  572. uint64_t tag = iu->srp.rsp.tag;
  573. trace_spapr_vscsi_process_login();
  574. /* TODO handle case that requested size is wrong and
  575. * buffer format is wrong
  576. */
  577. memset(iu, 0, sizeof(struct srp_login_rsp));
  578. rsp->opcode = SRP_LOGIN_RSP;
  579. /* Don't advertise quite as many request as we support to
  580. * keep room for management stuff etc...
  581. */
  582. rsp->req_lim_delta = cpu_to_be32(VSCSI_REQ_LIMIT-2);
  583. rsp->tag = tag;
  584. rsp->max_it_iu_len = cpu_to_be32(sizeof(union srp_iu));
  585. rsp->max_ti_iu_len = cpu_to_be32(sizeof(union srp_iu));
  586. /* direct and indirect */
  587. rsp->buf_fmt = cpu_to_be16(SRP_BUF_FORMAT_DIRECT | SRP_BUF_FORMAT_INDIRECT);
  588. vscsi_send_iu(s, req, sizeof(*rsp), VIOSRP_SRP_FORMAT);
  589. }
  590. static void vscsi_inquiry_no_target(VSCSIState *s, vscsi_req *req)
  591. {
  592. uint8_t *cdb = req->iu.srp.cmd.cdb;
  593. uint8_t resp_data[36];
  594. int rc, len, alen;
  595. /* We don't do EVPD. Also check that page_code is 0 */
  596. if ((cdb[1] & 0x01) || cdb[2] != 0) {
  597. /* Send INVALID FIELD IN CDB */
  598. vscsi_makeup_sense(s, req, ILLEGAL_REQUEST, 0x24, 0);
  599. vscsi_send_rsp(s, req, CHECK_CONDITION, 0, 0);
  600. return;
  601. }
  602. alen = cdb[3];
  603. alen = (alen << 8) | cdb[4];
  604. len = MIN(alen, 36);
  605. /* Fake up inquiry using PQ=3 */
  606. memset(resp_data, 0, 36);
  607. resp_data[0] = 0x7f; /* Not capable of supporting a device here */
  608. resp_data[2] = 0x06; /* SPS-4 */
  609. resp_data[3] = 0x02; /* Resp data format */
  610. resp_data[4] = 36 - 5; /* Additional length */
  611. resp_data[7] = 0x10; /* Sync transfers */
  612. memcpy(&resp_data[16], "QEMU EMPTY ", 16);
  613. memcpy(&resp_data[8], "QEMU ", 8);
  614. req->writing = 0;
  615. vscsi_preprocess_desc(req);
  616. rc = vscsi_srp_transfer_data(s, req, 0, resp_data, len);
  617. if (rc < 0) {
  618. vscsi_makeup_sense(s, req, HARDWARE_ERROR, 0, 0);
  619. vscsi_send_rsp(s, req, CHECK_CONDITION, 0, 0);
  620. } else {
  621. vscsi_send_rsp(s, req, 0, 36 - rc, 0);
  622. }
  623. }
  624. static void vscsi_report_luns(VSCSIState *s, vscsi_req *req)
  625. {
  626. BusChild *kid;
  627. int i, len, n, rc;
  628. uint8_t *resp_data;
  629. bool found_lun0;
  630. n = 0;
  631. found_lun0 = false;
  632. QTAILQ_FOREACH(kid, &s->bus.qbus.children, sibling) {
  633. SCSIDevice *dev = SCSI_DEVICE(kid->child);
  634. n += 8;
  635. if (dev->channel == 0 && dev->id == 0 && dev->lun == 0) {
  636. found_lun0 = true;
  637. }
  638. }
  639. if (!found_lun0) {
  640. n += 8;
  641. }
  642. len = n+8;
  643. resp_data = g_malloc0(len);
  644. stl_be_p(resp_data, n);
  645. i = found_lun0 ? 8 : 16;
  646. QTAILQ_FOREACH(kid, &s->bus.qbus.children, sibling) {
  647. DeviceState *qdev = kid->child;
  648. SCSIDevice *dev = SCSI_DEVICE(qdev);
  649. if (dev->id == 0 && dev->channel == 0) {
  650. resp_data[i] = 0; /* Use simple LUN for 0 (SAM5 4.7.7.1) */
  651. } else {
  652. resp_data[i] = (2 << 6); /* Otherwise LUN addressing (4.7.7.4) */
  653. }
  654. resp_data[i] |= dev->id;
  655. resp_data[i+1] = (dev->channel << 5);
  656. resp_data[i+1] |= dev->lun;
  657. i += 8;
  658. }
  659. vscsi_preprocess_desc(req);
  660. rc = vscsi_srp_transfer_data(s, req, 0, resp_data, len);
  661. g_free(resp_data);
  662. if (rc < 0) {
  663. vscsi_makeup_sense(s, req, HARDWARE_ERROR, 0, 0);
  664. vscsi_send_rsp(s, req, CHECK_CONDITION, 0, 0);
  665. } else {
  666. vscsi_send_rsp(s, req, 0, len - rc, 0);
  667. }
  668. }
  669. static int vscsi_queue_cmd(VSCSIState *s, vscsi_req *req)
  670. {
  671. union srp_iu *srp = &req->iu.srp;
  672. SCSIDevice *sdev;
  673. int n, lun;
  674. if ((srp->cmd.lun == 0 || be64_to_cpu(srp->cmd.lun) == SRP_REPORT_LUNS_WLUN)
  675. && srp->cmd.cdb[0] == REPORT_LUNS) {
  676. vscsi_report_luns(s, req);
  677. return 0;
  678. }
  679. sdev = vscsi_device_find(&s->bus, be64_to_cpu(srp->cmd.lun), &lun);
  680. if (!sdev) {
  681. trace_spapr_vscsi_queue_cmd_no_drive(be64_to_cpu(srp->cmd.lun));
  682. if (srp->cmd.cdb[0] == INQUIRY) {
  683. vscsi_inquiry_no_target(s, req);
  684. } else {
  685. vscsi_makeup_sense(s, req, ILLEGAL_REQUEST, 0x24, 0x00);
  686. vscsi_send_rsp(s, req, CHECK_CONDITION, 0, 0);
  687. } return 1;
  688. }
  689. req->sreq = scsi_req_new(sdev, req->qtag, lun, srp->cmd.cdb, req);
  690. n = scsi_req_enqueue(req->sreq);
  691. trace_spapr_vscsi_queue_cmd(req->qtag, srp->cmd.cdb[0],
  692. scsi_command_name(srp->cmd.cdb[0]), lun, n);
  693. if (n) {
  694. /* Transfer direction must be set before preprocessing the
  695. * descriptors
  696. */
  697. req->writing = (n < 1);
  698. /* Preprocess RDMA descriptors */
  699. vscsi_preprocess_desc(req);
  700. /* Get transfer direction and initiate transfer */
  701. if (n > 0) {
  702. req->data_len = n;
  703. } else if (n < 0) {
  704. req->data_len = -n;
  705. }
  706. scsi_req_continue(req->sreq);
  707. }
  708. /* Don't touch req here, it may have been recycled already */
  709. return 0;
  710. }
  711. static int vscsi_process_tsk_mgmt(VSCSIState *s, vscsi_req *req)
  712. {
  713. union viosrp_iu *iu = &req->iu;
  714. vscsi_req *tmpreq;
  715. int i, lun = 0, resp = SRP_TSK_MGMT_COMPLETE;
  716. SCSIDevice *d;
  717. uint64_t tag = iu->srp.rsp.tag;
  718. uint8_t sol_not = iu->srp.cmd.sol_not;
  719. fprintf(stderr, "vscsi_process_tsk_mgmt %02x\n",
  720. iu->srp.tsk_mgmt.tsk_mgmt_func);
  721. d = vscsi_device_find(&s->bus, be64_to_cpu(req->iu.srp.tsk_mgmt.lun), &lun);
  722. if (!d) {
  723. resp = SRP_TSK_MGMT_FIELDS_INVALID;
  724. } else {
  725. switch (iu->srp.tsk_mgmt.tsk_mgmt_func) {
  726. case SRP_TSK_ABORT_TASK:
  727. if (d->lun != lun) {
  728. resp = SRP_TSK_MGMT_FIELDS_INVALID;
  729. break;
  730. }
  731. tmpreq = vscsi_find_req(s, req->iu.srp.tsk_mgmt.task_tag);
  732. if (tmpreq && tmpreq->sreq) {
  733. assert(tmpreq->sreq->hba_private);
  734. scsi_req_cancel(tmpreq->sreq);
  735. }
  736. break;
  737. case SRP_TSK_LUN_RESET:
  738. if (d->lun != lun) {
  739. resp = SRP_TSK_MGMT_FIELDS_INVALID;
  740. break;
  741. }
  742. qdev_reset_all(&d->qdev);
  743. break;
  744. case SRP_TSK_ABORT_TASK_SET:
  745. case SRP_TSK_CLEAR_TASK_SET:
  746. if (d->lun != lun) {
  747. resp = SRP_TSK_MGMT_FIELDS_INVALID;
  748. break;
  749. }
  750. for (i = 0; i < VSCSI_REQ_LIMIT; i++) {
  751. tmpreq = &s->reqs[i];
  752. if (tmpreq->iu.srp.cmd.lun != req->iu.srp.tsk_mgmt.lun) {
  753. continue;
  754. }
  755. if (!tmpreq->active || !tmpreq->sreq) {
  756. continue;
  757. }
  758. assert(tmpreq->sreq->hba_private);
  759. scsi_req_cancel(tmpreq->sreq);
  760. }
  761. break;
  762. case SRP_TSK_CLEAR_ACA:
  763. resp = SRP_TSK_MGMT_NOT_SUPPORTED;
  764. break;
  765. default:
  766. resp = SRP_TSK_MGMT_FIELDS_INVALID;
  767. break;
  768. }
  769. }
  770. /* Compose the response here as */
  771. memset(iu, 0, sizeof(struct srp_rsp) + 4);
  772. iu->srp.rsp.opcode = SRP_RSP;
  773. iu->srp.rsp.req_lim_delta = cpu_to_be32(1);
  774. iu->srp.rsp.tag = tag;
  775. iu->srp.rsp.flags |= SRP_RSP_FLAG_RSPVALID;
  776. iu->srp.rsp.resp_data_len = cpu_to_be32(4);
  777. if (resp) {
  778. iu->srp.rsp.sol_not = (sol_not & 0x04) >> 2;
  779. } else {
  780. iu->srp.rsp.sol_not = (sol_not & 0x02) >> 1;
  781. }
  782. iu->srp.rsp.status = GOOD;
  783. iu->srp.rsp.data[3] = resp;
  784. vscsi_send_iu(s, req, sizeof(iu->srp.rsp) + 4, VIOSRP_SRP_FORMAT);
  785. return 1;
  786. }
  787. static int vscsi_handle_srp_req(VSCSIState *s, vscsi_req *req)
  788. {
  789. union srp_iu *srp = &req->iu.srp;
  790. int done = 1;
  791. uint8_t opcode = srp->rsp.opcode;
  792. switch (opcode) {
  793. case SRP_LOGIN_REQ:
  794. vscsi_process_login(s, req);
  795. break;
  796. case SRP_TSK_MGMT:
  797. done = vscsi_process_tsk_mgmt(s, req);
  798. break;
  799. case SRP_CMD:
  800. done = vscsi_queue_cmd(s, req);
  801. break;
  802. case SRP_LOGIN_RSP:
  803. case SRP_I_LOGOUT:
  804. case SRP_T_LOGOUT:
  805. case SRP_RSP:
  806. case SRP_CRED_REQ:
  807. case SRP_CRED_RSP:
  808. case SRP_AER_REQ:
  809. case SRP_AER_RSP:
  810. fprintf(stderr, "VSCSI: Unsupported opcode %02x\n", opcode);
  811. break;
  812. default:
  813. fprintf(stderr, "VSCSI: Unknown type %02x\n", opcode);
  814. }
  815. return done;
  816. }
  817. static int vscsi_send_adapter_info(VSCSIState *s, vscsi_req *req)
  818. {
  819. struct viosrp_adapter_info *sinfo;
  820. struct mad_adapter_info_data info;
  821. int rc;
  822. sinfo = &req->iu.mad.adapter_info;
  823. #if 0 /* What for ? */
  824. rc = spapr_vio_dma_read(&s->vdev, be64_to_cpu(sinfo->buffer),
  825. &info, be16_to_cpu(sinfo->common.length));
  826. if (rc) {
  827. fprintf(stderr, "vscsi_send_adapter_info: DMA read failure !\n");
  828. }
  829. #endif
  830. memset(&info, 0, sizeof(info));
  831. strcpy(info.srp_version, SRP_VERSION);
  832. memcpy(info.partition_name, "qemu", sizeof("qemu"));
  833. info.partition_number = cpu_to_be32(0);
  834. info.mad_version = cpu_to_be32(1);
  835. info.os_type = cpu_to_be32(2);
  836. info.port_max_txu[0] = cpu_to_be32(VSCSI_MAX_SECTORS << 9);
  837. rc = spapr_vio_dma_write(&s->vdev, be64_to_cpu(sinfo->buffer),
  838. &info, be16_to_cpu(sinfo->common.length));
  839. if (rc) {
  840. fprintf(stderr, "vscsi_send_adapter_info: DMA write failure !\n");
  841. }
  842. sinfo->common.status = rc ? cpu_to_be32(1) : 0;
  843. return vscsi_send_iu(s, req, sizeof(*sinfo), VIOSRP_MAD_FORMAT);
  844. }
  845. static int vscsi_send_capabilities(VSCSIState *s, vscsi_req *req)
  846. {
  847. struct viosrp_capabilities *vcap;
  848. struct capabilities cap = { };
  849. uint16_t len, req_len;
  850. uint64_t buffer;
  851. int rc;
  852. vcap = &req->iu.mad.capabilities;
  853. req_len = len = be16_to_cpu(vcap->common.length);
  854. buffer = be64_to_cpu(vcap->buffer);
  855. if (len > sizeof(cap)) {
  856. fprintf(stderr, "vscsi_send_capabilities: capabilities size mismatch !\n");
  857. /*
  858. * Just read and populate the structure that is known.
  859. * Zero rest of the structure.
  860. */
  861. len = sizeof(cap);
  862. }
  863. rc = spapr_vio_dma_read(&s->vdev, buffer, &cap, len);
  864. if (rc) {
  865. fprintf(stderr, "vscsi_send_capabilities: DMA read failure !\n");
  866. }
  867. /*
  868. * Current implementation does not suppport any migration or
  869. * reservation capabilities. Construct the response telling the
  870. * guest not to use them.
  871. */
  872. cap.flags = 0;
  873. cap.migration.ecl = 0;
  874. cap.reserve.type = 0;
  875. cap.migration.common.server_support = 0;
  876. cap.reserve.common.server_support = 0;
  877. rc = spapr_vio_dma_write(&s->vdev, buffer, &cap, len);
  878. if (rc) {
  879. fprintf(stderr, "vscsi_send_capabilities: DMA write failure !\n");
  880. }
  881. if (req_len > len) {
  882. /*
  883. * Being paranoid and lets not worry about the error code
  884. * here. Actual write of the cap is done above.
  885. */
  886. spapr_vio_dma_set(&s->vdev, (buffer + len), 0, (req_len - len));
  887. }
  888. vcap->common.status = rc ? cpu_to_be32(1) : 0;
  889. return vscsi_send_iu(s, req, sizeof(*vcap), VIOSRP_MAD_FORMAT);
  890. }
  891. static int vscsi_handle_mad_req(VSCSIState *s, vscsi_req *req)
  892. {
  893. union mad_iu *mad = &req->iu.mad;
  894. bool request_handled = false;
  895. uint64_t retlen = 0;
  896. switch (be32_to_cpu(mad->empty_iu.common.type)) {
  897. case VIOSRP_EMPTY_IU_TYPE:
  898. fprintf(stderr, "Unsupported EMPTY MAD IU\n");
  899. retlen = sizeof(mad->empty_iu);
  900. break;
  901. case VIOSRP_ERROR_LOG_TYPE:
  902. fprintf(stderr, "Unsupported ERROR LOG MAD IU\n");
  903. retlen = sizeof(mad->error_log);
  904. break;
  905. case VIOSRP_ADAPTER_INFO_TYPE:
  906. vscsi_send_adapter_info(s, req);
  907. request_handled = true;
  908. break;
  909. case VIOSRP_HOST_CONFIG_TYPE:
  910. retlen = sizeof(mad->host_config);
  911. break;
  912. case VIOSRP_CAPABILITIES_TYPE:
  913. vscsi_send_capabilities(s, req);
  914. request_handled = true;
  915. break;
  916. default:
  917. fprintf(stderr, "VSCSI: Unknown MAD type %02x\n",
  918. be32_to_cpu(mad->empty_iu.common.type));
  919. /*
  920. * PAPR+ says that "The length field is set to the length
  921. * of the data structure(s) used in the command".
  922. * As we did not recognize the request type, put zero there.
  923. */
  924. retlen = 0;
  925. }
  926. if (!request_handled) {
  927. mad->empty_iu.common.status = cpu_to_be16(VIOSRP_MAD_NOT_SUPPORTED);
  928. vscsi_send_iu(s, req, retlen, VIOSRP_MAD_FORMAT);
  929. }
  930. return 1;
  931. }
  932. static void vscsi_got_payload(VSCSIState *s, vscsi_crq *crq)
  933. {
  934. vscsi_req *req;
  935. int done;
  936. req = vscsi_get_req(s);
  937. if (req == NULL) {
  938. fprintf(stderr, "VSCSI: Failed to get a request !\n");
  939. return;
  940. }
  941. /* We only support a limited number of descriptors, we know
  942. * the ibmvscsi driver uses up to 10 max, so it should fit
  943. * in our 256 bytes IUs. If not we'll have to increase the size
  944. * of the structure.
  945. */
  946. if (crq->s.IU_length > sizeof(union viosrp_iu)) {
  947. fprintf(stderr, "VSCSI: SRP IU too long (%d bytes) !\n",
  948. crq->s.IU_length);
  949. vscsi_put_req(req);
  950. return;
  951. }
  952. /* XXX Handle failure differently ? */
  953. if (spapr_vio_dma_read(&s->vdev, crq->s.IU_data_ptr, &req->iu,
  954. crq->s.IU_length)) {
  955. fprintf(stderr, "vscsi_got_payload: DMA read failure !\n");
  956. vscsi_put_req(req);
  957. return;
  958. }
  959. memcpy(&req->crq, crq, sizeof(vscsi_crq));
  960. if (crq->s.format == VIOSRP_MAD_FORMAT) {
  961. done = vscsi_handle_mad_req(s, req);
  962. } else {
  963. done = vscsi_handle_srp_req(s, req);
  964. }
  965. if (done) {
  966. vscsi_put_req(req);
  967. }
  968. }
  969. static int vscsi_do_crq(struct SpaprVioDevice *dev, uint8_t *crq_data)
  970. {
  971. VSCSIState *s = VIO_SPAPR_VSCSI_DEVICE(dev);
  972. vscsi_crq crq;
  973. memcpy(crq.raw, crq_data, 16);
  974. crq.s.timeout = be16_to_cpu(crq.s.timeout);
  975. crq.s.IU_length = be16_to_cpu(crq.s.IU_length);
  976. crq.s.IU_data_ptr = be64_to_cpu(crq.s.IU_data_ptr);
  977. trace_spapr_vscsi_do_crq(crq.raw[0], crq.raw[1]);
  978. switch (crq.s.valid) {
  979. case 0xc0: /* Init command/response */
  980. /* Respond to initialization request */
  981. if (crq.s.format == 0x01) {
  982. memset(crq.raw, 0, 16);
  983. crq.s.valid = 0xc0;
  984. crq.s.format = 0x02;
  985. spapr_vio_send_crq(dev, crq.raw);
  986. }
  987. /* Note that in hotplug cases, we might get a 0x02
  988. * as a result of us emitting the init request
  989. */
  990. break;
  991. case 0xff: /* Link event */
  992. /* Not handled for now */
  993. break;
  994. case 0x80: /* Payloads */
  995. switch (crq.s.format) {
  996. case VIOSRP_SRP_FORMAT: /* AKA VSCSI request */
  997. case VIOSRP_MAD_FORMAT: /* AKA VSCSI response */
  998. vscsi_got_payload(s, &crq);
  999. break;
  1000. case VIOSRP_OS400_FORMAT:
  1001. case VIOSRP_AIX_FORMAT:
  1002. case VIOSRP_LINUX_FORMAT:
  1003. case VIOSRP_INLINE_FORMAT:
  1004. fprintf(stderr, "vscsi_do_srq: Unsupported payload format %02x\n",
  1005. crq.s.format);
  1006. break;
  1007. default:
  1008. fprintf(stderr, "vscsi_do_srq: Unknown payload format %02x\n",
  1009. crq.s.format);
  1010. }
  1011. break;
  1012. default:
  1013. fprintf(stderr, "vscsi_do_crq: unknown CRQ %02x %02x ...\n",
  1014. crq.raw[0], crq.raw[1]);
  1015. };
  1016. return 0;
  1017. }
  1018. static const struct SCSIBusInfo vscsi_scsi_info = {
  1019. .tcq = true,
  1020. .max_channel = 7, /* logical unit addressing format */
  1021. .max_target = 63,
  1022. .max_lun = 31,
  1023. .transfer_data = vscsi_transfer_data,
  1024. .complete = vscsi_command_complete,
  1025. .cancel = vscsi_request_cancelled,
  1026. .save_request = vscsi_save_request,
  1027. .load_request = vscsi_load_request,
  1028. };
  1029. static void spapr_vscsi_reset(SpaprVioDevice *dev)
  1030. {
  1031. VSCSIState *s = VIO_SPAPR_VSCSI_DEVICE(dev);
  1032. int i;
  1033. memset(s->reqs, 0, sizeof(s->reqs));
  1034. for (i = 0; i < VSCSI_REQ_LIMIT; i++) {
  1035. s->reqs[i].qtag = i;
  1036. }
  1037. }
  1038. static void spapr_vscsi_realize(SpaprVioDevice *dev, Error **errp)
  1039. {
  1040. VSCSIState *s = VIO_SPAPR_VSCSI_DEVICE(dev);
  1041. dev->crq.SendFunc = vscsi_do_crq;
  1042. scsi_bus_new(&s->bus, sizeof(s->bus), DEVICE(dev),
  1043. &vscsi_scsi_info, NULL);
  1044. }
  1045. void spapr_vscsi_create(SpaprVioBus *bus)
  1046. {
  1047. DeviceState *dev;
  1048. dev = qdev_create(&bus->bus, "spapr-vscsi");
  1049. qdev_init_nofail(dev);
  1050. scsi_bus_legacy_handle_cmdline(&VIO_SPAPR_VSCSI_DEVICE(dev)->bus);
  1051. }
  1052. static int spapr_vscsi_devnode(SpaprVioDevice *dev, void *fdt, int node_off)
  1053. {
  1054. int ret;
  1055. ret = fdt_setprop_cell(fdt, node_off, "#address-cells", 2);
  1056. if (ret < 0) {
  1057. return ret;
  1058. }
  1059. ret = fdt_setprop_cell(fdt, node_off, "#size-cells", 0);
  1060. if (ret < 0) {
  1061. return ret;
  1062. }
  1063. return 0;
  1064. }
  1065. static Property spapr_vscsi_properties[] = {
  1066. DEFINE_SPAPR_PROPERTIES(VSCSIState, vdev),
  1067. DEFINE_PROP_END_OF_LIST(),
  1068. };
  1069. static const VMStateDescription vmstate_spapr_vscsi = {
  1070. .name = "spapr_vscsi",
  1071. .version_id = 1,
  1072. .minimum_version_id = 1,
  1073. .fields = (VMStateField[]) {
  1074. VMSTATE_SPAPR_VIO(vdev, VSCSIState),
  1075. /* VSCSI state */
  1076. /* ???? */
  1077. VMSTATE_END_OF_LIST()
  1078. },
  1079. };
  1080. static void spapr_vscsi_class_init(ObjectClass *klass, void *data)
  1081. {
  1082. DeviceClass *dc = DEVICE_CLASS(klass);
  1083. SpaprVioDeviceClass *k = VIO_SPAPR_DEVICE_CLASS(klass);
  1084. k->realize = spapr_vscsi_realize;
  1085. k->reset = spapr_vscsi_reset;
  1086. k->devnode = spapr_vscsi_devnode;
  1087. k->dt_name = "v-scsi";
  1088. k->dt_type = "vscsi";
  1089. k->dt_compatible = "IBM,v-scsi";
  1090. k->signal_mask = 0x00000001;
  1091. set_bit(DEVICE_CATEGORY_STORAGE, dc->categories);
  1092. dc->props = spapr_vscsi_properties;
  1093. k->rtce_window_size = 0x10000000;
  1094. dc->vmsd = &vmstate_spapr_vscsi;
  1095. }
  1096. static const TypeInfo spapr_vscsi_info = {
  1097. .name = TYPE_VIO_SPAPR_VSCSI_DEVICE,
  1098. .parent = TYPE_VIO_SPAPR_DEVICE,
  1099. .instance_size = sizeof(VSCSIState),
  1100. .class_init = spapr_vscsi_class_init,
  1101. };
  1102. static void spapr_vscsi_register_types(void)
  1103. {
  1104. type_register_static(&spapr_vscsi_info);
  1105. }
  1106. type_init(spapr_vscsi_register_types)