Home | History | Annotate | Download | only in sg_write_buffer

Lines Matching refs:dop

40  * page 0x83 (device identification) descriptor(s) in dop. Return the
44 * N.B. Does not write total VPD page length into dop[2:3] . */
48 int tproto, uint8_t * dop, int max_do_len)
54 if ((NULL == nvme_id_ctl_p) || (NULL == dop) || (max_do_len < 56))
57 memset(dop, 0, max_do_len);
58 dop[0] = 0x1f & pdt; /* (PQ=0)<<5 | (PDT=pdt); 0 or 0xd (SES) */
59 dop[1] = 0x83; /* Device Identification VPD page number */
62 dop[4] = ((0xf & tproto) << 4) | 0x2;
63 dop[5] = 0xa1; /* PIV=1, ASSOC=2 (target device), desig_id=1 */
65 dop[4] = 0x2; /* Prococol id=0, code_set=2 (ASCII) */
66 dop[5] = 0x21; /* PIV=0, ASSOC=2 (target device), desig_id=1 */
68 memcpy(dop + 8, nvme_scsi_vendor_str, 8); /* N.B. this is "NVMe " */
69 memcpy(dop + 16, nvme_id_ctl_p + 24, 40); /* MN */
71 if (' ' == dop[15 + k])
72 dop[15 + k] = '_'; /* convert trailing spaces */
81 memcpy(dop + n, nvme_id_ctl_p + 4, 20); /* SN */
83 if (' ' == dop[n + k - 1])
84 dop[n + k - 1] = '\0';
91 dop[7] = n - 8;
105 dop[n + 0] = 0x1; /* Prococol id=0, code_set=1 (binary) */
106 dop[n + 1] = 0x02; /* PIV=0, ASSOC=0 (lu), desig_id=2 (eui) */
107 dop[n + 3] = 16;
108 memcpy(dop + n + 4, nvme_id_ns_p + 104, 16);
112 dop[n + 0] = 0x3; /* Prococol id=0, code_set=3 (utf8) */
113 dop[n + 1] = 0x08; /* PIV=0, ASSOC=0 (lu), desig_id=8 (scsi string) */
114 dop[n + 3] = 36;
115 memcpy(dop + n + 4, "eui.", 4);
118 memcpy(dop + n + 8 + (2 * k), b, 2);
124 dop[n + 0] = 0x1; /* Prococol id=0, code_set=1 (binary) */
125 dop[n + 1] = 0x02; /* PIV=0, ASSOC=0 (lu), desig_id=2 (eui) */
126 dop[n + 3] = 8;
127 memcpy(dop + n + 4, nvme_id_ns_p + 120, 8);
131 dop[n + 0] = 0x3; /* Prococol id=0, code_set=3 (utf8) */
132 dop[n + 1] = 0x08; /* PIV=0, ASSOC=0 (lu), desig_id=8 (scsi string) */
133 dop[n + 3] = 20;
134 memcpy(dop + n + 4, "eui.", 4);
137 memcpy(dop + n + 8 + (2 * k), b, 2);