summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorTed Unangst <tedu@cvs.openbsd.org>2010-06-29 18:43:55 +0000
committerTed Unangst <tedu@cvs.openbsd.org>2010-06-29 18:43:55 +0000
commitfa0d9c1de9b80a2ef642deca86027fbc945ad709 (patch)
tree484f5108e8923e9a8285d7799250c90a952bf896 /sys
parent77670e751eb5e3a565a2d78106cdb35b569192a8 (diff)
move a little code around, eventually it will be better
Diffstat (limited to 'sys')
-rw-r--r--sys/dev/softraid_aoe.c175
1 files changed, 97 insertions, 78 deletions
diff --git a/sys/dev/softraid_aoe.c b/sys/dev/softraid_aoe.c
index 97d9afe5e81..de6775c4bc1 100644
--- a/sys/dev/softraid_aoe.c
+++ b/sys/dev/softraid_aoe.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: softraid_aoe.c,v 1.14 2010/03/06 17:26:44 jsing Exp $ */
+/* $OpenBSD: softraid_aoe.c,v 1.15 2010/06/29 18:43:54 tedu Exp $ */
/*
* Copyright (c) 2008 Ted Unangst <tedu@openbsd.org>
* Copyright (c) 2008 Marco Peereboom <marco@openbsd.org>
@@ -299,25 +299,114 @@ sr_aoe_free_resources(struct sr_discipline *sd)
return (rv);
}
+int sr_send_aoe_chunk(struct sr_workunit *wu, daddr64_t blk, int i);
int
-sr_aoe_rw(struct sr_workunit *wu)
+sr_send_aoe_chunk(struct sr_workunit *wu, daddr64_t blk, int i)
{
struct sr_discipline *sd = wu->swu_dis;
struct scsi_xfer *xs = wu->swu_xs;
- struct sr_workunit *wup;
- struct sr_chunk *scp;
- int s, ios, rt;
- daddr64_t fragblk, blk;
+ int s;
+ daddr64_t fragblk;
struct mbuf *m;
struct ether_header *eh;
struct aoe_packet *ap;
struct ifnet *ifp;
struct aoe_handler *ah;
struct aoe_req *ar;
- int tag, rv, i;
+ int tag, rv;
int fragsize;
const int aoe_frags = 2;
+ fragblk = blk + aoe_frags * i;
+ fragsize = aoe_frags * 512;
+ if (fragblk + aoe_frags - 1 > wu->swu_blk_end) {
+ fragsize = (wu->swu_blk_end - fragblk + 1) * 512;
+ }
+ tag = ++sd->mds.mdd_aoe.sra_tag;
+ ah = sd->mds.mdd_aoe.sra_ah;
+ ar = malloc(sizeof(*ar), M_DEVBUF, M_NOWAIT);
+ if (!ar) {
+ splx(s);
+ return ENOMEM;
+ }
+ ar->v = wu;
+ ar->tag = tag;
+ ar->len = fragsize;
+ timeout_set(&ar->to, sr_aoe_timeout, ar);
+ TAILQ_INSERT_TAIL(&ah->reqs, ar, next);
+ splx(s);
+
+ ifp = ah->ifp;
+ MGETHDR(m, M_DONTWAIT, MT_HEADER);
+ if (xs->flags & SCSI_DATA_OUT && m) {
+ MCLGET(m, M_DONTWAIT);
+ if (!(m->m_flags & M_EXT)) {
+ m_freem(m);
+ m = NULL;
+ }
+ }
+ if (!m) {
+ s = splbio();
+ TAILQ_REMOVE(&ah->reqs, ar, next);
+ splx(s);
+ free(ar, M_DEVBUF);
+ return ENOMEM;
+ }
+
+ eh = mtod(m, struct ether_header *);
+ memcpy(eh->ether_dhost, sd->mds.mdd_aoe.sra_eaddr, 6);
+ memcpy(eh->ether_shost, ((struct arpcom *)ifp)->ac_enaddr, 6);
+ eh->ether_type = htons(ETHERTYPE_AOE);
+ ap = (struct aoe_packet *)&eh[1];
+ ap->vers = 1;
+ ap->flags = 0;
+ ap->error = 0;
+ ap->major = ah->major;
+ ap->minor = ah->minor;
+ ap->command = 0;
+ ap->tag = tag;
+ ap->aflags = 0; /* AOE_EXTENDED; */
+ if (xs->flags & SCSI_DATA_OUT) {
+ ap->aflags |= AOE_WRITE;
+ ap->cmd = AOE_WRITE;
+ memcpy(ap->data, xs->data + (aoe_frags * i * 512), fragsize);
+ } else {
+ ap->cmd = AOE_READ;
+ }
+ ap->feature = 0;
+ ap->sectorcnt = fragsize / 512;
+ AOE_BLK2HDR(fragblk, ap);
+
+ m->m_pkthdr.len = m->m_len = AOE_CMDHDRLEN + fragsize;
+ s = splnet();
+ IFQ_ENQUEUE(&ifp->if_snd, m, NULL, rv);
+ if ((ifp->if_flags & IFF_OACTIVE) == 0)
+ (*ifp->if_start)(ifp);
+ timeout_add_sec(&ar->to, 10);
+ splx(s);
+
+ if (rv) {
+ s = splbio();
+ TAILQ_REMOVE(&ah->reqs, ar, next);
+ splx(s);
+ free(ar, M_DEVBUF);
+ }
+
+ return rv;
+}
+
+int
+sr_aoe_rw(struct sr_workunit *wu)
+{
+ struct sr_discipline *sd = wu->swu_dis;
+ struct scsi_xfer *xs = wu->swu_xs;
+ struct sr_workunit *wup;
+ struct sr_chunk *scp;
+ daddr64_t blk;
+ int s, ios, rt;
+ int rv, i;
+ const int aoe_frags = 2;
+
printf("%s: sr_aoe_rw 0x%02x\n", DEVNAME(sd->sd_sc),
xs->cmd->opcode);
@@ -359,11 +448,6 @@ sr_aoe_rw(struct sr_workunit *wu)
return (0);
}
for (i = 0; i < ios; i++) {
- fragblk = blk + aoe_frags * i;
- fragsize = aoe_frags * 512;
- if (fragblk + aoe_frags - 1 > wu->swu_blk_end) {
- fragsize = (wu->swu_blk_end - fragblk + 1) * 512;
- }
if (xs->flags & SCSI_DATA_IN) {
rt = 0;
ragain:
@@ -404,74 +488,9 @@ ragain:
}
}
- tag = ++sd->mds.mdd_aoe.sra_tag;
- ah = sd->mds.mdd_aoe.sra_ah;
- ar = malloc(sizeof(*ar), M_DEVBUF, M_NOWAIT);
- if (!ar) {
- splx(s);
- return ENOMEM;
- }
- ar->v = wu;
- ar->tag = tag;
- ar->len = fragsize;
- timeout_set(&ar->to, sr_aoe_timeout, ar);
- TAILQ_INSERT_TAIL(&ah->reqs, ar, next);
- splx(s);
-
- ifp = ah->ifp;
- MGETHDR(m, M_DONTWAIT, MT_HEADER);
- if (xs->flags & SCSI_DATA_OUT && m) {
- MCLGET(m, M_DONTWAIT);
- if (!(m->m_flags & M_EXT)) {
- m_freem(m);
- m = NULL;
- }
- }
- if (!m) {
- s = splbio();
- TAILQ_REMOVE(&ah->reqs, ar, next);
- splx(s);
- free(ar, M_DEVBUF);
- return ENOMEM;
- }
-
- eh = mtod(m, struct ether_header *);
- memcpy(eh->ether_dhost, sd->mds.mdd_aoe.sra_eaddr, 6);
- memcpy(eh->ether_shost, ((struct arpcom *)ifp)->ac_enaddr, 6);
- eh->ether_type = htons(ETHERTYPE_AOE);
- ap = (struct aoe_packet *)&eh[1];
- ap->vers = 1;
- ap->flags = 0;
- ap->error = 0;
- ap->major = ah->major;
- ap->minor = ah->minor;
- ap->command = 0;
- ap->tag = tag;
- ap->aflags = 0; /* AOE_EXTENDED; */
- if (xs->flags & SCSI_DATA_OUT) {
- ap->aflags |= AOE_WRITE;
- ap->cmd = AOE_WRITE;
- memcpy(ap->data, xs->data + (aoe_frags * i * 512), fragsize);
- } else {
- ap->cmd = AOE_READ;
- }
- ap->feature = 0;
- ap->sectorcnt = fragsize / 512;
- AOE_BLK2HDR(fragblk, ap);
-
- m->m_pkthdr.len = m->m_len = AOE_CMDHDRLEN + fragsize;
- s = splnet();
- IFQ_ENQUEUE(&ifp->if_snd, m, NULL, rv);
- if ((ifp->if_flags & IFF_OACTIVE) == 0)
- (*ifp->if_start)(ifp);
- timeout_add_sec(&ar->to, 10);
- splx(s);
+ rv = sr_send_aoe_chunk(wu, blk, i);
if (rv) {
- s = splbio();
- TAILQ_REMOVE(&ah->reqs, ar, next);
- splx(s);
- free(ar, M_DEVBUF);
return rv;
}
}