xen-scsiback.c 47 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890
  1. /*
  2. * Xen SCSI backend driver
  3. *
  4. * Copyright (c) 2008, FUJITSU Limited
  5. *
  6. * Based on the blkback driver code.
  7. * Adaption to kernel taget core infrastructure taken from vhost/scsi.c
  8. *
  9. * This program is free software; you can redistribute it and/or
  10. * modify it under the terms of the GNU General Public License version 2
  11. * as published by the Free Software Foundation; or, when distributed
  12. * separately from the Linux kernel or incorporated into other
  13. * software packages, subject to the following license:
  14. *
  15. * Permission is hereby granted, free of charge, to any person obtaining a copy
  16. * of this source file (the "Software"), to deal in the Software without
  17. * restriction, including without limitation the rights to use, copy, modify,
  18. * merge, publish, distribute, sublicense, and/or sell copies of the Software,
  19. * and to permit persons to whom the Software is furnished to do so, subject to
  20. * the following conditions:
  21. *
  22. * The above copyright notice and this permission notice shall be included in
  23. * all copies or substantial portions of the Software.
  24. *
  25. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  26. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  27. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  28. * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  29. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
  30. * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
  31. * IN THE SOFTWARE.
  32. */
  33. #define pr_fmt(fmt) "xen-pvscsi: " fmt
  34. #include <linux/module.h>
  35. #include <linux/utsname.h>
  36. #include <linux/interrupt.h>
  37. #include <linux/slab.h>
  38. #include <linux/wait.h>
  39. #include <linux/sched.h>
  40. #include <linux/list.h>
  41. #include <linux/gfp.h>
  42. #include <linux/delay.h>
  43. #include <linux/spinlock.h>
  44. #include <linux/configfs.h>
  45. #include <generated/utsrelease.h>
  46. #include <scsi/scsi_host.h> /* SG_ALL */
  47. #include <target/target_core_base.h>
  48. #include <target/target_core_fabric.h>
  49. #include <asm/hypervisor.h>
  50. #include <xen/xen.h>
  51. #include <xen/balloon.h>
  52. #include <xen/events.h>
  53. #include <xen/xenbus.h>
  54. #include <xen/grant_table.h>
  55. #include <xen/page.h>
  56. #include <xen/interface/grant_table.h>
  57. #include <xen/interface/io/vscsiif.h>
  58. #define VSCSI_VERSION "v0.1"
  59. #define VSCSI_NAMELEN 32
  60. struct ids_tuple {
  61. unsigned int hst; /* host */
  62. unsigned int chn; /* channel */
  63. unsigned int tgt; /* target */
  64. unsigned int lun; /* LUN */
  65. };
  66. struct v2p_entry {
  67. struct ids_tuple v; /* translate from */
  68. struct scsiback_tpg *tpg; /* translate to */
  69. unsigned int lun;
  70. struct kref kref;
  71. struct list_head l;
  72. };
  73. struct vscsibk_info {
  74. struct xenbus_device *dev;
  75. domid_t domid;
  76. unsigned int irq;
  77. struct vscsiif_back_ring ring;
  78. spinlock_t ring_lock;
  79. atomic_t nr_unreplied_reqs;
  80. spinlock_t v2p_lock;
  81. struct list_head v2p_entry_lists;
  82. wait_queue_head_t waiting_to_free;
  83. struct gnttab_page_cache free_pages;
  84. };
  85. /* theoretical maximum of grants for one request */
  86. #define VSCSI_MAX_GRANTS (SG_ALL + VSCSIIF_SG_TABLESIZE)
  87. /*
  88. * VSCSI_GRANT_BATCH is the maximum number of grants to be processed in one
  89. * call to map/unmap grants. Don't choose it too large, as there are arrays
  90. * with VSCSI_GRANT_BATCH elements allocated on the stack.
  91. */
  92. #define VSCSI_GRANT_BATCH 16
  93. struct vscsibk_pend {
  94. uint16_t rqid;
  95. uint8_t cmnd[VSCSIIF_MAX_COMMAND_SIZE];
  96. uint8_t cmd_len;
  97. uint8_t sc_data_direction;
  98. uint16_t n_sg; /* real length of SG list */
  99. uint16_t n_grants; /* SG pages and potentially SG list */
  100. uint32_t data_len;
  101. uint32_t result;
  102. struct vscsibk_info *info;
  103. struct v2p_entry *v2p;
  104. struct scatterlist *sgl;
  105. uint8_t sense_buffer[VSCSIIF_SENSE_BUFFERSIZE];
  106. grant_handle_t grant_handles[VSCSI_MAX_GRANTS];
  107. struct page *pages[VSCSI_MAX_GRANTS];
  108. struct se_cmd se_cmd;
  109. struct completion tmr_done;
  110. };
  111. #define VSCSI_DEFAULT_SESSION_TAGS 128
  112. struct scsiback_nexus {
  113. /* Pointer to TCM session for I_T Nexus */
  114. struct se_session *tvn_se_sess;
  115. };
  116. struct scsiback_tport {
  117. /* SCSI protocol the tport is providing */
  118. u8 tport_proto_id;
  119. /* Binary World Wide unique Port Name for pvscsi Target port */
  120. u64 tport_wwpn;
  121. /* ASCII formatted WWPN for pvscsi Target port */
  122. char tport_name[VSCSI_NAMELEN];
  123. /* Returned by scsiback_make_tport() */
  124. struct se_wwn tport_wwn;
  125. };
  126. struct scsiback_tpg {
  127. /* scsiback port target portal group tag for TCM */
  128. u16 tport_tpgt;
  129. /* track number of TPG Port/Lun Links wrt explicit I_T Nexus shutdown */
  130. int tv_tpg_port_count;
  131. /* xen-pvscsi references to tpg_nexus, protected by tv_tpg_mutex */
  132. int tv_tpg_fe_count;
  133. /* list for scsiback_list */
  134. struct list_head tv_tpg_list;
  135. /* Used to protect access for tpg_nexus */
  136. struct mutex tv_tpg_mutex;
  137. /* Pointer to the TCM pvscsi I_T Nexus for this TPG endpoint */
  138. struct scsiback_nexus *tpg_nexus;
  139. /* Pointer back to scsiback_tport */
  140. struct scsiback_tport *tport;
  141. /* Returned by scsiback_make_tpg() */
  142. struct se_portal_group se_tpg;
  143. /* alias used in xenstore */
  144. char param_alias[VSCSI_NAMELEN];
  145. /* list of info structures related to this target portal group */
  146. struct list_head info_list;
  147. };
  148. #define SCSIBACK_INVALID_HANDLE (~0)
  149. static bool log_print_stat;
  150. module_param(log_print_stat, bool, 0644);
  151. static int scsiback_max_buffer_pages = 1024;
  152. module_param_named(max_buffer_pages, scsiback_max_buffer_pages, int, 0644);
  153. MODULE_PARM_DESC(max_buffer_pages,
  154. "Maximum number of free pages to keep in backend buffer");
  155. /* Global spinlock to protect scsiback TPG list */
  156. static DEFINE_MUTEX(scsiback_mutex);
  157. static LIST_HEAD(scsiback_list);
  158. static void scsiback_get(struct vscsibk_info *info)
  159. {
  160. atomic_inc(&info->nr_unreplied_reqs);
  161. }
  162. static void scsiback_put(struct vscsibk_info *info)
  163. {
  164. if (atomic_dec_and_test(&info->nr_unreplied_reqs))
  165. wake_up(&info->waiting_to_free);
  166. }
  167. static unsigned long vaddr_page(struct page *page)
  168. {
  169. unsigned long pfn = page_to_pfn(page);
  170. return (unsigned long)pfn_to_kaddr(pfn);
  171. }
  172. static unsigned long vaddr(struct vscsibk_pend *req, int seg)
  173. {
  174. return vaddr_page(req->pages[seg]);
  175. }
  176. static void scsiback_print_status(char *sense_buffer, int errors,
  177. struct vscsibk_pend *pending_req)
  178. {
  179. struct scsiback_tpg *tpg = pending_req->v2p->tpg;
  180. pr_err("[%s:%d] cmnd[0]=%02x -> st=%02x msg=%02x host=%02x\n",
  181. tpg->tport->tport_name, pending_req->v2p->lun,
  182. pending_req->cmnd[0], errors & 0xff, COMMAND_COMPLETE,
  183. host_byte(errors));
  184. }
  185. static void scsiback_fast_flush_area(struct vscsibk_pend *req)
  186. {
  187. struct gnttab_unmap_grant_ref unmap[VSCSI_GRANT_BATCH];
  188. struct page *pages[VSCSI_GRANT_BATCH];
  189. unsigned int i, invcount = 0;
  190. grant_handle_t handle;
  191. int err;
  192. kfree(req->sgl);
  193. req->sgl = NULL;
  194. req->n_sg = 0;
  195. if (!req->n_grants)
  196. return;
  197. for (i = 0; i < req->n_grants; i++) {
  198. handle = req->grant_handles[i];
  199. if (handle == SCSIBACK_INVALID_HANDLE)
  200. continue;
  201. gnttab_set_unmap_op(&unmap[invcount], vaddr(req, i),
  202. GNTMAP_host_map, handle);
  203. req->grant_handles[i] = SCSIBACK_INVALID_HANDLE;
  204. pages[invcount] = req->pages[i];
  205. put_page(pages[invcount]);
  206. invcount++;
  207. if (invcount < VSCSI_GRANT_BATCH)
  208. continue;
  209. err = gnttab_unmap_refs(unmap, NULL, pages, invcount);
  210. BUG_ON(err);
  211. invcount = 0;
  212. }
  213. if (invcount) {
  214. err = gnttab_unmap_refs(unmap, NULL, pages, invcount);
  215. BUG_ON(err);
  216. }
  217. gnttab_page_cache_put(&req->info->free_pages, req->pages,
  218. req->n_grants);
  219. req->n_grants = 0;
  220. }
  221. static void scsiback_free_translation_entry(struct kref *kref)
  222. {
  223. struct v2p_entry *entry = container_of(kref, struct v2p_entry, kref);
  224. struct scsiback_tpg *tpg = entry->tpg;
  225. mutex_lock(&tpg->tv_tpg_mutex);
  226. tpg->tv_tpg_fe_count--;
  227. mutex_unlock(&tpg->tv_tpg_mutex);
  228. kfree(entry);
  229. }
  230. static int32_t scsiback_result(int32_t result)
  231. {
  232. int32_t host_status;
  233. switch (XEN_VSCSIIF_RSLT_HOST(result)) {
  234. case DID_OK:
  235. host_status = XEN_VSCSIIF_RSLT_HOST_OK;
  236. break;
  237. case DID_NO_CONNECT:
  238. host_status = XEN_VSCSIIF_RSLT_HOST_NO_CONNECT;
  239. break;
  240. case DID_BUS_BUSY:
  241. host_status = XEN_VSCSIIF_RSLT_HOST_BUS_BUSY;
  242. break;
  243. case DID_TIME_OUT:
  244. host_status = XEN_VSCSIIF_RSLT_HOST_TIME_OUT;
  245. break;
  246. case DID_BAD_TARGET:
  247. host_status = XEN_VSCSIIF_RSLT_HOST_BAD_TARGET;
  248. break;
  249. case DID_ABORT:
  250. host_status = XEN_VSCSIIF_RSLT_HOST_ABORT;
  251. break;
  252. case DID_PARITY:
  253. host_status = XEN_VSCSIIF_RSLT_HOST_PARITY;
  254. break;
  255. case DID_ERROR:
  256. host_status = XEN_VSCSIIF_RSLT_HOST_ERROR;
  257. break;
  258. case DID_RESET:
  259. host_status = XEN_VSCSIIF_RSLT_HOST_RESET;
  260. break;
  261. case DID_BAD_INTR:
  262. host_status = XEN_VSCSIIF_RSLT_HOST_BAD_INTR;
  263. break;
  264. case DID_PASSTHROUGH:
  265. host_status = XEN_VSCSIIF_RSLT_HOST_PASSTHROUGH;
  266. break;
  267. case DID_SOFT_ERROR:
  268. host_status = XEN_VSCSIIF_RSLT_HOST_SOFT_ERROR;
  269. break;
  270. case DID_IMM_RETRY:
  271. host_status = XEN_VSCSIIF_RSLT_HOST_IMM_RETRY;
  272. break;
  273. case DID_REQUEUE:
  274. host_status = XEN_VSCSIIF_RSLT_HOST_REQUEUE;
  275. break;
  276. case DID_TRANSPORT_DISRUPTED:
  277. host_status = XEN_VSCSIIF_RSLT_HOST_TRANSPORT_DISRUPTED;
  278. break;
  279. case DID_TRANSPORT_FAILFAST:
  280. host_status = XEN_VSCSIIF_RSLT_HOST_TRANSPORT_FAILFAST;
  281. break;
  282. case DID_TRANSPORT_MARGINAL:
  283. host_status = XEN_VSCSIIF_RSLT_HOST_TRANSPORT_MARGINAL;
  284. break;
  285. default:
  286. host_status = XEN_VSCSIIF_RSLT_HOST_ERROR;
  287. break;
  288. }
  289. return (host_status << 16) | (result & 0x00ffff);
  290. }
  291. static void scsiback_send_response(struct vscsibk_info *info,
  292. char *sense_buffer, int32_t result, uint32_t resid,
  293. uint16_t rqid)
  294. {
  295. struct vscsiif_response *ring_res;
  296. int notify;
  297. struct scsi_sense_hdr sshdr;
  298. unsigned long flags;
  299. unsigned len;
  300. spin_lock_irqsave(&info->ring_lock, flags);
  301. ring_res = RING_GET_RESPONSE(&info->ring, info->ring.rsp_prod_pvt);
  302. info->ring.rsp_prod_pvt++;
  303. ring_res->rslt = scsiback_result(result);
  304. ring_res->rqid = rqid;
  305. if (sense_buffer != NULL &&
  306. scsi_normalize_sense(sense_buffer, VSCSIIF_SENSE_BUFFERSIZE,
  307. &sshdr)) {
  308. len = min_t(unsigned, 8 + sense_buffer[7],
  309. VSCSIIF_SENSE_BUFFERSIZE);
  310. memcpy(ring_res->sense_buffer, sense_buffer, len);
  311. ring_res->sense_len = len;
  312. } else {
  313. ring_res->sense_len = 0;
  314. }
  315. ring_res->residual_len = resid;
  316. RING_PUSH_RESPONSES_AND_CHECK_NOTIFY(&info->ring, notify);
  317. spin_unlock_irqrestore(&info->ring_lock, flags);
  318. if (notify)
  319. notify_remote_via_irq(info->irq);
  320. }
  321. static void scsiback_do_resp_with_sense(char *sense_buffer, int32_t result,
  322. uint32_t resid, struct vscsibk_pend *pending_req)
  323. {
  324. scsiback_send_response(pending_req->info, sense_buffer, result,
  325. resid, pending_req->rqid);
  326. if (pending_req->v2p)
  327. kref_put(&pending_req->v2p->kref,
  328. scsiback_free_translation_entry);
  329. }
  330. static void scsiback_cmd_done(struct vscsibk_pend *pending_req)
  331. {
  332. struct vscsibk_info *info = pending_req->info;
  333. unsigned char *sense_buffer;
  334. unsigned int resid;
  335. int errors;
  336. sense_buffer = pending_req->sense_buffer;
  337. resid = pending_req->se_cmd.residual_count;
  338. errors = pending_req->result;
  339. if (errors && log_print_stat)
  340. scsiback_print_status(sense_buffer, errors, pending_req);
  341. scsiback_fast_flush_area(pending_req);
  342. scsiback_do_resp_with_sense(sense_buffer, errors, resid, pending_req);
  343. scsiback_put(info);
  344. /*
  345. * Drop the extra KREF_ACK reference taken by target_submit_cmd_map_sgls()
  346. * ahead of scsiback_check_stop_free() -> transport_generic_free_cmd()
  347. * final se_cmd->cmd_kref put.
  348. */
  349. target_put_sess_cmd(&pending_req->se_cmd);
  350. }
  351. static void scsiback_cmd_exec(struct vscsibk_pend *pending_req)
  352. {
  353. struct se_cmd *se_cmd = &pending_req->se_cmd;
  354. struct se_session *sess = pending_req->v2p->tpg->tpg_nexus->tvn_se_sess;
  355. scsiback_get(pending_req->info);
  356. se_cmd->tag = pending_req->rqid;
  357. target_init_cmd(se_cmd, sess, pending_req->sense_buffer,
  358. pending_req->v2p->lun, pending_req->data_len, 0,
  359. pending_req->sc_data_direction, TARGET_SCF_ACK_KREF);
  360. if (target_submit_prep(se_cmd, pending_req->cmnd, pending_req->sgl,
  361. pending_req->n_sg, NULL, 0, NULL, 0, GFP_KERNEL))
  362. return;
  363. target_submit(se_cmd);
  364. }
  365. static int scsiback_gnttab_data_map_batch(struct gnttab_map_grant_ref *map,
  366. struct page **pg, grant_handle_t *grant, int cnt)
  367. {
  368. int err, i;
  369. if (!cnt)
  370. return 0;
  371. err = gnttab_map_refs(map, NULL, pg, cnt);
  372. for (i = 0; i < cnt; i++) {
  373. if (unlikely(map[i].status != GNTST_okay)) {
  374. pr_err("invalid buffer -- could not remap it\n");
  375. map[i].handle = SCSIBACK_INVALID_HANDLE;
  376. if (!err)
  377. err = -ENOMEM;
  378. } else {
  379. get_page(pg[i]);
  380. }
  381. grant[i] = map[i].handle;
  382. }
  383. return err;
  384. }
  385. static int scsiback_gnttab_data_map_list(struct vscsibk_pend *pending_req,
  386. struct scsiif_request_segment *seg, struct page **pg,
  387. grant_handle_t *grant, int cnt, u32 flags)
  388. {
  389. int mapcount = 0, i, err = 0;
  390. struct gnttab_map_grant_ref map[VSCSI_GRANT_BATCH];
  391. struct vscsibk_info *info = pending_req->info;
  392. for (i = 0; i < cnt; i++) {
  393. if (gnttab_page_cache_get(&info->free_pages, pg + mapcount)) {
  394. gnttab_page_cache_put(&info->free_pages, pg, mapcount);
  395. pr_err("no grant page\n");
  396. return -ENOMEM;
  397. }
  398. gnttab_set_map_op(&map[mapcount], vaddr_page(pg[mapcount]),
  399. flags, seg[i].gref, info->domid);
  400. mapcount++;
  401. if (mapcount < VSCSI_GRANT_BATCH)
  402. continue;
  403. err = scsiback_gnttab_data_map_batch(map, pg, grant, mapcount);
  404. pg += mapcount;
  405. grant += mapcount;
  406. pending_req->n_grants += mapcount;
  407. if (err)
  408. return err;
  409. mapcount = 0;
  410. }
  411. err = scsiback_gnttab_data_map_batch(map, pg, grant, mapcount);
  412. pending_req->n_grants += mapcount;
  413. return err;
  414. }
  415. static int scsiback_gnttab_data_map(struct vscsiif_request *ring_req,
  416. struct vscsibk_pend *pending_req)
  417. {
  418. u32 flags;
  419. int i, err, n_segs, i_seg = 0;
  420. struct page **pg;
  421. struct scsiif_request_segment *seg;
  422. unsigned long end_seg = 0;
  423. unsigned int nr_segments = (unsigned int)ring_req->nr_segments;
  424. unsigned int nr_sgl = 0;
  425. struct scatterlist *sg;
  426. grant_handle_t *grant;
  427. pending_req->n_sg = 0;
  428. pending_req->n_grants = 0;
  429. pending_req->data_len = 0;
  430. nr_segments &= ~VSCSIIF_SG_GRANT;
  431. if (!nr_segments)
  432. return 0;
  433. if (nr_segments > VSCSIIF_SG_TABLESIZE) {
  434. pr_debug("invalid parameter nr_seg = %d\n",
  435. ring_req->nr_segments);
  436. return -EINVAL;
  437. }
  438. if (ring_req->nr_segments & VSCSIIF_SG_GRANT) {
  439. err = scsiback_gnttab_data_map_list(pending_req, ring_req->seg,
  440. pending_req->pages, pending_req->grant_handles,
  441. nr_segments, GNTMAP_host_map | GNTMAP_readonly);
  442. if (err)
  443. return err;
  444. nr_sgl = nr_segments;
  445. nr_segments = 0;
  446. for (i = 0; i < nr_sgl; i++) {
  447. n_segs = ring_req->seg[i].length /
  448. sizeof(struct scsiif_request_segment);
  449. if ((unsigned)ring_req->seg[i].offset +
  450. (unsigned)ring_req->seg[i].length > PAGE_SIZE ||
  451. n_segs * sizeof(struct scsiif_request_segment) !=
  452. ring_req->seg[i].length)
  453. return -EINVAL;
  454. nr_segments += n_segs;
  455. }
  456. if (nr_segments > SG_ALL) {
  457. pr_debug("invalid nr_seg = %d\n", nr_segments);
  458. return -EINVAL;
  459. }
  460. }
  461. /* free of (sgl) in fast_flush_area() */
  462. pending_req->sgl = kmalloc_objs(struct scatterlist, nr_segments);
  463. if (!pending_req->sgl)
  464. return -ENOMEM;
  465. sg_init_table(pending_req->sgl, nr_segments);
  466. pending_req->n_sg = nr_segments;
  467. flags = GNTMAP_host_map;
  468. if (pending_req->sc_data_direction == DMA_TO_DEVICE)
  469. flags |= GNTMAP_readonly;
  470. pg = pending_req->pages + nr_sgl;
  471. grant = pending_req->grant_handles + nr_sgl;
  472. if (!nr_sgl) {
  473. seg = ring_req->seg;
  474. err = scsiback_gnttab_data_map_list(pending_req, seg,
  475. pg, grant, nr_segments, flags);
  476. if (err)
  477. return err;
  478. } else {
  479. for (i = 0; i < nr_sgl; i++) {
  480. seg = (struct scsiif_request_segment *)(
  481. vaddr(pending_req, i) + ring_req->seg[i].offset);
  482. n_segs = ring_req->seg[i].length /
  483. sizeof(struct scsiif_request_segment);
  484. err = scsiback_gnttab_data_map_list(pending_req, seg,
  485. pg, grant, n_segs, flags);
  486. if (err)
  487. return err;
  488. pg += n_segs;
  489. grant += n_segs;
  490. }
  491. end_seg = vaddr(pending_req, 0) + ring_req->seg[0].offset;
  492. seg = (struct scsiif_request_segment *)end_seg;
  493. end_seg += ring_req->seg[0].length;
  494. pg = pending_req->pages + nr_sgl;
  495. }
  496. for_each_sg(pending_req->sgl, sg, nr_segments, i) {
  497. sg_set_page(sg, pg[i], seg->length, seg->offset);
  498. pending_req->data_len += seg->length;
  499. seg++;
  500. if (nr_sgl && (unsigned long)seg >= end_seg) {
  501. i_seg++;
  502. end_seg = vaddr(pending_req, i_seg) +
  503. ring_req->seg[i_seg].offset;
  504. seg = (struct scsiif_request_segment *)end_seg;
  505. end_seg += ring_req->seg[i_seg].length;
  506. }
  507. if (sg->offset >= PAGE_SIZE ||
  508. sg->length > PAGE_SIZE ||
  509. sg->offset + sg->length > PAGE_SIZE)
  510. return -EINVAL;
  511. }
  512. return 0;
  513. }
  514. static void scsiback_disconnect(struct vscsibk_info *info)
  515. {
  516. wait_event(info->waiting_to_free,
  517. atomic_read(&info->nr_unreplied_reqs) == 0);
  518. unbind_from_irqhandler(info->irq, info);
  519. info->irq = 0;
  520. xenbus_unmap_ring_vfree(info->dev, info->ring.sring);
  521. }
  522. static void scsiback_device_action(struct vscsibk_pend *pending_req,
  523. enum tcm_tmreq_table act, int tag)
  524. {
  525. struct scsiback_tpg *tpg = pending_req->v2p->tpg;
  526. struct scsiback_nexus *nexus = tpg->tpg_nexus;
  527. struct se_cmd *se_cmd = &pending_req->se_cmd;
  528. u64 unpacked_lun = pending_req->v2p->lun;
  529. int rc, err = XEN_VSCSIIF_RSLT_RESET_FAILED;
  530. init_completion(&pending_req->tmr_done);
  531. rc = target_submit_tmr(&pending_req->se_cmd, nexus->tvn_se_sess,
  532. &pending_req->sense_buffer[0],
  533. unpacked_lun, NULL, act, GFP_KERNEL,
  534. tag, TARGET_SCF_ACK_KREF);
  535. if (rc)
  536. goto err;
  537. wait_for_completion(&pending_req->tmr_done);
  538. err = (se_cmd->se_tmr_req->response == TMR_FUNCTION_COMPLETE) ?
  539. XEN_VSCSIIF_RSLT_RESET_SUCCESS : XEN_VSCSIIF_RSLT_RESET_FAILED;
  540. scsiback_do_resp_with_sense(NULL, err, 0, pending_req);
  541. transport_generic_free_cmd(&pending_req->se_cmd, 0);
  542. return;
  543. err:
  544. scsiback_do_resp_with_sense(NULL, err, 0, pending_req);
  545. }
  546. /*
  547. Perform virtual to physical translation
  548. */
  549. static struct v2p_entry *scsiback_do_translation(struct vscsibk_info *info,
  550. struct ids_tuple *v)
  551. {
  552. struct v2p_entry *entry;
  553. struct list_head *head = &(info->v2p_entry_lists);
  554. unsigned long flags;
  555. spin_lock_irqsave(&info->v2p_lock, flags);
  556. list_for_each_entry(entry, head, l) {
  557. if ((entry->v.chn == v->chn) &&
  558. (entry->v.tgt == v->tgt) &&
  559. (entry->v.lun == v->lun)) {
  560. kref_get(&entry->kref);
  561. goto out;
  562. }
  563. }
  564. entry = NULL;
  565. out:
  566. spin_unlock_irqrestore(&info->v2p_lock, flags);
  567. return entry;
  568. }
  569. static struct vscsibk_pend *scsiback_get_pend_req(struct vscsiif_back_ring *ring,
  570. struct v2p_entry *v2p)
  571. {
  572. struct scsiback_tpg *tpg = v2p->tpg;
  573. struct scsiback_nexus *nexus = tpg->tpg_nexus;
  574. struct se_session *se_sess = nexus->tvn_se_sess;
  575. struct vscsibk_pend *req;
  576. int tag, cpu, i;
  577. tag = sbitmap_queue_get(&se_sess->sess_tag_pool, &cpu);
  578. if (tag < 0) {
  579. pr_err("Unable to obtain tag for vscsiif_request\n");
  580. return ERR_PTR(-ENOMEM);
  581. }
  582. req = &((struct vscsibk_pend *)se_sess->sess_cmd_map)[tag];
  583. memset(req, 0, sizeof(*req));
  584. req->se_cmd.map_tag = tag;
  585. req->se_cmd.map_cpu = cpu;
  586. for (i = 0; i < VSCSI_MAX_GRANTS; i++)
  587. req->grant_handles[i] = SCSIBACK_INVALID_HANDLE;
  588. return req;
  589. }
  590. static struct vscsibk_pend *prepare_pending_reqs(struct vscsibk_info *info,
  591. struct vscsiif_back_ring *ring,
  592. struct vscsiif_request *ring_req)
  593. {
  594. struct vscsibk_pend *pending_req;
  595. struct v2p_entry *v2p;
  596. struct ids_tuple vir;
  597. /* request range check from frontend */
  598. if ((ring_req->sc_data_direction != DMA_BIDIRECTIONAL) &&
  599. (ring_req->sc_data_direction != DMA_TO_DEVICE) &&
  600. (ring_req->sc_data_direction != DMA_FROM_DEVICE) &&
  601. (ring_req->sc_data_direction != DMA_NONE)) {
  602. pr_debug("invalid parameter data_dir = %d\n",
  603. ring_req->sc_data_direction);
  604. return ERR_PTR(-EINVAL);
  605. }
  606. if (ring_req->cmd_len > VSCSIIF_MAX_COMMAND_SIZE) {
  607. pr_debug("invalid parameter cmd_len = %d\n",
  608. ring_req->cmd_len);
  609. return ERR_PTR(-EINVAL);
  610. }
  611. vir.chn = ring_req->channel;
  612. vir.tgt = ring_req->id;
  613. vir.lun = ring_req->lun;
  614. v2p = scsiback_do_translation(info, &vir);
  615. if (!v2p) {
  616. pr_debug("the v2p of (chn:%d, tgt:%d, lun:%d) doesn't exist.\n",
  617. vir.chn, vir.tgt, vir.lun);
  618. return ERR_PTR(-ENODEV);
  619. }
  620. pending_req = scsiback_get_pend_req(ring, v2p);
  621. if (IS_ERR(pending_req)) {
  622. kref_put(&v2p->kref, scsiback_free_translation_entry);
  623. return ERR_PTR(-ENOMEM);
  624. }
  625. pending_req->rqid = ring_req->rqid;
  626. pending_req->info = info;
  627. pending_req->v2p = v2p;
  628. pending_req->sc_data_direction = ring_req->sc_data_direction;
  629. pending_req->cmd_len = ring_req->cmd_len;
  630. memcpy(pending_req->cmnd, ring_req->cmnd, pending_req->cmd_len);
  631. return pending_req;
  632. }
  633. static int scsiback_do_cmd_fn(struct vscsibk_info *info,
  634. unsigned int *eoi_flags)
  635. {
  636. struct vscsiif_back_ring *ring = &info->ring;
  637. struct vscsiif_request ring_req;
  638. struct vscsibk_pend *pending_req;
  639. RING_IDX rc, rp;
  640. int more_to_do;
  641. uint32_t result;
  642. rc = ring->req_cons;
  643. rp = ring->sring->req_prod;
  644. rmb(); /* guest system is accessing ring, too */
  645. if (RING_REQUEST_PROD_OVERFLOW(ring, rp)) {
  646. rc = ring->rsp_prod_pvt;
  647. pr_warn("Dom%d provided bogus ring requests (%#x - %#x = %u). Halting ring processing\n",
  648. info->domid, rp, rc, rp - rc);
  649. return -EINVAL;
  650. }
  651. while ((rc != rp)) {
  652. *eoi_flags &= ~XEN_EOI_FLAG_SPURIOUS;
  653. if (RING_REQUEST_CONS_OVERFLOW(ring, rc))
  654. break;
  655. RING_COPY_REQUEST(ring, rc, &ring_req);
  656. ring->req_cons = ++rc;
  657. pending_req = prepare_pending_reqs(info, ring, &ring_req);
  658. if (IS_ERR(pending_req)) {
  659. switch (PTR_ERR(pending_req)) {
  660. case -ENODEV:
  661. result = DID_NO_CONNECT;
  662. break;
  663. default:
  664. result = DID_ERROR;
  665. break;
  666. }
  667. scsiback_send_response(info, NULL, result << 16, 0,
  668. ring_req.rqid);
  669. return 1;
  670. }
  671. switch (ring_req.act) {
  672. case VSCSIIF_ACT_SCSI_CDB:
  673. if (scsiback_gnttab_data_map(&ring_req, pending_req)) {
  674. scsiback_fast_flush_area(pending_req);
  675. scsiback_do_resp_with_sense(NULL,
  676. DID_ERROR << 16, 0, pending_req);
  677. transport_generic_free_cmd(&pending_req->se_cmd, 0);
  678. } else {
  679. scsiback_cmd_exec(pending_req);
  680. }
  681. break;
  682. case VSCSIIF_ACT_SCSI_ABORT:
  683. scsiback_device_action(pending_req, TMR_ABORT_TASK,
  684. ring_req.ref_rqid);
  685. break;
  686. case VSCSIIF_ACT_SCSI_RESET:
  687. scsiback_device_action(pending_req, TMR_LUN_RESET, 0);
  688. break;
  689. default:
  690. pr_err_ratelimited("invalid request\n");
  691. scsiback_do_resp_with_sense(NULL, DID_ERROR << 16, 0,
  692. pending_req);
  693. transport_generic_free_cmd(&pending_req->se_cmd, 0);
  694. break;
  695. }
  696. /* Yield point for this unbounded loop. */
  697. cond_resched();
  698. }
  699. gnttab_page_cache_shrink(&info->free_pages, scsiback_max_buffer_pages);
  700. RING_FINAL_CHECK_FOR_REQUESTS(&info->ring, more_to_do);
  701. return more_to_do;
  702. }
  703. static irqreturn_t scsiback_irq_fn(int irq, void *dev_id)
  704. {
  705. struct vscsibk_info *info = dev_id;
  706. int rc;
  707. unsigned int eoi_flags = XEN_EOI_FLAG_SPURIOUS;
  708. while ((rc = scsiback_do_cmd_fn(info, &eoi_flags)) > 0)
  709. cond_resched();
  710. /* In case of a ring error we keep the event channel masked. */
  711. if (!rc)
  712. xen_irq_lateeoi(irq, eoi_flags);
  713. return IRQ_HANDLED;
  714. }
  715. static int scsiback_init_sring(struct vscsibk_info *info, grant_ref_t ring_ref,
  716. evtchn_port_t evtchn)
  717. {
  718. void *area;
  719. struct vscsiif_sring *sring;
  720. int err;
  721. if (info->irq)
  722. return -1;
  723. err = xenbus_map_ring_valloc(info->dev, &ring_ref, 1, &area);
  724. if (err)
  725. return err;
  726. sring = (struct vscsiif_sring *)area;
  727. BACK_RING_INIT(&info->ring, sring, PAGE_SIZE);
  728. err = bind_interdomain_evtchn_to_irq_lateeoi(info->dev, evtchn);
  729. if (err < 0)
  730. goto unmap_page;
  731. info->irq = err;
  732. err = request_threaded_irq(info->irq, NULL, scsiback_irq_fn,
  733. IRQF_ONESHOT, "vscsiif-backend", info);
  734. if (err)
  735. goto free_irq;
  736. return 0;
  737. free_irq:
  738. unbind_from_irqhandler(info->irq, info);
  739. info->irq = 0;
  740. unmap_page:
  741. xenbus_unmap_ring_vfree(info->dev, area);
  742. return err;
  743. }
  744. static int scsiback_map(struct vscsibk_info *info)
  745. {
  746. struct xenbus_device *dev = info->dev;
  747. unsigned int ring_ref;
  748. evtchn_port_t evtchn;
  749. int err;
  750. err = xenbus_gather(XBT_NIL, dev->otherend,
  751. "ring-ref", "%u", &ring_ref,
  752. "event-channel", "%u", &evtchn, NULL);
  753. if (err) {
  754. xenbus_dev_fatal(dev, err, "reading %s ring", dev->otherend);
  755. return err;
  756. }
  757. return scsiback_init_sring(info, ring_ref, evtchn);
  758. }
  759. /*
  760. Check for a translation entry being present
  761. */
  762. static struct v2p_entry *scsiback_chk_translation_entry(
  763. struct vscsibk_info *info, struct ids_tuple *v)
  764. {
  765. struct list_head *head = &(info->v2p_entry_lists);
  766. struct v2p_entry *entry;
  767. list_for_each_entry(entry, head, l)
  768. if ((entry->v.chn == v->chn) &&
  769. (entry->v.tgt == v->tgt) &&
  770. (entry->v.lun == v->lun))
  771. return entry;
  772. return NULL;
  773. }
  774. /*
  775. Add a new translation entry
  776. */
  777. static int scsiback_add_translation_entry(struct vscsibk_info *info,
  778. char *phy, struct ids_tuple *v)
  779. {
  780. int err = 0;
  781. struct v2p_entry *new;
  782. unsigned long flags;
  783. char *lunp;
  784. unsigned long long unpacked_lun;
  785. struct se_lun *se_lun;
  786. struct scsiback_tpg *tpg_entry, *tpg = NULL;
  787. char *error = "doesn't exist";
  788. lunp = strrchr(phy, ':');
  789. if (!lunp) {
  790. pr_err("illegal format of physical device %s\n", phy);
  791. return -EINVAL;
  792. }
  793. *lunp = 0;
  794. lunp++;
  795. err = kstrtoull(lunp, 10, &unpacked_lun);
  796. if (err < 0) {
  797. pr_err("lun number not valid: %s\n", lunp);
  798. return err;
  799. }
  800. mutex_lock(&scsiback_mutex);
  801. list_for_each_entry(tpg_entry, &scsiback_list, tv_tpg_list) {
  802. if (!strcmp(phy, tpg_entry->tport->tport_name) ||
  803. !strcmp(phy, tpg_entry->param_alias)) {
  804. mutex_lock(&tpg_entry->se_tpg.tpg_lun_mutex);
  805. hlist_for_each_entry(se_lun, &tpg_entry->se_tpg.tpg_lun_hlist, link) {
  806. if (se_lun->unpacked_lun == unpacked_lun) {
  807. if (!tpg_entry->tpg_nexus)
  808. error = "nexus undefined";
  809. else
  810. tpg = tpg_entry;
  811. break;
  812. }
  813. }
  814. mutex_unlock(&tpg_entry->se_tpg.tpg_lun_mutex);
  815. break;
  816. }
  817. }
  818. if (tpg) {
  819. mutex_lock(&tpg->tv_tpg_mutex);
  820. tpg->tv_tpg_fe_count++;
  821. mutex_unlock(&tpg->tv_tpg_mutex);
  822. }
  823. mutex_unlock(&scsiback_mutex);
  824. if (!tpg) {
  825. pr_err("%s:%llu %s\n", phy, unpacked_lun, error);
  826. return -ENODEV;
  827. }
  828. new = kmalloc_obj(struct v2p_entry);
  829. if (new == NULL) {
  830. err = -ENOMEM;
  831. goto out_free;
  832. }
  833. spin_lock_irqsave(&info->v2p_lock, flags);
  834. /* Check double assignment to identical virtual ID */
  835. if (scsiback_chk_translation_entry(info, v)) {
  836. pr_warn("Virtual ID is already used. Assignment was not performed.\n");
  837. err = -EEXIST;
  838. goto out;
  839. }
  840. /* Create a new translation entry and add to the list */
  841. kref_init(&new->kref);
  842. new->v = *v;
  843. new->tpg = tpg;
  844. new->lun = unpacked_lun;
  845. list_add_tail(&new->l, &info->v2p_entry_lists);
  846. out:
  847. spin_unlock_irqrestore(&info->v2p_lock, flags);
  848. out_free:
  849. if (err) {
  850. mutex_lock(&tpg->tv_tpg_mutex);
  851. tpg->tv_tpg_fe_count--;
  852. mutex_unlock(&tpg->tv_tpg_mutex);
  853. kfree(new);
  854. }
  855. return err;
  856. }
  857. /*
  858. Delete the translation entry specified
  859. */
  860. static int scsiback_del_translation_entry(struct vscsibk_info *info,
  861. struct ids_tuple *v)
  862. {
  863. struct v2p_entry *entry;
  864. unsigned long flags;
  865. spin_lock_irqsave(&info->v2p_lock, flags);
  866. /* Find out the translation entry specified */
  867. entry = scsiback_chk_translation_entry(info, v);
  868. if (entry)
  869. list_del(&entry->l);
  870. spin_unlock_irqrestore(&info->v2p_lock, flags);
  871. if (!entry)
  872. return -ENOENT;
  873. kref_put(&entry->kref, scsiback_free_translation_entry);
  874. return 0;
  875. }
  876. static void scsiback_do_add_lun(struct vscsibk_info *info, const char *state,
  877. char *phy, struct ids_tuple *vir, int try)
  878. {
  879. struct v2p_entry *entry;
  880. unsigned long flags;
  881. int err;
  882. if (try) {
  883. spin_lock_irqsave(&info->v2p_lock, flags);
  884. entry = scsiback_chk_translation_entry(info, vir);
  885. spin_unlock_irqrestore(&info->v2p_lock, flags);
  886. if (entry)
  887. return;
  888. }
  889. if (!scsiback_add_translation_entry(info, phy, vir)) {
  890. if (xenbus_printf(XBT_NIL, info->dev->nodename, state,
  891. "%d", XenbusStateInitialised)) {
  892. pr_err("xenbus_printf error %s\n", state);
  893. scsiback_del_translation_entry(info, vir);
  894. }
  895. } else if (!try) {
  896. err = xenbus_printf(XBT_NIL, info->dev->nodename, state,
  897. "%d", XenbusStateClosed);
  898. if (err)
  899. xenbus_dev_error(info->dev, err,
  900. "%s: writing %s", __func__, state);
  901. }
  902. }
  903. static void scsiback_do_del_lun(struct vscsibk_info *info, const char *state,
  904. struct ids_tuple *vir)
  905. {
  906. if (!scsiback_del_translation_entry(info, vir)) {
  907. if (xenbus_printf(XBT_NIL, info->dev->nodename, state,
  908. "%d", XenbusStateClosed))
  909. pr_err("xenbus_printf error %s\n", state);
  910. }
  911. }
  912. #define VSCSIBACK_OP_ADD_OR_DEL_LUN 1
  913. #define VSCSIBACK_OP_UPDATEDEV_STATE 2
  914. static void scsiback_do_1lun_hotplug(struct vscsibk_info *info, int op,
  915. char *ent)
  916. {
  917. int err;
  918. struct ids_tuple vir;
  919. char *val;
  920. int device_state;
  921. char phy[VSCSI_NAMELEN];
  922. char str[64];
  923. char state[64];
  924. struct xenbus_device *dev = info->dev;
  925. /* read status */
  926. snprintf(state, sizeof(state), "vscsi-devs/%s/state", ent);
  927. err = xenbus_scanf(XBT_NIL, dev->nodename, state, "%u", &device_state);
  928. if (XENBUS_EXIST_ERR(err))
  929. return;
  930. /* physical SCSI device */
  931. snprintf(str, sizeof(str), "vscsi-devs/%s/p-dev", ent);
  932. val = xenbus_read(XBT_NIL, dev->nodename, str, NULL);
  933. if (IS_ERR(val)) {
  934. err = xenbus_printf(XBT_NIL, dev->nodename, state,
  935. "%d", XenbusStateClosed);
  936. if (err)
  937. xenbus_dev_error(info->dev, err,
  938. "%s: writing %s", __func__, state);
  939. return;
  940. }
  941. strscpy(phy, val, VSCSI_NAMELEN);
  942. kfree(val);
  943. /* virtual SCSI device */
  944. snprintf(str, sizeof(str), "vscsi-devs/%s/v-dev", ent);
  945. err = xenbus_scanf(XBT_NIL, dev->nodename, str, "%u:%u:%u:%u",
  946. &vir.hst, &vir.chn, &vir.tgt, &vir.lun);
  947. if (XENBUS_EXIST_ERR(err)) {
  948. err = xenbus_printf(XBT_NIL, dev->nodename, state,
  949. "%d", XenbusStateClosed);
  950. if (err)
  951. xenbus_dev_error(info->dev, err,
  952. "%s: writing %s", __func__, state);
  953. return;
  954. }
  955. switch (op) {
  956. case VSCSIBACK_OP_ADD_OR_DEL_LUN:
  957. switch (device_state) {
  958. case XenbusStateInitialising:
  959. scsiback_do_add_lun(info, state, phy, &vir, 0);
  960. break;
  961. case XenbusStateConnected:
  962. scsiback_do_add_lun(info, state, phy, &vir, 1);
  963. break;
  964. case XenbusStateClosing:
  965. scsiback_do_del_lun(info, state, &vir);
  966. break;
  967. default:
  968. break;
  969. }
  970. break;
  971. case VSCSIBACK_OP_UPDATEDEV_STATE:
  972. if (device_state == XenbusStateInitialised) {
  973. /* modify vscsi-devs/dev-x/state */
  974. if (xenbus_printf(XBT_NIL, dev->nodename, state,
  975. "%d", XenbusStateConnected)) {
  976. pr_err("xenbus_printf error %s\n", str);
  977. scsiback_del_translation_entry(info, &vir);
  978. xenbus_printf(XBT_NIL, dev->nodename, state,
  979. "%d", XenbusStateClosed);
  980. }
  981. }
  982. break;
  983. /* When it is necessary, processing is added here. */
  984. default:
  985. break;
  986. }
  987. }
  988. static void scsiback_do_lun_hotplug(struct vscsibk_info *info, int op)
  989. {
  990. int i;
  991. char **dir;
  992. unsigned int ndir = 0;
  993. dir = xenbus_directory(XBT_NIL, info->dev->nodename, "vscsi-devs",
  994. &ndir);
  995. if (IS_ERR(dir))
  996. return;
  997. for (i = 0; i < ndir; i++)
  998. scsiback_do_1lun_hotplug(info, op, dir[i]);
  999. kfree(dir);
  1000. }
  1001. static void scsiback_frontend_changed(struct xenbus_device *dev,
  1002. enum xenbus_state frontend_state)
  1003. {
  1004. struct vscsibk_info *info = dev_get_drvdata(&dev->dev);
  1005. switch (frontend_state) {
  1006. case XenbusStateInitialising:
  1007. break;
  1008. case XenbusStateInitialised:
  1009. if (scsiback_map(info))
  1010. break;
  1011. scsiback_do_lun_hotplug(info, VSCSIBACK_OP_ADD_OR_DEL_LUN);
  1012. xenbus_switch_state(dev, XenbusStateConnected);
  1013. break;
  1014. case XenbusStateConnected:
  1015. scsiback_do_lun_hotplug(info, VSCSIBACK_OP_UPDATEDEV_STATE);
  1016. if (dev->state == XenbusStateConnected)
  1017. break;
  1018. xenbus_switch_state(dev, XenbusStateConnected);
  1019. break;
  1020. case XenbusStateClosing:
  1021. if (info->irq)
  1022. scsiback_disconnect(info);
  1023. xenbus_switch_state(dev, XenbusStateClosing);
  1024. break;
  1025. case XenbusStateClosed:
  1026. xenbus_switch_state(dev, XenbusStateClosed);
  1027. if (xenbus_dev_is_online(dev))
  1028. break;
  1029. fallthrough; /* if not online */
  1030. case XenbusStateUnknown:
  1031. device_unregister(&dev->dev);
  1032. break;
  1033. case XenbusStateReconfiguring:
  1034. scsiback_do_lun_hotplug(info, VSCSIBACK_OP_ADD_OR_DEL_LUN);
  1035. xenbus_switch_state(dev, XenbusStateReconfigured);
  1036. break;
  1037. default:
  1038. xenbus_dev_fatal(dev, -EINVAL, "saw state %d at frontend",
  1039. frontend_state);
  1040. break;
  1041. }
  1042. }
  1043. /*
  1044. Release the translation entry specfied
  1045. */
  1046. static void scsiback_release_translation_entry(struct vscsibk_info *info)
  1047. {
  1048. struct v2p_entry *entry, *tmp;
  1049. struct list_head *head = &(info->v2p_entry_lists);
  1050. struct list_head tmp_list;
  1051. unsigned long flags;
  1052. spin_lock_irqsave(&info->v2p_lock, flags);
  1053. list_cut_before(&tmp_list, head, head);
  1054. spin_unlock_irqrestore(&info->v2p_lock, flags);
  1055. list_for_each_entry_safe(entry, tmp, &tmp_list, l) {
  1056. list_del(&entry->l);
  1057. kref_put(&entry->kref, scsiback_free_translation_entry);
  1058. }
  1059. }
  1060. static void scsiback_remove(struct xenbus_device *dev)
  1061. {
  1062. struct vscsibk_info *info = dev_get_drvdata(&dev->dev);
  1063. if (info->irq)
  1064. scsiback_disconnect(info);
  1065. scsiback_release_translation_entry(info);
  1066. gnttab_page_cache_shrink(&info->free_pages, 0);
  1067. dev_set_drvdata(&dev->dev, NULL);
  1068. kfree(info);
  1069. }
  1070. static int scsiback_probe(struct xenbus_device *dev,
  1071. const struct xenbus_device_id *id)
  1072. {
  1073. int err;
  1074. struct vscsibk_info *info = kzalloc_obj(struct vscsibk_info);
  1075. pr_debug("%s %p %d\n", __func__, dev, dev->otherend_id);
  1076. if (!info) {
  1077. xenbus_dev_fatal(dev, -ENOMEM, "allocating backend structure");
  1078. return -ENOMEM;
  1079. }
  1080. info->dev = dev;
  1081. dev_set_drvdata(&dev->dev, info);
  1082. info->domid = dev->otherend_id;
  1083. spin_lock_init(&info->ring_lock);
  1084. atomic_set(&info->nr_unreplied_reqs, 0);
  1085. init_waitqueue_head(&info->waiting_to_free);
  1086. info->dev = dev;
  1087. info->irq = 0;
  1088. INIT_LIST_HEAD(&info->v2p_entry_lists);
  1089. spin_lock_init(&info->v2p_lock);
  1090. gnttab_page_cache_init(&info->free_pages);
  1091. err = xenbus_printf(XBT_NIL, dev->nodename, "feature-sg-grant", "%u",
  1092. SG_ALL);
  1093. if (err)
  1094. xenbus_dev_error(dev, err, "writing feature-sg-grant");
  1095. err = xenbus_switch_state(dev, XenbusStateInitWait);
  1096. if (err)
  1097. goto fail;
  1098. return 0;
  1099. fail:
  1100. pr_warn("%s failed\n", __func__);
  1101. scsiback_remove(dev);
  1102. return err;
  1103. }
  1104. static char *scsiback_dump_proto_id(struct scsiback_tport *tport)
  1105. {
  1106. switch (tport->tport_proto_id) {
  1107. case SCSI_PROTOCOL_SAS:
  1108. return "SAS";
  1109. case SCSI_PROTOCOL_FCP:
  1110. return "FCP";
  1111. case SCSI_PROTOCOL_ISCSI:
  1112. return "iSCSI";
  1113. default:
  1114. break;
  1115. }
  1116. return "Unknown";
  1117. }
  1118. static char *scsiback_get_fabric_wwn(struct se_portal_group *se_tpg)
  1119. {
  1120. struct scsiback_tpg *tpg = container_of(se_tpg,
  1121. struct scsiback_tpg, se_tpg);
  1122. struct scsiback_tport *tport = tpg->tport;
  1123. return &tport->tport_name[0];
  1124. }
  1125. static u16 scsiback_get_tag(struct se_portal_group *se_tpg)
  1126. {
  1127. struct scsiback_tpg *tpg = container_of(se_tpg,
  1128. struct scsiback_tpg, se_tpg);
  1129. return tpg->tport_tpgt;
  1130. }
  1131. static struct se_wwn *
  1132. scsiback_make_tport(struct target_fabric_configfs *tf,
  1133. struct config_group *group,
  1134. const char *name)
  1135. {
  1136. struct scsiback_tport *tport;
  1137. char *ptr;
  1138. u64 wwpn = 0;
  1139. int off = 0;
  1140. tport = kzalloc_obj(struct scsiback_tport);
  1141. if (!tport)
  1142. return ERR_PTR(-ENOMEM);
  1143. tport->tport_wwpn = wwpn;
  1144. /*
  1145. * Determine the emulated Protocol Identifier and Target Port Name
  1146. * based on the incoming configfs directory name.
  1147. */
  1148. ptr = strstr(name, "naa.");
  1149. if (ptr) {
  1150. tport->tport_proto_id = SCSI_PROTOCOL_SAS;
  1151. goto check_len;
  1152. }
  1153. ptr = strstr(name, "fc.");
  1154. if (ptr) {
  1155. tport->tport_proto_id = SCSI_PROTOCOL_FCP;
  1156. off = 3; /* Skip over "fc." */
  1157. goto check_len;
  1158. }
  1159. ptr = strstr(name, "iqn.");
  1160. if (ptr) {
  1161. tport->tport_proto_id = SCSI_PROTOCOL_ISCSI;
  1162. goto check_len;
  1163. }
  1164. pr_err("Unable to locate prefix for emulated Target Port: %s\n", name);
  1165. kfree(tport);
  1166. return ERR_PTR(-EINVAL);
  1167. check_len:
  1168. if (strlen(name) >= VSCSI_NAMELEN) {
  1169. pr_err("Emulated %s Address: %s, exceeds max: %d\n", name,
  1170. scsiback_dump_proto_id(tport), VSCSI_NAMELEN);
  1171. kfree(tport);
  1172. return ERR_PTR(-EINVAL);
  1173. }
  1174. snprintf(&tport->tport_name[0], VSCSI_NAMELEN, "%s", &name[off]);
  1175. pr_debug("Allocated emulated Target %s Address: %s\n",
  1176. scsiback_dump_proto_id(tport), name);
  1177. return &tport->tport_wwn;
  1178. }
  1179. static void scsiback_drop_tport(struct se_wwn *wwn)
  1180. {
  1181. struct scsiback_tport *tport = container_of(wwn,
  1182. struct scsiback_tport, tport_wwn);
  1183. pr_debug("Deallocating emulated Target %s Address: %s\n",
  1184. scsiback_dump_proto_id(tport), tport->tport_name);
  1185. kfree(tport);
  1186. }
  1187. static int scsiback_check_stop_free(struct se_cmd *se_cmd)
  1188. {
  1189. return transport_generic_free_cmd(se_cmd, 0);
  1190. }
  1191. static void scsiback_release_cmd(struct se_cmd *se_cmd)
  1192. {
  1193. target_free_tag(se_cmd->se_sess, se_cmd);
  1194. }
  1195. static int scsiback_write_pending(struct se_cmd *se_cmd)
  1196. {
  1197. /* Go ahead and process the write immediately */
  1198. target_execute_cmd(se_cmd);
  1199. return 0;
  1200. }
  1201. static int scsiback_queue_data_in(struct se_cmd *se_cmd)
  1202. {
  1203. struct vscsibk_pend *pending_req = container_of(se_cmd,
  1204. struct vscsibk_pend, se_cmd);
  1205. pending_req->result = SAM_STAT_GOOD;
  1206. scsiback_cmd_done(pending_req);
  1207. return 0;
  1208. }
  1209. static int scsiback_queue_status(struct se_cmd *se_cmd)
  1210. {
  1211. struct vscsibk_pend *pending_req = container_of(se_cmd,
  1212. struct vscsibk_pend, se_cmd);
  1213. if (se_cmd->sense_buffer &&
  1214. ((se_cmd->se_cmd_flags & SCF_TRANSPORT_TASK_SENSE) ||
  1215. (se_cmd->se_cmd_flags & SCF_EMULATED_TASK_SENSE)))
  1216. pending_req->result = SAM_STAT_CHECK_CONDITION;
  1217. else
  1218. pending_req->result = se_cmd->scsi_status;
  1219. scsiback_cmd_done(pending_req);
  1220. return 0;
  1221. }
  1222. static void scsiback_queue_tm_rsp(struct se_cmd *se_cmd)
  1223. {
  1224. struct vscsibk_pend *pending_req = container_of(se_cmd,
  1225. struct vscsibk_pend, se_cmd);
  1226. complete(&pending_req->tmr_done);
  1227. }
  1228. static void scsiback_aborted_task(struct se_cmd *se_cmd)
  1229. {
  1230. }
  1231. static ssize_t scsiback_tpg_param_alias_show(struct config_item *item,
  1232. char *page)
  1233. {
  1234. struct se_portal_group *se_tpg = param_to_tpg(item);
  1235. struct scsiback_tpg *tpg = container_of(se_tpg, struct scsiback_tpg,
  1236. se_tpg);
  1237. ssize_t rb;
  1238. mutex_lock(&tpg->tv_tpg_mutex);
  1239. rb = snprintf(page, PAGE_SIZE, "%s\n", tpg->param_alias);
  1240. mutex_unlock(&tpg->tv_tpg_mutex);
  1241. return rb;
  1242. }
  1243. static ssize_t scsiback_tpg_param_alias_store(struct config_item *item,
  1244. const char *page, size_t count)
  1245. {
  1246. struct se_portal_group *se_tpg = param_to_tpg(item);
  1247. struct scsiback_tpg *tpg = container_of(se_tpg, struct scsiback_tpg,
  1248. se_tpg);
  1249. int len;
  1250. if (strlen(page) >= VSCSI_NAMELEN) {
  1251. pr_err("param alias: %s, exceeds max: %d\n", page,
  1252. VSCSI_NAMELEN);
  1253. return -EINVAL;
  1254. }
  1255. mutex_lock(&tpg->tv_tpg_mutex);
  1256. len = snprintf(tpg->param_alias, VSCSI_NAMELEN, "%s", page);
  1257. if (tpg->param_alias[len - 1] == '\n')
  1258. tpg->param_alias[len - 1] = '\0';
  1259. mutex_unlock(&tpg->tv_tpg_mutex);
  1260. return count;
  1261. }
  1262. CONFIGFS_ATTR(scsiback_tpg_param_, alias);
  1263. static struct configfs_attribute *scsiback_param_attrs[] = {
  1264. &scsiback_tpg_param_attr_alias,
  1265. NULL,
  1266. };
  1267. static int scsiback_alloc_sess_cb(struct se_portal_group *se_tpg,
  1268. struct se_session *se_sess, void *p)
  1269. {
  1270. struct scsiback_tpg *tpg = container_of(se_tpg,
  1271. struct scsiback_tpg, se_tpg);
  1272. tpg->tpg_nexus = p;
  1273. return 0;
  1274. }
  1275. static int scsiback_make_nexus(struct scsiback_tpg *tpg,
  1276. const char *name)
  1277. {
  1278. struct scsiback_nexus *tv_nexus;
  1279. int ret = 0;
  1280. mutex_lock(&tpg->tv_tpg_mutex);
  1281. if (tpg->tpg_nexus) {
  1282. pr_debug("tpg->tpg_nexus already exists\n");
  1283. ret = -EEXIST;
  1284. goto out_unlock;
  1285. }
  1286. tv_nexus = kzalloc_obj(struct scsiback_nexus);
  1287. if (!tv_nexus) {
  1288. ret = -ENOMEM;
  1289. goto out_unlock;
  1290. }
  1291. tv_nexus->tvn_se_sess = target_setup_session(&tpg->se_tpg,
  1292. VSCSI_DEFAULT_SESSION_TAGS,
  1293. sizeof(struct vscsibk_pend),
  1294. TARGET_PROT_NORMAL, name,
  1295. tv_nexus, scsiback_alloc_sess_cb);
  1296. if (IS_ERR(tv_nexus->tvn_se_sess)) {
  1297. kfree(tv_nexus);
  1298. ret = -ENOMEM;
  1299. goto out_unlock;
  1300. }
  1301. out_unlock:
  1302. mutex_unlock(&tpg->tv_tpg_mutex);
  1303. return ret;
  1304. }
  1305. static int scsiback_drop_nexus(struct scsiback_tpg *tpg)
  1306. {
  1307. struct se_session *se_sess;
  1308. struct scsiback_nexus *tv_nexus;
  1309. mutex_lock(&tpg->tv_tpg_mutex);
  1310. tv_nexus = tpg->tpg_nexus;
  1311. if (!tv_nexus) {
  1312. mutex_unlock(&tpg->tv_tpg_mutex);
  1313. return -ENODEV;
  1314. }
  1315. se_sess = tv_nexus->tvn_se_sess;
  1316. if (!se_sess) {
  1317. mutex_unlock(&tpg->tv_tpg_mutex);
  1318. return -ENODEV;
  1319. }
  1320. if (tpg->tv_tpg_port_count != 0) {
  1321. mutex_unlock(&tpg->tv_tpg_mutex);
  1322. pr_err("Unable to remove xen-pvscsi I_T Nexus with active TPG port count: %d\n",
  1323. tpg->tv_tpg_port_count);
  1324. return -EBUSY;
  1325. }
  1326. if (tpg->tv_tpg_fe_count != 0) {
  1327. mutex_unlock(&tpg->tv_tpg_mutex);
  1328. pr_err("Unable to remove xen-pvscsi I_T Nexus with active TPG frontend count: %d\n",
  1329. tpg->tv_tpg_fe_count);
  1330. return -EBUSY;
  1331. }
  1332. pr_debug("Removing I_T Nexus to emulated %s Initiator Port: %s\n",
  1333. scsiback_dump_proto_id(tpg->tport),
  1334. tv_nexus->tvn_se_sess->se_node_acl->initiatorname);
  1335. /*
  1336. * Release the SCSI I_T Nexus to the emulated xen-pvscsi Target Port
  1337. */
  1338. target_remove_session(se_sess);
  1339. tpg->tpg_nexus = NULL;
  1340. mutex_unlock(&tpg->tv_tpg_mutex);
  1341. kfree(tv_nexus);
  1342. return 0;
  1343. }
  1344. static ssize_t scsiback_tpg_nexus_show(struct config_item *item, char *page)
  1345. {
  1346. struct se_portal_group *se_tpg = to_tpg(item);
  1347. struct scsiback_tpg *tpg = container_of(se_tpg,
  1348. struct scsiback_tpg, se_tpg);
  1349. struct scsiback_nexus *tv_nexus;
  1350. ssize_t ret;
  1351. mutex_lock(&tpg->tv_tpg_mutex);
  1352. tv_nexus = tpg->tpg_nexus;
  1353. if (!tv_nexus) {
  1354. mutex_unlock(&tpg->tv_tpg_mutex);
  1355. return -ENODEV;
  1356. }
  1357. ret = snprintf(page, PAGE_SIZE, "%s\n",
  1358. tv_nexus->tvn_se_sess->se_node_acl->initiatorname);
  1359. mutex_unlock(&tpg->tv_tpg_mutex);
  1360. return ret;
  1361. }
  1362. static ssize_t scsiback_tpg_nexus_store(struct config_item *item,
  1363. const char *page, size_t count)
  1364. {
  1365. struct se_portal_group *se_tpg = to_tpg(item);
  1366. struct scsiback_tpg *tpg = container_of(se_tpg,
  1367. struct scsiback_tpg, se_tpg);
  1368. struct scsiback_tport *tport_wwn = tpg->tport;
  1369. unsigned char i_port[VSCSI_NAMELEN], *ptr, *port_ptr;
  1370. int ret;
  1371. /*
  1372. * Shutdown the active I_T nexus if 'NULL' is passed.
  1373. */
  1374. if (!strncmp(page, "NULL", 4)) {
  1375. ret = scsiback_drop_nexus(tpg);
  1376. return (!ret) ? count : ret;
  1377. }
  1378. /*
  1379. * Otherwise make sure the passed virtual Initiator port WWN matches
  1380. * the fabric protocol_id set in scsiback_make_tport(), and call
  1381. * scsiback_make_nexus().
  1382. */
  1383. if (strlen(page) >= VSCSI_NAMELEN) {
  1384. pr_err("Emulated NAA Sas Address: %s, exceeds max: %d\n",
  1385. page, VSCSI_NAMELEN);
  1386. return -EINVAL;
  1387. }
  1388. snprintf(&i_port[0], VSCSI_NAMELEN, "%s", page);
  1389. ptr = strstr(i_port, "naa.");
  1390. if (ptr) {
  1391. if (tport_wwn->tport_proto_id != SCSI_PROTOCOL_SAS) {
  1392. pr_err("Passed SAS Initiator Port %s does not match target port protoid: %s\n",
  1393. i_port, scsiback_dump_proto_id(tport_wwn));
  1394. return -EINVAL;
  1395. }
  1396. port_ptr = &i_port[0];
  1397. goto check_newline;
  1398. }
  1399. ptr = strstr(i_port, "fc.");
  1400. if (ptr) {
  1401. if (tport_wwn->tport_proto_id != SCSI_PROTOCOL_FCP) {
  1402. pr_err("Passed FCP Initiator Port %s does not match target port protoid: %s\n",
  1403. i_port, scsiback_dump_proto_id(tport_wwn));
  1404. return -EINVAL;
  1405. }
  1406. port_ptr = &i_port[3]; /* Skip over "fc." */
  1407. goto check_newline;
  1408. }
  1409. ptr = strstr(i_port, "iqn.");
  1410. if (ptr) {
  1411. if (tport_wwn->tport_proto_id != SCSI_PROTOCOL_ISCSI) {
  1412. pr_err("Passed iSCSI Initiator Port %s does not match target port protoid: %s\n",
  1413. i_port, scsiback_dump_proto_id(tport_wwn));
  1414. return -EINVAL;
  1415. }
  1416. port_ptr = &i_port[0];
  1417. goto check_newline;
  1418. }
  1419. pr_err("Unable to locate prefix for emulated Initiator Port: %s\n",
  1420. i_port);
  1421. return -EINVAL;
  1422. /*
  1423. * Clear any trailing newline for the NAA WWN
  1424. */
  1425. check_newline:
  1426. if (i_port[strlen(i_port) - 1] == '\n')
  1427. i_port[strlen(i_port) - 1] = '\0';
  1428. ret = scsiback_make_nexus(tpg, port_ptr);
  1429. if (ret < 0)
  1430. return ret;
  1431. return count;
  1432. }
  1433. CONFIGFS_ATTR(scsiback_tpg_, nexus);
  1434. static struct configfs_attribute *scsiback_tpg_attrs[] = {
  1435. &scsiback_tpg_attr_nexus,
  1436. NULL,
  1437. };
  1438. static ssize_t
  1439. scsiback_wwn_version_show(struct config_item *item, char *page)
  1440. {
  1441. return sprintf(page, "xen-pvscsi fabric module %s on %s/%s on "
  1442. UTS_RELEASE"\n",
  1443. VSCSI_VERSION, utsname()->sysname, utsname()->machine);
  1444. }
  1445. CONFIGFS_ATTR_RO(scsiback_wwn_, version);
  1446. static struct configfs_attribute *scsiback_wwn_attrs[] = {
  1447. &scsiback_wwn_attr_version,
  1448. NULL,
  1449. };
  1450. static int scsiback_port_link(struct se_portal_group *se_tpg,
  1451. struct se_lun *lun)
  1452. {
  1453. struct scsiback_tpg *tpg = container_of(se_tpg,
  1454. struct scsiback_tpg, se_tpg);
  1455. mutex_lock(&tpg->tv_tpg_mutex);
  1456. tpg->tv_tpg_port_count++;
  1457. mutex_unlock(&tpg->tv_tpg_mutex);
  1458. return 0;
  1459. }
  1460. static void scsiback_port_unlink(struct se_portal_group *se_tpg,
  1461. struct se_lun *lun)
  1462. {
  1463. struct scsiback_tpg *tpg = container_of(se_tpg,
  1464. struct scsiback_tpg, se_tpg);
  1465. mutex_lock(&tpg->tv_tpg_mutex);
  1466. tpg->tv_tpg_port_count--;
  1467. mutex_unlock(&tpg->tv_tpg_mutex);
  1468. }
  1469. static struct se_portal_group *
  1470. scsiback_make_tpg(struct se_wwn *wwn, const char *name)
  1471. {
  1472. struct scsiback_tport *tport = container_of(wwn,
  1473. struct scsiback_tport, tport_wwn);
  1474. struct scsiback_tpg *tpg;
  1475. u16 tpgt;
  1476. int ret;
  1477. if (strstr(name, "tpgt_") != name)
  1478. return ERR_PTR(-EINVAL);
  1479. ret = kstrtou16(name + 5, 10, &tpgt);
  1480. if (ret)
  1481. return ERR_PTR(ret);
  1482. tpg = kzalloc_obj(struct scsiback_tpg);
  1483. if (!tpg)
  1484. return ERR_PTR(-ENOMEM);
  1485. mutex_init(&tpg->tv_tpg_mutex);
  1486. INIT_LIST_HEAD(&tpg->tv_tpg_list);
  1487. INIT_LIST_HEAD(&tpg->info_list);
  1488. tpg->tport = tport;
  1489. tpg->tport_tpgt = tpgt;
  1490. ret = core_tpg_register(wwn, &tpg->se_tpg, tport->tport_proto_id);
  1491. if (ret < 0) {
  1492. kfree(tpg);
  1493. return NULL;
  1494. }
  1495. mutex_lock(&scsiback_mutex);
  1496. list_add_tail(&tpg->tv_tpg_list, &scsiback_list);
  1497. mutex_unlock(&scsiback_mutex);
  1498. return &tpg->se_tpg;
  1499. }
  1500. static void scsiback_drop_tpg(struct se_portal_group *se_tpg)
  1501. {
  1502. struct scsiback_tpg *tpg = container_of(se_tpg,
  1503. struct scsiback_tpg, se_tpg);
  1504. mutex_lock(&scsiback_mutex);
  1505. list_del(&tpg->tv_tpg_list);
  1506. mutex_unlock(&scsiback_mutex);
  1507. /*
  1508. * Release the virtual I_T Nexus for this xen-pvscsi TPG
  1509. */
  1510. scsiback_drop_nexus(tpg);
  1511. /*
  1512. * Deregister the se_tpg from TCM.
  1513. */
  1514. core_tpg_deregister(se_tpg);
  1515. kfree(tpg);
  1516. }
  1517. static int scsiback_check_true(struct se_portal_group *se_tpg)
  1518. {
  1519. return 1;
  1520. }
  1521. static const struct target_core_fabric_ops scsiback_ops = {
  1522. .module = THIS_MODULE,
  1523. .fabric_name = "xen-pvscsi",
  1524. .tpg_get_wwn = scsiback_get_fabric_wwn,
  1525. .tpg_get_tag = scsiback_get_tag,
  1526. .tpg_check_demo_mode = scsiback_check_true,
  1527. .tpg_check_demo_mode_cache = scsiback_check_true,
  1528. .check_stop_free = scsiback_check_stop_free,
  1529. .release_cmd = scsiback_release_cmd,
  1530. .sess_get_initiator_sid = NULL,
  1531. .write_pending = scsiback_write_pending,
  1532. .queue_data_in = scsiback_queue_data_in,
  1533. .queue_status = scsiback_queue_status,
  1534. .queue_tm_rsp = scsiback_queue_tm_rsp,
  1535. .aborted_task = scsiback_aborted_task,
  1536. /*
  1537. * Setup callers for generic logic in target_core_fabric_configfs.c
  1538. */
  1539. .fabric_make_wwn = scsiback_make_tport,
  1540. .fabric_drop_wwn = scsiback_drop_tport,
  1541. .fabric_make_tpg = scsiback_make_tpg,
  1542. .fabric_drop_tpg = scsiback_drop_tpg,
  1543. .fabric_post_link = scsiback_port_link,
  1544. .fabric_pre_unlink = scsiback_port_unlink,
  1545. .tfc_wwn_attrs = scsiback_wwn_attrs,
  1546. .tfc_tpg_base_attrs = scsiback_tpg_attrs,
  1547. .tfc_tpg_param_attrs = scsiback_param_attrs,
  1548. .default_submit_type = TARGET_DIRECT_SUBMIT,
  1549. .direct_submit_supp = 1,
  1550. };
  1551. static const struct xenbus_device_id scsiback_ids[] = {
  1552. { "vscsi" },
  1553. { "" }
  1554. };
  1555. static struct xenbus_driver scsiback_driver = {
  1556. .ids = scsiback_ids,
  1557. .probe = scsiback_probe,
  1558. .remove = scsiback_remove,
  1559. .otherend_changed = scsiback_frontend_changed
  1560. };
  1561. static int __init scsiback_init(void)
  1562. {
  1563. int ret;
  1564. if (!xen_domain())
  1565. return -ENODEV;
  1566. pr_debug("xen-pvscsi: fabric module %s on %s/%s on "UTS_RELEASE"\n",
  1567. VSCSI_VERSION, utsname()->sysname, utsname()->machine);
  1568. ret = xenbus_register_backend(&scsiback_driver);
  1569. if (ret)
  1570. goto out;
  1571. ret = target_register_template(&scsiback_ops);
  1572. if (ret)
  1573. goto out_unregister_xenbus;
  1574. return 0;
  1575. out_unregister_xenbus:
  1576. xenbus_unregister_driver(&scsiback_driver);
  1577. out:
  1578. pr_err("%s: error %d\n", __func__, ret);
  1579. return ret;
  1580. }
  1581. static void __exit scsiback_exit(void)
  1582. {
  1583. target_unregister_template(&scsiback_ops);
  1584. xenbus_unregister_driver(&scsiback_driver);
  1585. }
  1586. module_init(scsiback_init);
  1587. module_exit(scsiback_exit);
  1588. MODULE_DESCRIPTION("Xen SCSI backend driver");
  1589. MODULE_LICENSE("Dual BSD/GPL");
  1590. MODULE_ALIAS("xen-backend:vscsi");
  1591. MODULE_AUTHOR("Juergen Gross <jgross@suse.com>");