]>
Commit | Line | Data |
---|---|---|
e4d5639d AS |
1 | /* |
2 | * Helpers for getting linearized buffers from iov / filling buffers into iovs | |
3 | * | |
4 | * Copyright IBM, Corp. 2007, 2008 | |
5 | * Copyright (C) 2010 Red Hat, Inc. | |
6 | * | |
7 | * Author(s): | |
8 | * Anthony Liguori <aliguori@us.ibm.com> | |
9 | * Amit Shah <amit.shah@redhat.com> | |
10 | * | |
11 | * This work is licensed under the terms of the GNU GPL, version 2. See | |
12 | * the COPYING file in the top-level directory. | |
13 | */ | |
14 | ||
15 | #include "iov.h" | |
16 | ||
348e7b8d HR |
17 | size_t iov_from_buf(struct iovec *iov, unsigned int iov_cnt, |
18 | const void *buf, size_t iov_off, size_t size) | |
e4d5639d | 19 | { |
348e7b8d | 20 | size_t iovec_off, buf_off; |
e4d5639d AS |
21 | unsigned int i; |
22 | ||
348e7b8d HR |
23 | iovec_off = 0; |
24 | buf_off = 0; | |
25 | for (i = 0; i < iov_cnt && size; i++) { | |
26 | if (iov_off < (iovec_off + iov[i].iov_len)) { | |
27 | size_t len = MIN((iovec_off + iov[i].iov_len) - iov_off, size); | |
e4d5639d | 28 | |
348e7b8d | 29 | memcpy(iov[i].iov_base + (iov_off - iovec_off), buf + buf_off, len); |
e4d5639d | 30 | |
348e7b8d HR |
31 | buf_off += len; |
32 | iov_off += len; | |
33 | size -= len; | |
34 | } | |
35 | iovec_off += iov[i].iov_len; | |
e4d5639d | 36 | } |
348e7b8d | 37 | return buf_off; |
e4d5639d | 38 | } |
fa6111f2 | 39 | |
348e7b8d HR |
40 | size_t iov_to_buf(const struct iovec *iov, const unsigned int iov_cnt, |
41 | void *buf, size_t iov_off, size_t size) | |
fa6111f2 AS |
42 | { |
43 | uint8_t *ptr; | |
348e7b8d | 44 | size_t iovec_off, buf_off; |
fa6111f2 AS |
45 | unsigned int i; |
46 | ||
47 | ptr = buf; | |
348e7b8d | 48 | iovec_off = 0; |
fa6111f2 | 49 | buf_off = 0; |
348e7b8d HR |
50 | for (i = 0; i < iov_cnt && size; i++) { |
51 | if (iov_off < (iovec_off + iov[i].iov_len)) { | |
52 | size_t len = MIN((iovec_off + iov[i].iov_len) - iov_off , size); | |
fa6111f2 | 53 | |
348e7b8d | 54 | memcpy(ptr + buf_off, iov[i].iov_base + (iov_off - iovec_off), len); |
fa6111f2 AS |
55 | |
56 | buf_off += len; | |
348e7b8d | 57 | iov_off += len; |
fa6111f2 AS |
58 | size -= len; |
59 | } | |
348e7b8d | 60 | iovec_off += iov[i].iov_len; |
8d15028e GH |
61 | } |
62 | return buf_off; | |
63 | } | |
64 | ||
65 | size_t iov_clear(const struct iovec *iov, const unsigned int iov_cnt, | |
66 | size_t iov_off, size_t size) | |
67 | { | |
68 | size_t iovec_off, buf_off; | |
69 | unsigned int i; | |
70 | ||
71 | iovec_off = 0; | |
72 | buf_off = 0; | |
73 | for (i = 0; i < iov_cnt && size; i++) { | |
74 | if (iov_off < (iovec_off + iov[i].iov_len)) { | |
75 | size_t len = MIN((iovec_off + iov[i].iov_len) - iov_off , size); | |
76 | ||
77 | memset(iov[i].iov_base + (iov_off - iovec_off), 0, len); | |
78 | ||
79 | buf_off += len; | |
80 | iov_off += len; | |
81 | size -= len; | |
82 | } | |
83 | iovec_off += iov[i].iov_len; | |
fa6111f2 AS |
84 | } |
85 | return buf_off; | |
86 | } | |
87 | ||
348e7b8d | 88 | size_t iov_size(const struct iovec *iov, const unsigned int iov_cnt) |
fa6111f2 AS |
89 | { |
90 | size_t len; | |
91 | unsigned int i; | |
92 | ||
93 | len = 0; | |
348e7b8d | 94 | for (i = 0; i < iov_cnt; i++) { |
fa6111f2 AS |
95 | len += iov[i].iov_len; |
96 | } | |
97 | return len; | |
98 | } | |
3a1dca94 GH |
99 | |
100 | void iov_hexdump(const struct iovec *iov, const unsigned int iov_cnt, | |
101 | FILE *fp, const char *prefix, size_t limit) | |
102 | { | |
103 | unsigned int i, v, b; | |
104 | uint8_t *c; | |
105 | ||
106 | c = iov[0].iov_base; | |
107 | for (i = 0, v = 0, b = 0; b < limit; i++, b++) { | |
108 | if (i == iov[v].iov_len) { | |
109 | i = 0; v++; | |
110 | if (v == iov_cnt) { | |
111 | break; | |
112 | } | |
113 | c = iov[v].iov_base; | |
114 | } | |
115 | if ((b % 16) == 0) { | |
116 | fprintf(fp, "%s: %04x:", prefix, b); | |
117 | } | |
118 | if ((b % 4) == 0) { | |
119 | fprintf(fp, " "); | |
120 | } | |
121 | fprintf(fp, " %02x", c[i]); | |
122 | if ((b % 16) == 15) { | |
123 | fprintf(fp, "\n"); | |
124 | } | |
125 | } | |
126 | if ((b % 16) != 0) { | |
127 | fprintf(fp, "\n"); | |
128 | } | |
129 | } |