diff options
Diffstat (limited to 'src/lib/libcrypto/bio')
-rw-r--r-- | src/lib/libcrypto/bio/Makefile.ssl | 127 | ||||
-rw-r--r-- | src/lib/libcrypto/bio/b_dump.c | 122 | ||||
-rw-r--r-- | src/lib/libcrypto/bio/b_print.c | 346 | ||||
-rw-r--r-- | src/lib/libcrypto/bio/b_sock.c | 37 | ||||
-rw-r--r-- | src/lib/libcrypto/bio/bf_buff.c | 52 | ||||
-rw-r--r-- | src/lib/libcrypto/bio/bf_lbuf.c | 397 | ||||
-rw-r--r-- | src/lib/libcrypto/bio/bf_nbio.c | 20 | ||||
-rw-r--r-- | src/lib/libcrypto/bio/bf_null.c | 20 | ||||
-rw-r--r-- | src/lib/libcrypto/bio/bio.h | 66 | ||||
-rw-r--r-- | src/lib/libcrypto/bio/bio_err.c | 7 | ||||
-rw-r--r-- | src/lib/libcrypto/bio/bio_lib.c | 30 | ||||
-rw-r--r-- | src/lib/libcrypto/bio/bss_acpt.c | 24 | ||||
-rw-r--r-- | src/lib/libcrypto/bio/bss_bio.c | 20 | ||||
-rw-r--r-- | src/lib/libcrypto/bio/bss_conn.c | 47 | ||||
-rw-r--r-- | src/lib/libcrypto/bio/bss_file.c | 16 | ||||
-rw-r--r-- | src/lib/libcrypto/bio/bss_log.c | 130 | ||||
-rw-r--r-- | src/lib/libcrypto/bio/bss_mem.c | 33 | ||||
-rw-r--r-- | src/lib/libcrypto/bio/bss_null.c | 16 | ||||
-rw-r--r-- | src/lib/libcrypto/bio/bss_rtcp.c | 16 | ||||
-rw-r--r-- | src/lib/libcrypto/bio/bss_sock.c | 28 |
20 files changed, 1034 insertions, 520 deletions
diff --git a/src/lib/libcrypto/bio/Makefile.ssl b/src/lib/libcrypto/bio/Makefile.ssl index 755f255fe4..916d651d47 100644 --- a/src/lib/libcrypto/bio/Makefile.ssl +++ b/src/lib/libcrypto/bio/Makefile.ssl | |||
@@ -27,11 +27,13 @@ LIBSRC= bio_lib.c bio_cb.c bio_err.c \ | |||
27 | bss_file.c bss_sock.c bss_conn.c \ | 27 | bss_file.c bss_sock.c bss_conn.c \ |
28 | bf_null.c bf_buff.c b_print.c b_dump.c \ | 28 | bf_null.c bf_buff.c b_print.c b_dump.c \ |
29 | b_sock.c bss_acpt.c bf_nbio.c bss_log.c bss_bio.c | 29 | b_sock.c bss_acpt.c bf_nbio.c bss_log.c bss_bio.c |
30 | # bf_lbuf.c | ||
30 | LIBOBJ= bio_lib.o bio_cb.o bio_err.o \ | 31 | LIBOBJ= bio_lib.o bio_cb.o bio_err.o \ |
31 | bss_mem.o bss_null.o bss_fd.o \ | 32 | bss_mem.o bss_null.o bss_fd.o \ |
32 | bss_file.o bss_sock.o bss_conn.o \ | 33 | bss_file.o bss_sock.o bss_conn.o \ |
33 | bf_null.o bf_buff.o b_print.o b_dump.o \ | 34 | bf_null.o bf_buff.o b_print.o b_dump.o \ |
34 | b_sock.o bss_acpt.o bf_nbio.o bss_log.o bss_bio.o | 35 | b_sock.o bss_acpt.o bf_nbio.o bss_log.o bss_bio.o |
36 | # bf_lbuf.o | ||
35 | 37 | ||
36 | SRC= $(LIBSRC) | 38 | SRC= $(LIBSRC) |
37 | 39 | ||
@@ -89,20 +91,23 @@ clean: | |||
89 | b_dump.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h | 91 | b_dump.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h |
90 | b_dump.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h | 92 | b_dump.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h |
91 | b_dump.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h | 93 | b_dump.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h |
92 | b_dump.o: ../../include/openssl/opensslconf.h ../../include/openssl/opensslv.h | 94 | b_dump.o: ../../include/openssl/lhash.h ../../include/openssl/opensslconf.h |
93 | b_dump.o: ../../include/openssl/safestack.h ../../include/openssl/stack.h | 95 | b_dump.o: ../../include/openssl/opensslv.h ../../include/openssl/safestack.h |
96 | b_dump.o: ../../include/openssl/stack.h ../../include/openssl/symhacks.h | ||
94 | b_dump.o: ../cryptlib.h | 97 | b_dump.o: ../cryptlib.h |
95 | b_print.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h | 98 | b_print.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h |
96 | b_print.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h | 99 | b_print.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h |
97 | b_print.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h | 100 | b_print.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h |
98 | b_print.o: ../../include/openssl/opensslconf.h ../../include/openssl/opensslv.h | 101 | b_print.o: ../../include/openssl/lhash.h ../../include/openssl/opensslconf.h |
99 | b_print.o: ../../include/openssl/safestack.h ../../include/openssl/stack.h | 102 | b_print.o: ../../include/openssl/opensslv.h ../../include/openssl/safestack.h |
103 | b_print.o: ../../include/openssl/stack.h ../../include/openssl/symhacks.h | ||
100 | b_print.o: ../cryptlib.h | 104 | b_print.o: ../cryptlib.h |
101 | b_sock.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h | 105 | b_sock.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h |
102 | b_sock.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h | 106 | b_sock.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h |
103 | b_sock.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h | 107 | b_sock.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h |
104 | b_sock.o: ../../include/openssl/opensslconf.h ../../include/openssl/opensslv.h | 108 | b_sock.o: ../../include/openssl/lhash.h ../../include/openssl/opensslconf.h |
105 | b_sock.o: ../../include/openssl/safestack.h ../../include/openssl/stack.h | 109 | b_sock.o: ../../include/openssl/opensslv.h ../../include/openssl/safestack.h |
110 | b_sock.o: ../../include/openssl/stack.h ../../include/openssl/symhacks.h | ||
106 | b_sock.o: ../cryptlib.h | 111 | b_sock.o: ../cryptlib.h |
107 | bf_buff.o: ../../include/openssl/asn1.h ../../include/openssl/bio.h | 112 | bf_buff.o: ../../include/openssl/asn1.h ../../include/openssl/bio.h |
108 | bf_buff.o: ../../include/openssl/blowfish.h ../../include/openssl/bn.h | 113 | bf_buff.o: ../../include/openssl/blowfish.h ../../include/openssl/bn.h |
@@ -111,14 +116,16 @@ bf_buff.o: ../../include/openssl/crypto.h ../../include/openssl/des.h | |||
111 | bf_buff.o: ../../include/openssl/dh.h ../../include/openssl/dsa.h | 116 | bf_buff.o: ../../include/openssl/dh.h ../../include/openssl/dsa.h |
112 | bf_buff.o: ../../include/openssl/e_os.h ../../include/openssl/e_os2.h | 117 | bf_buff.o: ../../include/openssl/e_os.h ../../include/openssl/e_os2.h |
113 | bf_buff.o: ../../include/openssl/err.h ../../include/openssl/evp.h | 118 | bf_buff.o: ../../include/openssl/err.h ../../include/openssl/evp.h |
114 | bf_buff.o: ../../include/openssl/idea.h ../../include/openssl/md2.h | 119 | bf_buff.o: ../../include/openssl/idea.h ../../include/openssl/lhash.h |
120 | bf_buff.o: ../../include/openssl/md2.h ../../include/openssl/md4.h | ||
115 | bf_buff.o: ../../include/openssl/md5.h ../../include/openssl/mdc2.h | 121 | bf_buff.o: ../../include/openssl/md5.h ../../include/openssl/mdc2.h |
116 | bf_buff.o: ../../include/openssl/objects.h ../../include/openssl/opensslconf.h | 122 | bf_buff.o: ../../include/openssl/obj_mac.h ../../include/openssl/objects.h |
117 | bf_buff.o: ../../include/openssl/opensslv.h ../../include/openssl/rc2.h | 123 | bf_buff.o: ../../include/openssl/opensslconf.h ../../include/openssl/opensslv.h |
118 | bf_buff.o: ../../include/openssl/rc4.h ../../include/openssl/rc5.h | 124 | bf_buff.o: ../../include/openssl/rc2.h ../../include/openssl/rc4.h |
119 | bf_buff.o: ../../include/openssl/ripemd.h ../../include/openssl/rsa.h | 125 | bf_buff.o: ../../include/openssl/rc5.h ../../include/openssl/ripemd.h |
120 | bf_buff.o: ../../include/openssl/safestack.h ../../include/openssl/sha.h | 126 | bf_buff.o: ../../include/openssl/rsa.h ../../include/openssl/safestack.h |
121 | bf_buff.o: ../../include/openssl/stack.h ../cryptlib.h | 127 | bf_buff.o: ../../include/openssl/sha.h ../../include/openssl/stack.h |
128 | bf_buff.o: ../../include/openssl/symhacks.h ../cryptlib.h | ||
122 | bf_nbio.o: ../../include/openssl/asn1.h ../../include/openssl/bio.h | 129 | bf_nbio.o: ../../include/openssl/asn1.h ../../include/openssl/bio.h |
123 | bf_nbio.o: ../../include/openssl/blowfish.h ../../include/openssl/bn.h | 130 | bf_nbio.o: ../../include/openssl/blowfish.h ../../include/openssl/bn.h |
124 | bf_nbio.o: ../../include/openssl/buffer.h ../../include/openssl/cast.h | 131 | bf_nbio.o: ../../include/openssl/buffer.h ../../include/openssl/cast.h |
@@ -126,14 +133,16 @@ bf_nbio.o: ../../include/openssl/crypto.h ../../include/openssl/des.h | |||
126 | bf_nbio.o: ../../include/openssl/dh.h ../../include/openssl/dsa.h | 133 | bf_nbio.o: ../../include/openssl/dh.h ../../include/openssl/dsa.h |
127 | bf_nbio.o: ../../include/openssl/e_os.h ../../include/openssl/e_os2.h | 134 | bf_nbio.o: ../../include/openssl/e_os.h ../../include/openssl/e_os2.h |
128 | bf_nbio.o: ../../include/openssl/err.h ../../include/openssl/evp.h | 135 | bf_nbio.o: ../../include/openssl/err.h ../../include/openssl/evp.h |
129 | bf_nbio.o: ../../include/openssl/idea.h ../../include/openssl/md2.h | 136 | bf_nbio.o: ../../include/openssl/idea.h ../../include/openssl/lhash.h |
137 | bf_nbio.o: ../../include/openssl/md2.h ../../include/openssl/md4.h | ||
130 | bf_nbio.o: ../../include/openssl/md5.h ../../include/openssl/mdc2.h | 138 | bf_nbio.o: ../../include/openssl/md5.h ../../include/openssl/mdc2.h |
131 | bf_nbio.o: ../../include/openssl/objects.h ../../include/openssl/opensslconf.h | 139 | bf_nbio.o: ../../include/openssl/obj_mac.h ../../include/openssl/objects.h |
132 | bf_nbio.o: ../../include/openssl/opensslv.h ../../include/openssl/rand.h | 140 | bf_nbio.o: ../../include/openssl/opensslconf.h ../../include/openssl/opensslv.h |
133 | bf_nbio.o: ../../include/openssl/rc2.h ../../include/openssl/rc4.h | 141 | bf_nbio.o: ../../include/openssl/rand.h ../../include/openssl/rc2.h |
134 | bf_nbio.o: ../../include/openssl/rc5.h ../../include/openssl/ripemd.h | 142 | bf_nbio.o: ../../include/openssl/rc4.h ../../include/openssl/rc5.h |
135 | bf_nbio.o: ../../include/openssl/rsa.h ../../include/openssl/safestack.h | 143 | bf_nbio.o: ../../include/openssl/ripemd.h ../../include/openssl/rsa.h |
136 | bf_nbio.o: ../../include/openssl/sha.h ../../include/openssl/stack.h | 144 | bf_nbio.o: ../../include/openssl/safestack.h ../../include/openssl/sha.h |
145 | bf_nbio.o: ../../include/openssl/stack.h ../../include/openssl/symhacks.h | ||
137 | bf_nbio.o: ../cryptlib.h | 146 | bf_nbio.o: ../cryptlib.h |
138 | bf_null.o: ../../include/openssl/asn1.h ../../include/openssl/bio.h | 147 | bf_null.o: ../../include/openssl/asn1.h ../../include/openssl/bio.h |
139 | bf_null.o: ../../include/openssl/blowfish.h ../../include/openssl/bn.h | 148 | bf_null.o: ../../include/openssl/blowfish.h ../../include/openssl/bn.h |
@@ -142,79 +151,93 @@ bf_null.o: ../../include/openssl/crypto.h ../../include/openssl/des.h | |||
142 | bf_null.o: ../../include/openssl/dh.h ../../include/openssl/dsa.h | 151 | bf_null.o: ../../include/openssl/dh.h ../../include/openssl/dsa.h |
143 | bf_null.o: ../../include/openssl/e_os.h ../../include/openssl/e_os2.h | 152 | bf_null.o: ../../include/openssl/e_os.h ../../include/openssl/e_os2.h |
144 | bf_null.o: ../../include/openssl/err.h ../../include/openssl/evp.h | 153 | bf_null.o: ../../include/openssl/err.h ../../include/openssl/evp.h |
145 | bf_null.o: ../../include/openssl/idea.h ../../include/openssl/md2.h | 154 | bf_null.o: ../../include/openssl/idea.h ../../include/openssl/lhash.h |
155 | bf_null.o: ../../include/openssl/md2.h ../../include/openssl/md4.h | ||
146 | bf_null.o: ../../include/openssl/md5.h ../../include/openssl/mdc2.h | 156 | bf_null.o: ../../include/openssl/md5.h ../../include/openssl/mdc2.h |
147 | bf_null.o: ../../include/openssl/objects.h ../../include/openssl/opensslconf.h | 157 | bf_null.o: ../../include/openssl/obj_mac.h ../../include/openssl/objects.h |
148 | bf_null.o: ../../include/openssl/opensslv.h ../../include/openssl/rc2.h | 158 | bf_null.o: ../../include/openssl/opensslconf.h ../../include/openssl/opensslv.h |
149 | bf_null.o: ../../include/openssl/rc4.h ../../include/openssl/rc5.h | 159 | bf_null.o: ../../include/openssl/rc2.h ../../include/openssl/rc4.h |
150 | bf_null.o: ../../include/openssl/ripemd.h ../../include/openssl/rsa.h | 160 | bf_null.o: ../../include/openssl/rc5.h ../../include/openssl/ripemd.h |
151 | bf_null.o: ../../include/openssl/safestack.h ../../include/openssl/sha.h | 161 | bf_null.o: ../../include/openssl/rsa.h ../../include/openssl/safestack.h |
152 | bf_null.o: ../../include/openssl/stack.h ../cryptlib.h | 162 | bf_null.o: ../../include/openssl/sha.h ../../include/openssl/stack.h |
163 | bf_null.o: ../../include/openssl/symhacks.h ../cryptlib.h | ||
153 | bio_cb.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h | 164 | bio_cb.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h |
154 | bio_cb.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h | 165 | bio_cb.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h |
155 | bio_cb.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h | 166 | bio_cb.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h |
156 | bio_cb.o: ../../include/openssl/opensslconf.h ../../include/openssl/opensslv.h | 167 | bio_cb.o: ../../include/openssl/lhash.h ../../include/openssl/opensslconf.h |
157 | bio_cb.o: ../../include/openssl/safestack.h ../../include/openssl/stack.h | 168 | bio_cb.o: ../../include/openssl/opensslv.h ../../include/openssl/safestack.h |
169 | bio_cb.o: ../../include/openssl/stack.h ../../include/openssl/symhacks.h | ||
158 | bio_cb.o: ../cryptlib.h | 170 | bio_cb.o: ../cryptlib.h |
159 | bio_err.o: ../../include/openssl/bio.h ../../include/openssl/crypto.h | 171 | bio_err.o: ../../include/openssl/bio.h ../../include/openssl/crypto.h |
160 | bio_err.o: ../../include/openssl/err.h ../../include/openssl/opensslv.h | 172 | bio_err.o: ../../include/openssl/err.h ../../include/openssl/lhash.h |
161 | bio_err.o: ../../include/openssl/safestack.h ../../include/openssl/stack.h | 173 | bio_err.o: ../../include/openssl/opensslv.h ../../include/openssl/safestack.h |
174 | bio_err.o: ../../include/openssl/stack.h ../../include/openssl/symhacks.h | ||
162 | bio_lib.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h | 175 | bio_lib.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h |
163 | bio_lib.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h | 176 | bio_lib.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h |
164 | bio_lib.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h | 177 | bio_lib.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h |
165 | bio_lib.o: ../../include/openssl/opensslconf.h ../../include/openssl/opensslv.h | 178 | bio_lib.o: ../../include/openssl/lhash.h ../../include/openssl/opensslconf.h |
166 | bio_lib.o: ../../include/openssl/safestack.h ../../include/openssl/stack.h | 179 | bio_lib.o: ../../include/openssl/opensslv.h ../../include/openssl/safestack.h |
180 | bio_lib.o: ../../include/openssl/stack.h ../../include/openssl/symhacks.h | ||
167 | bio_lib.o: ../cryptlib.h | 181 | bio_lib.o: ../cryptlib.h |
168 | bss_acpt.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h | 182 | bss_acpt.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h |
169 | bss_acpt.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h | 183 | bss_acpt.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h |
170 | bss_acpt.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h | 184 | bss_acpt.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h |
171 | bss_acpt.o: ../../include/openssl/opensslconf.h | 185 | bss_acpt.o: ../../include/openssl/lhash.h ../../include/openssl/opensslconf.h |
172 | bss_acpt.o: ../../include/openssl/opensslv.h ../../include/openssl/safestack.h | 186 | bss_acpt.o: ../../include/openssl/opensslv.h ../../include/openssl/safestack.h |
173 | bss_acpt.o: ../../include/openssl/stack.h ../cryptlib.h | 187 | bss_acpt.o: ../../include/openssl/stack.h ../../include/openssl/symhacks.h |
188 | bss_acpt.o: ../cryptlib.h | ||
174 | bss_bio.o: ../../include/openssl/bio.h ../../include/openssl/crypto.h | 189 | bss_bio.o: ../../include/openssl/bio.h ../../include/openssl/crypto.h |
175 | bss_bio.o: ../../include/openssl/e_os.h ../../include/openssl/e_os2.h | 190 | bss_bio.o: ../../include/openssl/e_os.h ../../include/openssl/e_os2.h |
176 | bss_bio.o: ../../include/openssl/err.h ../../include/openssl/opensslconf.h | 191 | bss_bio.o: ../../include/openssl/err.h ../../include/openssl/lhash.h |
177 | bss_bio.o: ../../include/openssl/opensslv.h ../../include/openssl/safestack.h | 192 | bss_bio.o: ../../include/openssl/opensslconf.h ../../include/openssl/opensslv.h |
178 | bss_bio.o: ../../include/openssl/stack.h | 193 | bss_bio.o: ../../include/openssl/safestack.h ../../include/openssl/stack.h |
194 | bss_bio.o: ../../include/openssl/symhacks.h | ||
179 | bss_conn.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h | 195 | bss_conn.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h |
180 | bss_conn.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h | 196 | bss_conn.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h |
181 | bss_conn.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h | 197 | bss_conn.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h |
182 | bss_conn.o: ../../include/openssl/opensslconf.h | 198 | bss_conn.o: ../../include/openssl/lhash.h ../../include/openssl/opensslconf.h |
183 | bss_conn.o: ../../include/openssl/opensslv.h ../../include/openssl/safestack.h | 199 | bss_conn.o: ../../include/openssl/opensslv.h ../../include/openssl/safestack.h |
184 | bss_conn.o: ../../include/openssl/stack.h ../cryptlib.h | 200 | bss_conn.o: ../../include/openssl/stack.h ../../include/openssl/symhacks.h |
201 | bss_conn.o: ../cryptlib.h | ||
185 | bss_fd.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h | 202 | bss_fd.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h |
186 | bss_fd.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h | 203 | bss_fd.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h |
187 | bss_fd.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h | 204 | bss_fd.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h |
188 | bss_fd.o: ../../include/openssl/opensslconf.h ../../include/openssl/opensslv.h | 205 | bss_fd.o: ../../include/openssl/lhash.h ../../include/openssl/opensslconf.h |
189 | bss_fd.o: ../../include/openssl/safestack.h ../../include/openssl/stack.h | 206 | bss_fd.o: ../../include/openssl/opensslv.h ../../include/openssl/safestack.h |
207 | bss_fd.o: ../../include/openssl/stack.h ../../include/openssl/symhacks.h | ||
190 | bss_fd.o: ../cryptlib.h bss_sock.c | 208 | bss_fd.o: ../cryptlib.h bss_sock.c |
191 | bss_file.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h | 209 | bss_file.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h |
192 | bss_file.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h | 210 | bss_file.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h |
193 | bss_file.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h | 211 | bss_file.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h |
194 | bss_file.o: ../../include/openssl/opensslconf.h | 212 | bss_file.o: ../../include/openssl/lhash.h ../../include/openssl/opensslconf.h |
195 | bss_file.o: ../../include/openssl/opensslv.h ../../include/openssl/safestack.h | 213 | bss_file.o: ../../include/openssl/opensslv.h ../../include/openssl/safestack.h |
196 | bss_file.o: ../../include/openssl/stack.h ../cryptlib.h | 214 | bss_file.o: ../../include/openssl/stack.h ../../include/openssl/symhacks.h |
215 | bss_file.o: ../cryptlib.h | ||
197 | bss_log.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h | 216 | bss_log.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h |
198 | bss_log.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h | 217 | bss_log.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h |
199 | bss_log.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h | 218 | bss_log.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h |
200 | bss_log.o: ../../include/openssl/opensslconf.h ../../include/openssl/opensslv.h | 219 | bss_log.o: ../../include/openssl/lhash.h ../../include/openssl/opensslconf.h |
201 | bss_log.o: ../../include/openssl/safestack.h ../../include/openssl/stack.h | 220 | bss_log.o: ../../include/openssl/opensslv.h ../../include/openssl/safestack.h |
221 | bss_log.o: ../../include/openssl/stack.h ../../include/openssl/symhacks.h | ||
202 | bss_log.o: ../cryptlib.h | 222 | bss_log.o: ../cryptlib.h |
203 | bss_mem.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h | 223 | bss_mem.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h |
204 | bss_mem.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h | 224 | bss_mem.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h |
205 | bss_mem.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h | 225 | bss_mem.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h |
206 | bss_mem.o: ../../include/openssl/opensslconf.h ../../include/openssl/opensslv.h | 226 | bss_mem.o: ../../include/openssl/lhash.h ../../include/openssl/opensslconf.h |
207 | bss_mem.o: ../../include/openssl/safestack.h ../../include/openssl/stack.h | 227 | bss_mem.o: ../../include/openssl/opensslv.h ../../include/openssl/safestack.h |
228 | bss_mem.o: ../../include/openssl/stack.h ../../include/openssl/symhacks.h | ||
208 | bss_mem.o: ../cryptlib.h | 229 | bss_mem.o: ../cryptlib.h |
209 | bss_null.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h | 230 | bss_null.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h |
210 | bss_null.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h | 231 | bss_null.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h |
211 | bss_null.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h | 232 | bss_null.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h |
212 | bss_null.o: ../../include/openssl/opensslconf.h | 233 | bss_null.o: ../../include/openssl/lhash.h ../../include/openssl/opensslconf.h |
213 | bss_null.o: ../../include/openssl/opensslv.h ../../include/openssl/safestack.h | 234 | bss_null.o: ../../include/openssl/opensslv.h ../../include/openssl/safestack.h |
214 | bss_null.o: ../../include/openssl/stack.h ../cryptlib.h | 235 | bss_null.o: ../../include/openssl/stack.h ../../include/openssl/symhacks.h |
236 | bss_null.o: ../cryptlib.h | ||
215 | bss_sock.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h | 237 | bss_sock.o: ../../include/openssl/bio.h ../../include/openssl/buffer.h |
216 | bss_sock.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h | 238 | bss_sock.o: ../../include/openssl/crypto.h ../../include/openssl/e_os.h |
217 | bss_sock.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h | 239 | bss_sock.o: ../../include/openssl/e_os2.h ../../include/openssl/err.h |
218 | bss_sock.o: ../../include/openssl/opensslconf.h | 240 | bss_sock.o: ../../include/openssl/lhash.h ../../include/openssl/opensslconf.h |
219 | bss_sock.o: ../../include/openssl/opensslv.h ../../include/openssl/safestack.h | 241 | bss_sock.o: ../../include/openssl/opensslv.h ../../include/openssl/safestack.h |
220 | bss_sock.o: ../../include/openssl/stack.h ../cryptlib.h | 242 | bss_sock.o: ../../include/openssl/stack.h ../../include/openssl/symhacks.h |
243 | bss_sock.o: ../cryptlib.h | ||
diff --git a/src/lib/libcrypto/bio/b_dump.c b/src/lib/libcrypto/bio/b_dump.c index f5aeb237f5..8397cfab6a 100644 --- a/src/lib/libcrypto/bio/b_dump.c +++ b/src/lib/libcrypto/bio/b_dump.c | |||
@@ -66,63 +66,87 @@ | |||
66 | 66 | ||
67 | #define TRUNCATE | 67 | #define TRUNCATE |
68 | #define DUMP_WIDTH 16 | 68 | #define DUMP_WIDTH 16 |
69 | #define DUMP_WIDTH_LESS_INDENT(i) (DUMP_WIDTH-((i-(i>6?6:i)+3)/4)) | ||
69 | 70 | ||
70 | int BIO_dump(BIO *bio, const char *s, int len) | 71 | int BIO_dump(BIO *bio, const char *s, int len) |
71 | { | 72 | { |
72 | int ret=0; | 73 | return BIO_dump_indent(bio, s, len, 0); |
73 | char buf[160+1],tmp[20]; | 74 | } |
74 | int i,j,rows,trunc; | ||
75 | unsigned char ch; | ||
76 | |||
77 | trunc=0; | ||
78 | 75 | ||
76 | int BIO_dump_indent(BIO *bio, const char *s, int len, int indent) | ||
77 | { | ||
78 | int ret=0; | ||
79 | char buf[288+1],tmp[20],str[128+1]; | ||
80 | int i,j,rows,trunc; | ||
81 | unsigned char ch; | ||
82 | int dump_width; | ||
83 | |||
84 | trunc=0; | ||
85 | |||
79 | #ifdef TRUNCATE | 86 | #ifdef TRUNCATE |
80 | for(; (len > 0) && ((s[len-1] == ' ') || (s[len-1] == '\0')); len--) | 87 | for(; (len > 0) && ((s[len-1] == ' ') || (s[len-1] == '\0')); len--) |
81 | trunc++; | 88 | trunc++; |
82 | #endif | 89 | #endif |
83 | 90 | ||
84 | rows=(len/DUMP_WIDTH); | 91 | if (indent < 0) |
85 | if ((rows*DUMP_WIDTH)<len) | 92 | indent = 0; |
86 | rows++; | 93 | if (indent) |
87 | for(i=0;i<rows;i++) { | 94 | { |
88 | buf[0]='\0'; /* start with empty string */ | 95 | if (indent > 128) indent=128; |
89 | sprintf(tmp,"%04x - ",i*DUMP_WIDTH); | 96 | memset(str,' ',indent); |
90 | strcpy(buf,tmp); | 97 | } |
91 | for(j=0;j<DUMP_WIDTH;j++) { | 98 | str[indent]='\0'; |
92 | if (((i*DUMP_WIDTH)+j)>=len) { | 99 | |
93 | strcat(buf," "); | 100 | dump_width=DUMP_WIDTH_LESS_INDENT(indent); |
94 | } else { | 101 | rows=(len/dump_width); |
95 | ch=((unsigned char)*(s+i*DUMP_WIDTH+j)) & 0xff; | 102 | if ((rows*dump_width)<len) |
96 | sprintf(tmp,"%02x%c",ch,j==7?'-':' '); | 103 | rows++; |
97 | strcat(buf,tmp); | 104 | for(i=0;i<rows;i++) |
98 | } | 105 | { |
99 | } | 106 | buf[0]='\0'; /* start with empty string */ |
100 | strcat(buf," "); | 107 | strcpy(buf,str); |
101 | for(j=0;j<DUMP_WIDTH;j++) { | 108 | sprintf(tmp,"%04x - ",i*dump_width); |
102 | if (((i*DUMP_WIDTH)+j)>=len) | 109 | strcat(buf,tmp); |
103 | break; | 110 | for(j=0;j<dump_width;j++) |
104 | ch=((unsigned char)*(s+i*DUMP_WIDTH+j)) & 0xff; | 111 | { |
112 | if (((i*dump_width)+j)>=len) | ||
113 | { | ||
114 | strcat(buf," "); | ||
115 | } | ||
116 | else | ||
117 | { | ||
118 | ch=((unsigned char)*(s+i*dump_width+j)) & 0xff; | ||
119 | sprintf(tmp,"%02x%c",ch,j==7?'-':' '); | ||
120 | strcat(buf,tmp); | ||
121 | } | ||
122 | } | ||
123 | strcat(buf," "); | ||
124 | for(j=0;j<dump_width;j++) | ||
125 | { | ||
126 | if (((i*dump_width)+j)>=len) | ||
127 | break; | ||
128 | ch=((unsigned char)*(s+i*dump_width+j)) & 0xff; | ||
105 | #ifndef CHARSET_EBCDIC | 129 | #ifndef CHARSET_EBCDIC |
106 | sprintf(tmp,"%c",((ch>=' ')&&(ch<='~'))?ch:'.'); | 130 | sprintf(tmp,"%c",((ch>=' ')&&(ch<='~'))?ch:'.'); |
107 | #else | 131 | #else |
108 | sprintf(tmp,"%c",((ch>=os_toascii[' '])&&(ch<=os_toascii['~'])) | 132 | sprintf(tmp,"%c",((ch>=os_toascii[' '])&&(ch<=os_toascii['~'])) |
109 | ? os_toebcdic[ch] | 133 | ? os_toebcdic[ch] |
110 | : '.'); | 134 | : '.'); |
111 | #endif | 135 | #endif |
112 | strcat(buf,tmp); | 136 | strcat(buf,tmp); |
113 | } | 137 | } |
114 | strcat(buf,"\n"); | 138 | strcat(buf,"\n"); |
115 | /* if this is the last call then update the ddt_dump thing so that | 139 | /* if this is the last call then update the ddt_dump thing so that |
116 | * we will move the selection point in the debug window | 140 | * we will move the selection point in the debug window |
117 | */ | 141 | */ |
118 | ret+=BIO_write(bio,(char *)buf,strlen(buf)); | 142 | ret+=BIO_write(bio,(char *)buf,strlen(buf)); |
119 | } | 143 | } |
120 | #ifdef TRUNCATE | 144 | #ifdef TRUNCATE |
121 | if (trunc > 0) { | 145 | if (trunc > 0) |
122 | sprintf(buf,"%04x - <SPACES/NULS>\n",len+trunc); | 146 | { |
123 | ret+=BIO_write(bio,(char *)buf,strlen(buf)); | 147 | sprintf(buf,"%s%04x - <SPACES/NULS>\n",str,len+trunc); |
124 | } | 148 | ret+=BIO_write(bio,(char *)buf,strlen(buf)); |
149 | } | ||
125 | #endif | 150 | #endif |
126 | return(ret); | 151 | return(ret); |
127 | } | 152 | } |
128 | |||
diff --git a/src/lib/libcrypto/bio/b_print.c b/src/lib/libcrypto/bio/b_print.c index b11b501512..a62f551635 100644 --- a/src/lib/libcrypto/bio/b_print.c +++ b/src/lib/libcrypto/bio/b_print.c | |||
@@ -61,7 +61,6 @@ | |||
61 | */ | 61 | */ |
62 | 62 | ||
63 | #include <stdio.h> | 63 | #include <stdio.h> |
64 | #include <stdarg.h> | ||
65 | #include <string.h> | 64 | #include <string.h> |
66 | #include <ctype.h> | 65 | #include <ctype.h> |
67 | #include <assert.h> | 66 | #include <assert.h> |
@@ -78,48 +77,7 @@ | |||
78 | # endif | 77 | # endif |
79 | #endif | 78 | #endif |
80 | 79 | ||
81 | static void dopr (char *buffer, size_t maxlen, size_t *retlen, | 80 | /***************************************************************************/ |
82 | const char *format, va_list args); | ||
83 | #ifdef USE_ALLOCATING_PRINT | ||
84 | static void doapr (char **buffer, size_t *retlen, | ||
85 | const char *format, va_list args); | ||
86 | #endif | ||
87 | |||
88 | int BIO_printf (BIO *bio, ...) | ||
89 | { | ||
90 | va_list args; | ||
91 | char *format; | ||
92 | int ret; | ||
93 | size_t retlen; | ||
94 | #ifdef USE_ALLOCATING_PRINT | ||
95 | char *hugebuf; | ||
96 | #else | ||
97 | MS_STATIC char hugebuf[1024*2]; /* 10k in one chunk is the limit */ | ||
98 | #endif | ||
99 | |||
100 | va_start(args, bio); | ||
101 | format=va_arg(args, char *); | ||
102 | |||
103 | #ifndef USE_ALLOCATING_PRINT | ||
104 | hugebuf[0]='\0'; | ||
105 | dopr(hugebuf, sizeof(hugebuf), &retlen, format, args); | ||
106 | #else | ||
107 | hugebuf = NULL; | ||
108 | CRYPTO_push_info("doapr()"); | ||
109 | doapr(&hugebuf, &retlen, format, args); | ||
110 | if (hugebuf) | ||
111 | { | ||
112 | #endif | ||
113 | ret=BIO_write(bio, hugebuf, (int)retlen); | ||
114 | |||
115 | #ifdef USE_ALLOCATING_PRINT | ||
116 | Free(hugebuf); | ||
117 | } | ||
118 | CRYPTO_pop_info(); | ||
119 | #endif | ||
120 | va_end(args); | ||
121 | return(ret); | ||
122 | } | ||
123 | 81 | ||
124 | /* | 82 | /* |
125 | * Copyright Patrick Powell 1995 | 83 | * Copyright Patrick Powell 1995 |
@@ -140,6 +98,7 @@ int BIO_printf (BIO *bio, ...) | |||
140 | * o Andrew Tridgell <tridge@samba.org> (1998, for Samba) | 98 | * o Andrew Tridgell <tridge@samba.org> (1998, for Samba) |
141 | * o Luke Mewburn <lukem@netbsd.org> (1999, for LukemFTP) | 99 | * o Luke Mewburn <lukem@netbsd.org> (1999, for LukemFTP) |
142 | * o Ralf S. Engelschall <rse@engelschall.com> (1999, for Pth) | 100 | * o Ralf S. Engelschall <rse@engelschall.com> (1999, for Pth) |
101 | * o ... (for OpenSSL) | ||
143 | */ | 102 | */ |
144 | 103 | ||
145 | #if HAVE_LONG_DOUBLE | 104 | #if HAVE_LONG_DOUBLE |
@@ -154,25 +113,15 @@ int BIO_printf (BIO *bio, ...) | |||
154 | #define LLONG long | 113 | #define LLONG long |
155 | #endif | 114 | #endif |
156 | 115 | ||
157 | static void fmtstr (void (*)(char **, size_t *, size_t *, int), | 116 | static void fmtstr (char **, char **, size_t *, size_t *, |
158 | char **, size_t *, size_t *, const char *, int, int, | 117 | const char *, int, int, int); |
159 | int); | 118 | static void fmtint (char **, char **, size_t *, size_t *, |
160 | static void fmtint (void (*)(char **, size_t *, size_t *, int), | 119 | LLONG, int, int, int, int); |
161 | char **, size_t *, size_t *, LLONG, int, int, int, int); | 120 | static void fmtfp (char **, char **, size_t *, size_t *, |
162 | static void fmtfp (void (*)(char **, size_t *, size_t *, int), | 121 | LDOUBLE, int, int, int); |
163 | char **, size_t *, size_t *, LDOUBLE, int, int, int); | 122 | static void doapr_outch (char **, char **, size_t *, size_t *, int); |
164 | #ifndef USE_ALLOCATING_PRINT | 123 | static void _dopr(char **sbuffer, char **buffer, |
165 | static int dopr_isbig (size_t, size_t); | 124 | size_t *maxlen, size_t *retlen, int *truncated, |
166 | static int dopr_copy (size_t); | ||
167 | static void dopr_outch (char **, size_t *, size_t *, int); | ||
168 | #else | ||
169 | static int doapr_isbig (size_t, size_t); | ||
170 | static int doapr_copy (size_t); | ||
171 | static void doapr_outch (char **, size_t *, size_t *, int); | ||
172 | #endif | ||
173 | static void _dopr(void (*)(char **, size_t *, size_t *, int), | ||
174 | int (*)(size_t, size_t), int (*)(size_t), | ||
175 | char **buffer, size_t *maxlen, size_t *retlen, | ||
176 | const char *format, va_list args); | 125 | const char *format, va_list args); |
177 | 126 | ||
178 | /* format read states */ | 127 | /* format read states */ |
@@ -204,41 +153,13 @@ static void _dopr(void (*)(char **, size_t *, size_t *, int), | |||
204 | #define char_to_int(p) (p - '0') | 153 | #define char_to_int(p) (p - '0') |
205 | #define MAX(p,q) ((p >= q) ? p : q) | 154 | #define MAX(p,q) ((p >= q) ? p : q) |
206 | 155 | ||
207 | #ifndef USE_ALLOCATING_PRINT | ||
208 | static void | ||
209 | dopr( | ||
210 | char *buffer, | ||
211 | size_t maxlen, | ||
212 | size_t *retlen, | ||
213 | const char *format, | ||
214 | va_list args) | ||
215 | { | ||
216 | _dopr(dopr_outch, dopr_isbig, dopr_copy, | ||
217 | &buffer, &maxlen, retlen, format, args); | ||
218 | } | ||
219 | |||
220 | #else | ||
221 | static void | ||
222 | doapr( | ||
223 | char **buffer, | ||
224 | size_t *retlen, | ||
225 | const char *format, | ||
226 | va_list args) | ||
227 | { | ||
228 | size_t dummy_maxlen = 0; | ||
229 | _dopr(doapr_outch, doapr_isbig, doapr_copy, | ||
230 | buffer, &dummy_maxlen, retlen, format, args); | ||
231 | } | ||
232 | #endif | ||
233 | |||
234 | static void | 156 | static void |
235 | _dopr( | 157 | _dopr( |
236 | void (*outch_fn)(char **, size_t *, size_t *, int), | 158 | char **sbuffer, |
237 | int (*isbig_fn)(size_t, size_t), | ||
238 | int (*copy_fn)(size_t), | ||
239 | char **buffer, | 159 | char **buffer, |
240 | size_t *maxlen, | 160 | size_t *maxlen, |
241 | size_t *retlen, | 161 | size_t *retlen, |
162 | int *truncated, | ||
242 | const char *format, | 163 | const char *format, |
243 | va_list args) | 164 | va_list args) |
244 | { | 165 | { |
@@ -259,7 +180,7 @@ _dopr( | |||
259 | ch = *format++; | 180 | ch = *format++; |
260 | 181 | ||
261 | while (state != DP_S_DONE) { | 182 | while (state != DP_S_DONE) { |
262 | if ((ch == '\0') || (*isbig_fn)(currlen, *maxlen)) | 183 | if (ch == '\0' || (buffer == NULL && currlen >= *maxlen)) |
263 | state = DP_S_DONE; | 184 | state = DP_S_DONE; |
264 | 185 | ||
265 | switch (state) { | 186 | switch (state) { |
@@ -267,7 +188,7 @@ _dopr( | |||
267 | if (ch == '%') | 188 | if (ch == '%') |
268 | state = DP_S_FLAGS; | 189 | state = DP_S_FLAGS; |
269 | else | 190 | else |
270 | (*outch_fn)(buffer, &currlen, maxlen, ch); | 191 | doapr_outch(sbuffer,buffer, &currlen, maxlen, ch); |
271 | ch = *format++; | 192 | ch = *format++; |
272 | break; | 193 | break; |
273 | case DP_S_FLAGS: | 194 | case DP_S_FLAGS: |
@@ -373,8 +294,8 @@ _dopr( | |||
373 | value = va_arg(args, int); | 294 | value = va_arg(args, int); |
374 | break; | 295 | break; |
375 | } | 296 | } |
376 | fmtint(outch_fn, buffer, &currlen, maxlen, | 297 | fmtint(sbuffer, buffer, &currlen, maxlen, |
377 | value, 10, min, max, flags); | 298 | value, 10, min, max, flags); |
378 | break; | 299 | break; |
379 | case 'X': | 300 | case 'X': |
380 | flags |= DP_F_UP; | 301 | flags |= DP_F_UP; |
@@ -399,7 +320,7 @@ _dopr( | |||
399 | unsigned int); | 320 | unsigned int); |
400 | break; | 321 | break; |
401 | } | 322 | } |
402 | fmtint(outch_fn, buffer, &currlen, maxlen, value, | 323 | fmtint(sbuffer, buffer, &currlen, maxlen, value, |
403 | ch == 'o' ? 8 : (ch == 'u' ? 10 : 16), | 324 | ch == 'o' ? 8 : (ch == 'u' ? 10 : 16), |
404 | min, max, flags); | 325 | min, max, flags); |
405 | break; | 326 | break; |
@@ -408,8 +329,8 @@ _dopr( | |||
408 | fvalue = va_arg(args, LDOUBLE); | 329 | fvalue = va_arg(args, LDOUBLE); |
409 | else | 330 | else |
410 | fvalue = va_arg(args, double); | 331 | fvalue = va_arg(args, double); |
411 | fmtfp(outch_fn, buffer, &currlen, maxlen, | 332 | fmtfp(sbuffer, buffer, &currlen, maxlen, |
412 | fvalue, min, max, flags); | 333 | fvalue, min, max, flags); |
413 | break; | 334 | break; |
414 | case 'E': | 335 | case 'E': |
415 | flags |= DP_F_UP; | 336 | flags |= DP_F_UP; |
@@ -428,19 +349,23 @@ _dopr( | |||
428 | fvalue = va_arg(args, double); | 349 | fvalue = va_arg(args, double); |
429 | break; | 350 | break; |
430 | case 'c': | 351 | case 'c': |
431 | (*outch_fn)(buffer, &currlen, maxlen, | 352 | doapr_outch(sbuffer, buffer, &currlen, maxlen, |
432 | va_arg(args, int)); | 353 | va_arg(args, int)); |
433 | break; | 354 | break; |
434 | case 's': | 355 | case 's': |
435 | strvalue = va_arg(args, char *); | 356 | strvalue = va_arg(args, char *); |
436 | if (max < 0) | 357 | if (max < 0) { |
437 | max = (*copy_fn)(*maxlen); | 358 | if (buffer) |
438 | fmtstr(outch_fn, buffer, &currlen, maxlen, strvalue, | 359 | max = INT_MAX; |
439 | flags, min, max); | 360 | else |
361 | max = *maxlen; | ||
362 | } | ||
363 | fmtstr(sbuffer, buffer, &currlen, maxlen, strvalue, | ||
364 | flags, min, max); | ||
440 | break; | 365 | break; |
441 | case 'p': | 366 | case 'p': |
442 | value = (long)va_arg(args, void *); | 367 | value = (long)va_arg(args, void *); |
443 | fmtint(outch_fn, buffer, &currlen, maxlen, | 368 | fmtint(sbuffer, buffer, &currlen, maxlen, |
444 | value, 16, min, max, flags); | 369 | value, 16, min, max, flags); |
445 | break; | 370 | break; |
446 | case 'n': /* XXX */ | 371 | case 'n': /* XXX */ |
@@ -463,7 +388,7 @@ _dopr( | |||
463 | } | 388 | } |
464 | break; | 389 | break; |
465 | case '%': | 390 | case '%': |
466 | (*outch_fn)(buffer, &currlen, maxlen, ch); | 391 | doapr_outch(sbuffer, buffer, &currlen, maxlen, ch); |
467 | break; | 392 | break; |
468 | case 'w': | 393 | case 'w': |
469 | /* not supported yet, treat as next char */ | 394 | /* not supported yet, treat as next char */ |
@@ -484,16 +409,17 @@ _dopr( | |||
484 | break; | 409 | break; |
485 | } | 410 | } |
486 | } | 411 | } |
487 | if (currlen >= *maxlen - 1) | 412 | *truncated = (currlen > *maxlen - 1); |
413 | if (*truncated) | ||
488 | currlen = *maxlen - 1; | 414 | currlen = *maxlen - 1; |
489 | (*buffer)[currlen] = '\0'; | 415 | doapr_outch(sbuffer, buffer, &currlen, maxlen, '\0'); |
490 | *retlen = currlen; | 416 | *retlen = currlen - 1; |
491 | return; | 417 | return; |
492 | } | 418 | } |
493 | 419 | ||
494 | static void | 420 | static void |
495 | fmtstr( | 421 | fmtstr( |
496 | void (*outch_fn)(char **, size_t *, size_t *, int), | 422 | char **sbuffer, |
497 | char **buffer, | 423 | char **buffer, |
498 | size_t *currlen, | 424 | size_t *currlen, |
499 | size_t *maxlen, | 425 | size_t *maxlen, |
@@ -516,16 +442,16 @@ fmtstr( | |||
516 | padlen = -padlen; | 442 | padlen = -padlen; |
517 | 443 | ||
518 | while ((padlen > 0) && (cnt < max)) { | 444 | while ((padlen > 0) && (cnt < max)) { |
519 | (*outch_fn)(buffer, currlen, maxlen, ' '); | 445 | doapr_outch(sbuffer, buffer, currlen, maxlen, ' '); |
520 | --padlen; | 446 | --padlen; |
521 | ++cnt; | 447 | ++cnt; |
522 | } | 448 | } |
523 | while (*value && (cnt < max)) { | 449 | while (*value && (cnt < max)) { |
524 | (*outch_fn)(buffer, currlen, maxlen, *value++); | 450 | doapr_outch(sbuffer, buffer, currlen, maxlen, *value++); |
525 | ++cnt; | 451 | ++cnt; |
526 | } | 452 | } |
527 | while ((padlen < 0) && (cnt < max)) { | 453 | while ((padlen < 0) && (cnt < max)) { |
528 | (*outch_fn)(buffer, currlen, maxlen, ' '); | 454 | doapr_outch(sbuffer, buffer, currlen, maxlen, ' '); |
529 | ++padlen; | 455 | ++padlen; |
530 | ++cnt; | 456 | ++cnt; |
531 | } | 457 | } |
@@ -533,7 +459,7 @@ fmtstr( | |||
533 | 459 | ||
534 | static void | 460 | static void |
535 | fmtint( | 461 | fmtint( |
536 | void (*outch_fn)(char **, size_t *, size_t *, int), | 462 | char **sbuffer, |
537 | char **buffer, | 463 | char **buffer, |
538 | size_t *currlen, | 464 | size_t *currlen, |
539 | size_t *maxlen, | 465 | size_t *maxlen, |
@@ -590,28 +516,28 @@ fmtint( | |||
590 | 516 | ||
591 | /* spaces */ | 517 | /* spaces */ |
592 | while (spadlen > 0) { | 518 | while (spadlen > 0) { |
593 | (*outch_fn)(buffer, currlen, maxlen, ' '); | 519 | doapr_outch(sbuffer, buffer, currlen, maxlen, ' '); |
594 | --spadlen; | 520 | --spadlen; |
595 | } | 521 | } |
596 | 522 | ||
597 | /* sign */ | 523 | /* sign */ |
598 | if (signvalue) | 524 | if (signvalue) |
599 | (*outch_fn)(buffer, currlen, maxlen, signvalue); | 525 | doapr_outch(sbuffer, buffer, currlen, maxlen, signvalue); |
600 | 526 | ||
601 | /* zeros */ | 527 | /* zeros */ |
602 | if (zpadlen > 0) { | 528 | if (zpadlen > 0) { |
603 | while (zpadlen > 0) { | 529 | while (zpadlen > 0) { |
604 | (*outch_fn)(buffer, currlen, maxlen, '0'); | 530 | doapr_outch(sbuffer, buffer, currlen, maxlen, '0'); |
605 | --zpadlen; | 531 | --zpadlen; |
606 | } | 532 | } |
607 | } | 533 | } |
608 | /* digits */ | 534 | /* digits */ |
609 | while (place > 0) | 535 | while (place > 0) |
610 | (*outch_fn)(buffer, currlen, maxlen, convert[--place]); | 536 | doapr_outch(sbuffer, buffer, currlen, maxlen, convert[--place]); |
611 | 537 | ||
612 | /* left justified spaces */ | 538 | /* left justified spaces */ |
613 | while (spadlen < 0) { | 539 | while (spadlen < 0) { |
614 | (*outch_fn)(buffer, currlen, maxlen, ' '); | 540 | doapr_outch(sbuffer, buffer, currlen, maxlen, ' '); |
615 | ++spadlen; | 541 | ++spadlen; |
616 | } | 542 | } |
617 | return; | 543 | return; |
@@ -650,7 +576,7 @@ round(LDOUBLE value) | |||
650 | 576 | ||
651 | static void | 577 | static void |
652 | fmtfp( | 578 | fmtfp( |
653 | void (*outch_fn)(char **, size_t *, size_t *, int), | 579 | char **sbuffer, |
654 | char **buffer, | 580 | char **buffer, |
655 | size_t *currlen, | 581 | size_t *currlen, |
656 | size_t *maxlen, | 582 | size_t *maxlen, |
@@ -731,114 +657,158 @@ fmtfp( | |||
731 | 657 | ||
732 | if ((flags & DP_F_ZERO) && (padlen > 0)) { | 658 | if ((flags & DP_F_ZERO) && (padlen > 0)) { |
733 | if (signvalue) { | 659 | if (signvalue) { |
734 | (*outch_fn)(buffer, currlen, maxlen, signvalue); | 660 | doapr_outch(sbuffer, buffer, currlen, maxlen, signvalue); |
735 | --padlen; | 661 | --padlen; |
736 | signvalue = 0; | 662 | signvalue = 0; |
737 | } | 663 | } |
738 | while (padlen > 0) { | 664 | while (padlen > 0) { |
739 | (*outch_fn)(buffer, currlen, maxlen, '0'); | 665 | doapr_outch(sbuffer, buffer, currlen, maxlen, '0'); |
740 | --padlen; | 666 | --padlen; |
741 | } | 667 | } |
742 | } | 668 | } |
743 | while (padlen > 0) { | 669 | while (padlen > 0) { |
744 | (*outch_fn)(buffer, currlen, maxlen, ' '); | 670 | doapr_outch(sbuffer, buffer, currlen, maxlen, ' '); |
745 | --padlen; | 671 | --padlen; |
746 | } | 672 | } |
747 | if (signvalue) | 673 | if (signvalue) |
748 | (*outch_fn)(buffer, currlen, maxlen, signvalue); | 674 | doapr_outch(sbuffer, buffer, currlen, maxlen, signvalue); |
749 | 675 | ||
750 | while (iplace > 0) | 676 | while (iplace > 0) |
751 | (*outch_fn)(buffer, currlen, maxlen, iconvert[--iplace]); | 677 | doapr_outch(sbuffer, buffer, currlen, maxlen, iconvert[--iplace]); |
752 | 678 | ||
753 | /* | 679 | /* |
754 | * Decimal point. This should probably use locale to find the correct | 680 | * Decimal point. This should probably use locale to find the correct |
755 | * char to print out. | 681 | * char to print out. |
756 | */ | 682 | */ |
757 | if (max > 0) { | 683 | if (max > 0) { |
758 | (*outch_fn)(buffer, currlen, maxlen, '.'); | 684 | doapr_outch(sbuffer, buffer, currlen, maxlen, '.'); |
759 | 685 | ||
760 | while (fplace > 0) | 686 | while (fplace > 0) |
761 | (*outch_fn)(buffer, currlen, maxlen, fconvert[--fplace]); | 687 | doapr_outch(sbuffer, buffer, currlen, maxlen, fconvert[--fplace]); |
762 | } | 688 | } |
763 | while (zpadlen > 0) { | 689 | while (zpadlen > 0) { |
764 | (*outch_fn)(buffer, currlen, maxlen, '0'); | 690 | doapr_outch(sbuffer, buffer, currlen, maxlen, '0'); |
765 | --zpadlen; | 691 | --zpadlen; |
766 | } | 692 | } |
767 | 693 | ||
768 | while (padlen < 0) { | 694 | while (padlen < 0) { |
769 | (*outch_fn)(buffer, currlen, maxlen, ' '); | 695 | doapr_outch(sbuffer, buffer, currlen, maxlen, ' '); |
770 | ++padlen; | 696 | ++padlen; |
771 | } | 697 | } |
772 | } | 698 | } |
773 | 699 | ||
774 | static int | ||
775 | dopr_copy( | ||
776 | size_t len) | ||
777 | { | ||
778 | return len; | ||
779 | } | ||
780 | |||
781 | #ifdef USE_ALLOCATING_PRINT | ||
782 | static int | ||
783 | doapr_copy( | ||
784 | size_t len) | ||
785 | { | ||
786 | /* Return as high an integer as possible */ | ||
787 | return INT_MAX; | ||
788 | } | ||
789 | #endif | ||
790 | |||
791 | static int | ||
792 | dopr_isbig( | ||
793 | size_t currlen, | ||
794 | size_t maxlen) | ||
795 | { | ||
796 | return currlen > maxlen; | ||
797 | } | ||
798 | |||
799 | #ifdef USE_ALLOCATING_PRINT | ||
800 | static int | ||
801 | doapr_isbig( | ||
802 | size_t currlen, | ||
803 | size_t maxlen) | ||
804 | { | ||
805 | return 0; | ||
806 | } | ||
807 | #endif | ||
808 | |||
809 | static void | ||
810 | dopr_outch( | ||
811 | char **buffer, | ||
812 | size_t *currlen, | ||
813 | size_t *maxlen, | ||
814 | int c) | ||
815 | { | ||
816 | if (*currlen < *maxlen) | ||
817 | (*buffer)[(*currlen)++] = (char)c; | ||
818 | return; | ||
819 | } | ||
820 | |||
821 | #ifdef USE_ALLOCATING_PRINT | ||
822 | static void | 700 | static void |
823 | doapr_outch( | 701 | doapr_outch( |
702 | char **sbuffer, | ||
824 | char **buffer, | 703 | char **buffer, |
825 | size_t *currlen, | 704 | size_t *currlen, |
826 | size_t *maxlen, | 705 | size_t *maxlen, |
827 | int c) | 706 | int c) |
828 | { | 707 | { |
829 | if (*buffer == NULL) { | 708 | /* If we haven't at least one buffer, someone has doe a big booboo */ |
830 | if (*maxlen == 0) | 709 | assert(*sbuffer != NULL || buffer != NULL); |
831 | *maxlen = 1024; | 710 | |
832 | *buffer = Malloc(*maxlen); | 711 | if (buffer) { |
712 | while (*currlen >= *maxlen) { | ||
713 | if (*buffer == NULL) { | ||
714 | assert(*sbuffer != NULL); | ||
715 | if (*maxlen == 0) | ||
716 | *maxlen = 1024; | ||
717 | *buffer = OPENSSL_malloc(*maxlen); | ||
718 | if (*currlen > 0) | ||
719 | memcpy(*buffer, *sbuffer, *currlen); | ||
720 | *sbuffer = NULL; | ||
721 | } else { | ||
722 | *maxlen += 1024; | ||
723 | *buffer = OPENSSL_realloc(*buffer, *maxlen); | ||
724 | } | ||
725 | } | ||
726 | /* What to do if *buffer is NULL? */ | ||
727 | assert(*sbuffer != NULL || *buffer != NULL); | ||
833 | } | 728 | } |
834 | while (*currlen >= *maxlen) { | 729 | |
835 | *maxlen += 1024; | 730 | if (*currlen < *maxlen) { |
836 | *buffer = Realloc(*buffer, *maxlen); | 731 | if (*sbuffer) |
732 | (*sbuffer)[(*currlen)++] = (char)c; | ||
733 | else | ||
734 | (*buffer)[(*currlen)++] = (char)c; | ||
837 | } | 735 | } |
838 | /* What to do if *buffer is NULL? */ | ||
839 | assert(*buffer != NULL); | ||
840 | 736 | ||
841 | (*buffer)[(*currlen)++] = (char)c; | ||
842 | return; | 737 | return; |
843 | } | 738 | } |
844 | #endif | 739 | |
740 | /***************************************************************************/ | ||
741 | |||
742 | int BIO_printf (BIO *bio, const char *format, ...) | ||
743 | { | ||
744 | va_list args; | ||
745 | int ret; | ||
746 | |||
747 | va_start(args, format); | ||
748 | |||
749 | ret = BIO_vprintf(bio, format, args); | ||
750 | |||
751 | va_end(args); | ||
752 | return(ret); | ||
753 | } | ||
754 | |||
755 | int BIO_vprintf (BIO *bio, const char *format, va_list args) | ||
756 | { | ||
757 | int ret; | ||
758 | size_t retlen; | ||
759 | MS_STATIC char hugebuf[1024*10]; | ||
760 | char *hugebufp = hugebuf; | ||
761 | size_t hugebufsize = sizeof(hugebuf); | ||
762 | char *dynbuf = NULL; | ||
763 | int ignored; | ||
764 | |||
765 | dynbuf = NULL; | ||
766 | CRYPTO_push_info("doapr()"); | ||
767 | _dopr(&hugebufp, &dynbuf, &hugebufsize, | ||
768 | &retlen, &ignored, format, args); | ||
769 | if (dynbuf) | ||
770 | { | ||
771 | ret=BIO_write(bio, dynbuf, (int)retlen); | ||
772 | OPENSSL_free(dynbuf); | ||
773 | } | ||
774 | else | ||
775 | { | ||
776 | ret=BIO_write(bio, hugebuf, (int)retlen); | ||
777 | } | ||
778 | CRYPTO_pop_info(); | ||
779 | return(ret); | ||
780 | } | ||
781 | |||
782 | /* As snprintf is not available everywhere, we provide our own implementation. | ||
783 | * This function has nothing to do with BIOs, but it's closely related | ||
784 | * to BIO_printf, and we need *some* name prefix ... | ||
785 | * (XXX the function should be renamed, but to what?) */ | ||
786 | int BIO_snprintf(char *buf, size_t n, const char *format, ...) | ||
787 | { | ||
788 | va_list args; | ||
789 | int ret; | ||
790 | |||
791 | va_start(args, format); | ||
792 | |||
793 | ret = BIO_vsnprintf(buf, n, format, args); | ||
794 | |||
795 | va_end(args); | ||
796 | return(ret); | ||
797 | } | ||
798 | |||
799 | int BIO_vsnprintf(char *buf, size_t n, const char *format, va_list args) | ||
800 | { | ||
801 | size_t retlen; | ||
802 | int truncated; | ||
803 | |||
804 | _dopr(&buf, NULL, &n, &retlen, &truncated, format, args); | ||
805 | |||
806 | if (truncated) | ||
807 | /* In case of truncation, return -1 like traditional snprintf. | ||
808 | * (Current drafts for ISO/IEC 9899 say snprintf should return | ||
809 | * the number of characters that would have been written, | ||
810 | * had the buffer been large enough.) */ | ||
811 | return -1; | ||
812 | else | ||
813 | return (retlen <= INT_MAX) ? retlen : -1; | ||
814 | } | ||
diff --git a/src/lib/libcrypto/bio/b_sock.c b/src/lib/libcrypto/bio/b_sock.c index 6409f98f57..64310058b4 100644 --- a/src/lib/libcrypto/bio/b_sock.c +++ b/src/lib/libcrypto/bio/b_sock.c | |||
@@ -105,17 +105,22 @@ int BIO_get_host_ip(const char *str, unsigned char *ip) | |||
105 | struct hostent *he; | 105 | struct hostent *he; |
106 | 106 | ||
107 | i=get_ip(str,ip); | 107 | i=get_ip(str,ip); |
108 | if (i > 0) return(1); | ||
109 | if (i < 0) | 108 | if (i < 0) |
110 | { | 109 | { |
111 | BIOerr(BIO_F_BIO_GET_HOST_IP,BIO_R_INVALID_IP_ADDRESS); | 110 | BIOerr(BIO_F_BIO_GET_HOST_IP,BIO_R_INVALID_IP_ADDRESS); |
112 | goto err; | 111 | goto err; |
113 | } | 112 | } |
114 | 113 | ||
115 | /* do a gethostbyname */ | 114 | /* At this point, we have something that is most probably correct |
115 | in some way, so let's init the socket. */ | ||
116 | if (!BIO_sock_init()) | 116 | if (!BIO_sock_init()) |
117 | return(0); /* don't generate another error code here */ | 117 | return(0); /* don't generate another error code here */ |
118 | 118 | ||
119 | /* If the string actually contained an IP address, we need not do | ||
120 | anything more */ | ||
121 | if (i > 0) return(1); | ||
122 | |||
123 | /* do a gethostbyname */ | ||
119 | CRYPTO_w_lock(CRYPTO_LOCK_GETHOSTBYNAME); | 124 | CRYPTO_w_lock(CRYPTO_LOCK_GETHOSTBYNAME); |
120 | locked = 1; | 125 | locked = 1; |
121 | he=BIO_gethostbyname(str); | 126 | he=BIO_gethostbyname(str); |
@@ -267,14 +272,14 @@ static struct hostent *ghbn_dup(struct hostent *a) | |||
267 | int i,j; | 272 | int i,j; |
268 | 273 | ||
269 | MemCheck_off(); | 274 | MemCheck_off(); |
270 | ret=(struct hostent *)Malloc(sizeof(struct hostent)); | 275 | ret=(struct hostent *)OPENSSL_malloc(sizeof(struct hostent)); |
271 | if (ret == NULL) return(NULL); | 276 | if (ret == NULL) return(NULL); |
272 | memset(ret,0,sizeof(struct hostent)); | 277 | memset(ret,0,sizeof(struct hostent)); |
273 | 278 | ||
274 | for (i=0; a->h_aliases[i] != NULL; i++) | 279 | for (i=0; a->h_aliases[i] != NULL; i++) |
275 | ; | 280 | ; |
276 | i++; | 281 | i++; |
277 | ret->h_aliases = (char **)Malloc(i*sizeof(char *)); | 282 | ret->h_aliases = (char **)OPENSSL_malloc(i*sizeof(char *)); |
278 | if (ret->h_aliases == NULL) | 283 | if (ret->h_aliases == NULL) |
279 | goto err; | 284 | goto err; |
280 | memset(ret->h_aliases, 0, i*sizeof(char *)); | 285 | memset(ret->h_aliases, 0, i*sizeof(char *)); |
@@ -282,25 +287,25 @@ static struct hostent *ghbn_dup(struct hostent *a) | |||
282 | for (i=0; a->h_addr_list[i] != NULL; i++) | 287 | for (i=0; a->h_addr_list[i] != NULL; i++) |
283 | ; | 288 | ; |
284 | i++; | 289 | i++; |
285 | ret->h_addr_list=(char **)Malloc(i*sizeof(char *)); | 290 | ret->h_addr_list=(char **)OPENSSL_malloc(i*sizeof(char *)); |
286 | if (ret->h_addr_list == NULL) | 291 | if (ret->h_addr_list == NULL) |
287 | goto err; | 292 | goto err; |
288 | memset(ret->h_addr_list, 0, i*sizeof(char *)); | 293 | memset(ret->h_addr_list, 0, i*sizeof(char *)); |
289 | 294 | ||
290 | j=strlen(a->h_name)+1; | 295 | j=strlen(a->h_name)+1; |
291 | if ((ret->h_name=Malloc(j)) == NULL) goto err; | 296 | if ((ret->h_name=OPENSSL_malloc(j)) == NULL) goto err; |
292 | memcpy((char *)ret->h_name,a->h_name,j); | 297 | memcpy((char *)ret->h_name,a->h_name,j); |
293 | for (i=0; a->h_aliases[i] != NULL; i++) | 298 | for (i=0; a->h_aliases[i] != NULL; i++) |
294 | { | 299 | { |
295 | j=strlen(a->h_aliases[i])+1; | 300 | j=strlen(a->h_aliases[i])+1; |
296 | if ((ret->h_aliases[i]=Malloc(j)) == NULL) goto err; | 301 | if ((ret->h_aliases[i]=OPENSSL_malloc(j)) == NULL) goto err; |
297 | memcpy(ret->h_aliases[i],a->h_aliases[i],j); | 302 | memcpy(ret->h_aliases[i],a->h_aliases[i],j); |
298 | } | 303 | } |
299 | ret->h_length=a->h_length; | 304 | ret->h_length=a->h_length; |
300 | ret->h_addrtype=a->h_addrtype; | 305 | ret->h_addrtype=a->h_addrtype; |
301 | for (i=0; a->h_addr_list[i] != NULL; i++) | 306 | for (i=0; a->h_addr_list[i] != NULL; i++) |
302 | { | 307 | { |
303 | if ((ret->h_addr_list[i]=Malloc(a->h_length)) == NULL) | 308 | if ((ret->h_addr_list[i]=OPENSSL_malloc(a->h_length)) == NULL) |
304 | goto err; | 309 | goto err; |
305 | memcpy(ret->h_addr_list[i],a->h_addr_list[i],a->h_length); | 310 | memcpy(ret->h_addr_list[i],a->h_addr_list[i],a->h_length); |
306 | } | 311 | } |
@@ -325,17 +330,17 @@ static void ghbn_free(struct hostent *a) | |||
325 | if (a->h_aliases != NULL) | 330 | if (a->h_aliases != NULL) |
326 | { | 331 | { |
327 | for (i=0; a->h_aliases[i] != NULL; i++) | 332 | for (i=0; a->h_aliases[i] != NULL; i++) |
328 | Free(a->h_aliases[i]); | 333 | OPENSSL_free(a->h_aliases[i]); |
329 | Free(a->h_aliases); | 334 | OPENSSL_free(a->h_aliases); |
330 | } | 335 | } |
331 | if (a->h_addr_list != NULL) | 336 | if (a->h_addr_list != NULL) |
332 | { | 337 | { |
333 | for (i=0; a->h_addr_list[i] != NULL; i++) | 338 | for (i=0; a->h_addr_list[i] != NULL; i++) |
334 | Free(a->h_addr_list[i]); | 339 | OPENSSL_free(a->h_addr_list[i]); |
335 | Free(a->h_addr_list); | 340 | OPENSSL_free(a->h_addr_list); |
336 | } | 341 | } |
337 | if (a->h_name != NULL) Free(a->h_name); | 342 | if (a->h_name != NULL) OPENSSL_free(a->h_name); |
338 | Free(a); | 343 | OPENSSL_free(a); |
339 | } | 344 | } |
340 | 345 | ||
341 | struct hostent *BIO_gethostbyname(const char *name) | 346 | struct hostent *BIO_gethostbyname(const char *name) |
@@ -628,7 +633,7 @@ again: | |||
628 | } | 633 | } |
629 | ret=1; | 634 | ret=1; |
630 | err: | 635 | err: |
631 | if (str != NULL) Free(str); | 636 | if (str != NULL) OPENSSL_free(str); |
632 | if ((ret == 0) && (s != INVALID_SOCKET)) | 637 | if ((ret == 0) && (s != INVALID_SOCKET)) |
633 | { | 638 | { |
634 | closesocket(s); | 639 | closesocket(s); |
@@ -667,7 +672,7 @@ int BIO_accept(int sock, char **addr) | |||
667 | port=ntohs(from.sin_port); | 672 | port=ntohs(from.sin_port); |
668 | if (*addr == NULL) | 673 | if (*addr == NULL) |
669 | { | 674 | { |
670 | if ((p=Malloc(24)) == NULL) | 675 | if ((p=OPENSSL_malloc(24)) == NULL) |
671 | { | 676 | { |
672 | BIOerr(BIO_F_BIO_ACCEPT,ERR_R_MALLOC_FAILURE); | 677 | BIOerr(BIO_F_BIO_ACCEPT,ERR_R_MALLOC_FAILURE); |
673 | goto end; | 678 | goto end; |
diff --git a/src/lib/libcrypto/bio/bf_buff.c b/src/lib/libcrypto/bio/bf_buff.c index ff0c9070ae..f50e8f98a3 100644 --- a/src/lib/libcrypto/bio/bf_buff.c +++ b/src/lib/libcrypto/bio/bf_buff.c | |||
@@ -62,14 +62,14 @@ | |||
62 | #include <openssl/bio.h> | 62 | #include <openssl/bio.h> |
63 | #include <openssl/evp.h> | 63 | #include <openssl/evp.h> |
64 | 64 | ||
65 | static int buffer_write(BIO *h,char *buf,int num); | 65 | static int buffer_write(BIO *h, const char *buf,int num); |
66 | static int buffer_read(BIO *h,char *buf,int size); | 66 | static int buffer_read(BIO *h, char *buf, int size); |
67 | static int buffer_puts(BIO *h,char *str); | 67 | static int buffer_puts(BIO *h, const char *str); |
68 | static int buffer_gets(BIO *h,char *str,int size); | 68 | static int buffer_gets(BIO *h, char *str, int size); |
69 | static long buffer_ctrl(BIO *h,int cmd,long arg1,char *arg2); | 69 | static long buffer_ctrl(BIO *h, int cmd, long arg1, void *arg2); |
70 | static int buffer_new(BIO *h); | 70 | static int buffer_new(BIO *h); |
71 | static int buffer_free(BIO *data); | 71 | static int buffer_free(BIO *data); |
72 | static long buffer_callback_ctrl(BIO *h,int cmd, void (*fp)()); | 72 | static long buffer_callback_ctrl(BIO *h, int cmd, bio_info_cb *fp); |
73 | #define DEFAULT_BUFFER_SIZE 1024 | 73 | #define DEFAULT_BUFFER_SIZE 1024 |
74 | 74 | ||
75 | static BIO_METHOD methods_buffer= | 75 | static BIO_METHOD methods_buffer= |
@@ -95,12 +95,12 @@ static int buffer_new(BIO *bi) | |||
95 | { | 95 | { |
96 | BIO_F_BUFFER_CTX *ctx; | 96 | BIO_F_BUFFER_CTX *ctx; |
97 | 97 | ||
98 | ctx=(BIO_F_BUFFER_CTX *)Malloc(sizeof(BIO_F_BUFFER_CTX)); | 98 | ctx=(BIO_F_BUFFER_CTX *)OPENSSL_malloc(sizeof(BIO_F_BUFFER_CTX)); |
99 | if (ctx == NULL) return(0); | 99 | if (ctx == NULL) return(0); |
100 | ctx->ibuf=(char *)Malloc(DEFAULT_BUFFER_SIZE); | 100 | ctx->ibuf=(char *)OPENSSL_malloc(DEFAULT_BUFFER_SIZE); |
101 | if (ctx->ibuf == NULL) { Free(ctx); return(0); } | 101 | if (ctx->ibuf == NULL) { OPENSSL_free(ctx); return(0); } |
102 | ctx->obuf=(char *)Malloc(DEFAULT_BUFFER_SIZE); | 102 | ctx->obuf=(char *)OPENSSL_malloc(DEFAULT_BUFFER_SIZE); |
103 | if (ctx->obuf == NULL) { Free(ctx->ibuf); Free(ctx); return(0); } | 103 | if (ctx->obuf == NULL) { OPENSSL_free(ctx->ibuf); OPENSSL_free(ctx); return(0); } |
104 | ctx->ibuf_size=DEFAULT_BUFFER_SIZE; | 104 | ctx->ibuf_size=DEFAULT_BUFFER_SIZE; |
105 | ctx->obuf_size=DEFAULT_BUFFER_SIZE; | 105 | ctx->obuf_size=DEFAULT_BUFFER_SIZE; |
106 | ctx->ibuf_len=0; | 106 | ctx->ibuf_len=0; |
@@ -120,9 +120,9 @@ static int buffer_free(BIO *a) | |||
120 | 120 | ||
121 | if (a == NULL) return(0); | 121 | if (a == NULL) return(0); |
122 | b=(BIO_F_BUFFER_CTX *)a->ptr; | 122 | b=(BIO_F_BUFFER_CTX *)a->ptr; |
123 | if (b->ibuf != NULL) Free(b->ibuf); | 123 | if (b->ibuf != NULL) OPENSSL_free(b->ibuf); |
124 | if (b->obuf != NULL) Free(b->obuf); | 124 | if (b->obuf != NULL) OPENSSL_free(b->obuf); |
125 | Free(a->ptr); | 125 | OPENSSL_free(a->ptr); |
126 | a->ptr=NULL; | 126 | a->ptr=NULL; |
127 | a->init=0; | 127 | a->init=0; |
128 | a->flags=0; | 128 | a->flags=0; |
@@ -195,7 +195,7 @@ start: | |||
195 | goto start; | 195 | goto start; |
196 | } | 196 | } |
197 | 197 | ||
198 | static int buffer_write(BIO *b, char *in, int inl) | 198 | static int buffer_write(BIO *b, const char *in, int inl) |
199 | { | 199 | { |
200 | int i,num=0; | 200 | int i,num=0; |
201 | BIO_F_BUFFER_CTX *ctx; | 201 | BIO_F_BUFFER_CTX *ctx; |
@@ -268,7 +268,7 @@ start: | |||
268 | goto start; | 268 | goto start; |
269 | } | 269 | } |
270 | 270 | ||
271 | static long buffer_ctrl(BIO *b, int cmd, long num, char *ptr) | 271 | static long buffer_ctrl(BIO *b, int cmd, long num, void *ptr) |
272 | { | 272 | { |
273 | BIO *dbio; | 273 | BIO *dbio; |
274 | BIO_F_BUFFER_CTX *ctx; | 274 | BIO_F_BUFFER_CTX *ctx; |
@@ -319,9 +319,9 @@ static long buffer_ctrl(BIO *b, int cmd, long num, char *ptr) | |||
319 | case BIO_C_SET_BUFF_READ_DATA: | 319 | case BIO_C_SET_BUFF_READ_DATA: |
320 | if (num > ctx->ibuf_size) | 320 | if (num > ctx->ibuf_size) |
321 | { | 321 | { |
322 | p1=Malloc((int)num); | 322 | p1=OPENSSL_malloc((int)num); |
323 | if (p1 == NULL) goto malloc_error; | 323 | if (p1 == NULL) goto malloc_error; |
324 | if (ctx->ibuf != NULL) Free(ctx->ibuf); | 324 | if (ctx->ibuf != NULL) OPENSSL_free(ctx->ibuf); |
325 | ctx->ibuf=p1; | 325 | ctx->ibuf=p1; |
326 | } | 326 | } |
327 | ctx->ibuf_off=0; | 327 | ctx->ibuf_off=0; |
@@ -353,21 +353,21 @@ static long buffer_ctrl(BIO *b, int cmd, long num, char *ptr) | |||
353 | p2=ctx->obuf; | 353 | p2=ctx->obuf; |
354 | if ((ibs > DEFAULT_BUFFER_SIZE) && (ibs != ctx->ibuf_size)) | 354 | if ((ibs > DEFAULT_BUFFER_SIZE) && (ibs != ctx->ibuf_size)) |
355 | { | 355 | { |
356 | p1=(char *)Malloc((int)num); | 356 | p1=(char *)OPENSSL_malloc((int)num); |
357 | if (p1 == NULL) goto malloc_error; | 357 | if (p1 == NULL) goto malloc_error; |
358 | } | 358 | } |
359 | if ((obs > DEFAULT_BUFFER_SIZE) && (obs != ctx->obuf_size)) | 359 | if ((obs > DEFAULT_BUFFER_SIZE) && (obs != ctx->obuf_size)) |
360 | { | 360 | { |
361 | p2=(char *)Malloc((int)num); | 361 | p2=(char *)OPENSSL_malloc((int)num); |
362 | if (p2 == NULL) | 362 | if (p2 == NULL) |
363 | { | 363 | { |
364 | if (p1 != ctx->ibuf) Free(p1); | 364 | if (p1 != ctx->ibuf) OPENSSL_free(p1); |
365 | goto malloc_error; | 365 | goto malloc_error; |
366 | } | 366 | } |
367 | } | 367 | } |
368 | if (ctx->ibuf != p1) | 368 | if (ctx->ibuf != p1) |
369 | { | 369 | { |
370 | Free(ctx->ibuf); | 370 | OPENSSL_free(ctx->ibuf); |
371 | ctx->ibuf=p1; | 371 | ctx->ibuf=p1; |
372 | ctx->ibuf_off=0; | 372 | ctx->ibuf_off=0; |
373 | ctx->ibuf_len=0; | 373 | ctx->ibuf_len=0; |
@@ -375,7 +375,7 @@ static long buffer_ctrl(BIO *b, int cmd, long num, char *ptr) | |||
375 | } | 375 | } |
376 | if (ctx->obuf != p2) | 376 | if (ctx->obuf != p2) |
377 | { | 377 | { |
378 | Free(ctx->obuf); | 378 | OPENSSL_free(ctx->obuf); |
379 | ctx->obuf=p2; | 379 | ctx->obuf=p2; |
380 | ctx->obuf_off=0; | 380 | ctx->obuf_off=0; |
381 | ctx->obuf_len=0; | 381 | ctx->obuf_len=0; |
@@ -439,7 +439,7 @@ malloc_error: | |||
439 | return(0); | 439 | return(0); |
440 | } | 440 | } |
441 | 441 | ||
442 | static long buffer_callback_ctrl(BIO *b, int cmd, void (*fp)()) | 442 | static long buffer_callback_ctrl(BIO *b, int cmd, bio_info_cb *fp) |
443 | { | 443 | { |
444 | long ret=1; | 444 | long ret=1; |
445 | 445 | ||
@@ -504,8 +504,8 @@ static int buffer_gets(BIO *b, char *buf, int size) | |||
504 | } | 504 | } |
505 | } | 505 | } |
506 | 506 | ||
507 | static int buffer_puts(BIO *b, char *str) | 507 | static int buffer_puts(BIO *b, const char *str) |
508 | { | 508 | { |
509 | return(BIO_write(b,str,strlen(str))); | 509 | return(buffer_write(b,str,strlen(str))); |
510 | } | 510 | } |
511 | 511 | ||
diff --git a/src/lib/libcrypto/bio/bf_lbuf.c b/src/lib/libcrypto/bio/bf_lbuf.c new file mode 100644 index 0000000000..7bcf8ed941 --- /dev/null +++ b/src/lib/libcrypto/bio/bf_lbuf.c | |||
@@ -0,0 +1,397 @@ | |||
1 | /* crypto/bio/bf_buff.c */ | ||
2 | /* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) | ||
3 | * All rights reserved. | ||
4 | * | ||
5 | * This package is an SSL implementation written | ||
6 | * by Eric Young (eay@cryptsoft.com). | ||
7 | * The implementation was written so as to conform with Netscapes SSL. | ||
8 | * | ||
9 | * This library is free for commercial and non-commercial use as long as | ||
10 | * the following conditions are aheared to. The following conditions | ||
11 | * apply to all code found in this distribution, be it the RC4, RSA, | ||
12 | * lhash, DES, etc., code; not just the SSL code. The SSL documentation | ||
13 | * included with this distribution is covered by the same copyright terms | ||
14 | * except that the holder is Tim Hudson (tjh@cryptsoft.com). | ||
15 | * | ||
16 | * Copyright remains Eric Young's, and as such any Copyright notices in | ||
17 | * the code are not to be removed. | ||
18 | * If this package is used in a product, Eric Young should be given attribution | ||
19 | * as the author of the parts of the library used. | ||
20 | * This can be in the form of a textual message at program startup or | ||
21 | * in documentation (online or textual) provided with the package. | ||
22 | * | ||
23 | * Redistribution and use in source and binary forms, with or without | ||
24 | * modification, are permitted provided that the following conditions | ||
25 | * are met: | ||
26 | * 1. Redistributions of source code must retain the copyright | ||
27 | * notice, this list of conditions and the following disclaimer. | ||
28 | * 2. Redistributions in binary form must reproduce the above copyright | ||
29 | * notice, this list of conditions and the following disclaimer in the | ||
30 | * documentation and/or other materials provided with the distribution. | ||
31 | * 3. All advertising materials mentioning features or use of this software | ||
32 | * must display the following acknowledgement: | ||
33 | * "This product includes cryptographic software written by | ||
34 | * Eric Young (eay@cryptsoft.com)" | ||
35 | * The word 'cryptographic' can be left out if the rouines from the library | ||
36 | * being used are not cryptographic related :-). | ||
37 | * 4. If you include any Windows specific code (or a derivative thereof) from | ||
38 | * the apps directory (application code) you must include an acknowledgement: | ||
39 | * "This product includes software written by Tim Hudson (tjh@cryptsoft.com)" | ||
40 | * | ||
41 | * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND | ||
42 | * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||
43 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE | ||
44 | * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE | ||
45 | * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||
46 | * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS | ||
47 | * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) | ||
48 | * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT | ||
49 | * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY | ||
50 | * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | ||
51 | * SUCH DAMAGE. | ||
52 | * | ||
53 | * The licence and distribution terms for any publically available version or | ||
54 | * derivative of this code cannot be changed. i.e. this code cannot simply be | ||
55 | * copied and put under another distribution licence | ||
56 | * [including the GNU Public Licence.] | ||
57 | */ | ||
58 | |||
59 | #include <stdio.h> | ||
60 | #include <errno.h> | ||
61 | #include "cryptlib.h" | ||
62 | #include <openssl/bio.h> | ||
63 | #include <openssl/evp.h> | ||
64 | |||
65 | static int linebuffer_write(BIO *h, const char *buf,int num); | ||
66 | static int linebuffer_read(BIO *h, char *buf, int size); | ||
67 | static int linebuffer_puts(BIO *h, const char *str); | ||
68 | static int linebuffer_gets(BIO *h, char *str, int size); | ||
69 | static long linebuffer_ctrl(BIO *h, int cmd, long arg1, void *arg2); | ||
70 | static int linebuffer_new(BIO *h); | ||
71 | static int linebuffer_free(BIO *data); | ||
72 | static long linebuffer_callback_ctrl(BIO *h, int cmd, bio_info_cb *fp); | ||
73 | |||
74 | /* A 10k maximum should be enough for most purposes */ | ||
75 | #define DEFAULT_LINEBUFFER_SIZE 1024*10 | ||
76 | |||
77 | /* #define DEBUG */ | ||
78 | |||
79 | static BIO_METHOD methods_linebuffer= | ||
80 | { | ||
81 | BIO_TYPE_LINEBUFFER, | ||
82 | "linebuffer", | ||
83 | linebuffer_write, | ||
84 | linebuffer_read, | ||
85 | linebuffer_puts, | ||
86 | linebuffer_gets, | ||
87 | linebuffer_ctrl, | ||
88 | linebuffer_new, | ||
89 | linebuffer_free, | ||
90 | linebuffer_callback_ctrl, | ||
91 | }; | ||
92 | |||
93 | BIO_METHOD *BIO_f_linebuffer(void) | ||
94 | { | ||
95 | return(&methods_linebuffer); | ||
96 | } | ||
97 | |||
98 | typedef struct bio_linebuffer_ctx_struct | ||
99 | { | ||
100 | char *obuf; /* the output char array */ | ||
101 | int obuf_size; /* how big is the output buffer */ | ||
102 | int obuf_len; /* how many bytes are in it */ | ||
103 | } BIO_LINEBUFFER_CTX; | ||
104 | |||
105 | static int linebuffer_new(BIO *bi) | ||
106 | { | ||
107 | BIO_LINEBUFFER_CTX *ctx; | ||
108 | |||
109 | ctx=(BIO_LINEBUFFER_CTX *)OPENSSL_malloc(sizeof(BIO_LINEBUFFER_CTX)); | ||
110 | if (ctx == NULL) return(0); | ||
111 | ctx->obuf=(char *)OPENSSL_malloc(DEFAULT_LINEBUFFER_SIZE); | ||
112 | if (ctx->obuf == NULL) { OPENSSL_free(ctx); return(0); } | ||
113 | ctx->obuf_size=DEFAULT_LINEBUFFER_SIZE; | ||
114 | ctx->obuf_len=0; | ||
115 | |||
116 | bi->init=1; | ||
117 | bi->ptr=(char *)ctx; | ||
118 | bi->flags=0; | ||
119 | return(1); | ||
120 | } | ||
121 | |||
122 | static int linebuffer_free(BIO *a) | ||
123 | { | ||
124 | BIO_LINEBUFFER_CTX *b; | ||
125 | |||
126 | if (a == NULL) return(0); | ||
127 | b=(BIO_LINEBUFFER_CTX *)a->ptr; | ||
128 | if (b->obuf != NULL) OPENSSL_free(b->obuf); | ||
129 | OPENSSL_free(a->ptr); | ||
130 | a->ptr=NULL; | ||
131 | a->init=0; | ||
132 | a->flags=0; | ||
133 | return(1); | ||
134 | } | ||
135 | |||
136 | static int linebuffer_read(BIO *b, char *out, int outl) | ||
137 | { | ||
138 | int ret=0; | ||
139 | |||
140 | if (out == NULL) return(0); | ||
141 | if (b->next_bio == NULL) return(0); | ||
142 | ret=BIO_read(b->next_bio,out,outl); | ||
143 | BIO_clear_retry_flags(b); | ||
144 | BIO_copy_next_retry(b); | ||
145 | return(ret); | ||
146 | } | ||
147 | |||
148 | static int linebuffer_write(BIO *b, const char *in, int inl) | ||
149 | { | ||
150 | int i,num=0,foundnl; | ||
151 | BIO_LINEBUFFER_CTX *ctx; | ||
152 | |||
153 | if ((in == NULL) || (inl <= 0)) return(0); | ||
154 | ctx=(BIO_LINEBUFFER_CTX *)b->ptr; | ||
155 | if ((ctx == NULL) || (b->next_bio == NULL)) return(0); | ||
156 | |||
157 | BIO_clear_retry_flags(b); | ||
158 | |||
159 | do | ||
160 | { | ||
161 | const char *p; | ||
162 | |||
163 | for(p = in; p < in + inl && *p != '\n'; p++) | ||
164 | ; | ||
165 | if (*p == '\n') | ||
166 | { | ||
167 | p++; | ||
168 | foundnl = 1; | ||
169 | } | ||
170 | else | ||
171 | foundnl = 0; | ||
172 | |||
173 | /* If a NL was found and we already have text in the save | ||
174 | buffer, concatenate them and write */ | ||
175 | while ((foundnl || p - in > ctx->obuf_size - ctx->obuf_len) | ||
176 | && ctx->obuf_len > 0) | ||
177 | { | ||
178 | int orig_olen = ctx->obuf_len; | ||
179 | |||
180 | i = ctx->obuf_size - ctx->obuf_len; | ||
181 | if (p - in > 0) | ||
182 | { | ||
183 | if (i >= p - in) | ||
184 | { | ||
185 | memcpy(&(ctx->obuf[ctx->obuf_len]), | ||
186 | in,p - in); | ||
187 | ctx->obuf_len += p - in; | ||
188 | inl -= p - in; | ||
189 | num += p - in; | ||
190 | in = p; | ||
191 | } | ||
192 | else | ||
193 | { | ||
194 | memcpy(&(ctx->obuf[ctx->obuf_len]), | ||
195 | in,i); | ||
196 | ctx->obuf_len += i; | ||
197 | inl -= i; | ||
198 | in += i; | ||
199 | num += i; | ||
200 | } | ||
201 | } | ||
202 | |||
203 | #ifdef DEBUG | ||
204 | BIO_write(b->next_bio, "<*<", 3); | ||
205 | #endif | ||
206 | i=BIO_write(b->next_bio, | ||
207 | ctx->obuf, ctx->obuf_len); | ||
208 | if (i <= 0) | ||
209 | { | ||
210 | ctx->obuf_len = orig_olen; | ||
211 | BIO_copy_next_retry(b); | ||
212 | |||
213 | #ifdef DEBUG | ||
214 | BIO_write(b->next_bio, ">*>", 3); | ||
215 | #endif | ||
216 | if (i < 0) return((num > 0)?num:i); | ||
217 | if (i == 0) return(num); | ||
218 | } | ||
219 | #ifdef DEBUG | ||
220 | BIO_write(b->next_bio, ">*>", 3); | ||
221 | #endif | ||
222 | if (i < ctx->obuf_len) | ||
223 | memmove(ctx->obuf, ctx->obuf + i, | ||
224 | ctx->obuf_len - i); | ||
225 | ctx->obuf_len-=i; | ||
226 | } | ||
227 | |||
228 | /* Now that the save buffer is emptied, let's write the input | ||
229 | buffer if a NL was found and there is anything to write. */ | ||
230 | if ((foundnl || p - in > ctx->obuf_size) && p - in > 0) | ||
231 | { | ||
232 | #ifdef DEBUG | ||
233 | BIO_write(b->next_bio, "<*<", 3); | ||
234 | #endif | ||
235 | i=BIO_write(b->next_bio,in,p - in); | ||
236 | if (i <= 0) | ||
237 | { | ||
238 | BIO_copy_next_retry(b); | ||
239 | #ifdef DEBUG | ||
240 | BIO_write(b->next_bio, ">*>", 3); | ||
241 | #endif | ||
242 | if (i < 0) return((num > 0)?num:i); | ||
243 | if (i == 0) return(num); | ||
244 | } | ||
245 | #ifdef DEBUG | ||
246 | BIO_write(b->next_bio, ">*>", 3); | ||
247 | #endif | ||
248 | num+=i; | ||
249 | in+=i; | ||
250 | inl-=i; | ||
251 | } | ||
252 | } | ||
253 | while(foundnl && inl > 0); | ||
254 | /* We've written as much as we can. The rest of the input buffer, if | ||
255 | any, is text that doesn't and with a NL and therefore needs to be | ||
256 | saved for the next trip. */ | ||
257 | if (inl > 0) | ||
258 | { | ||
259 | memcpy(&(ctx->obuf[ctx->obuf_len]), in, inl); | ||
260 | ctx->obuf_len += inl; | ||
261 | num += inl; | ||
262 | } | ||
263 | return num; | ||
264 | } | ||
265 | |||
266 | static long linebuffer_ctrl(BIO *b, int cmd, long num, void *ptr) | ||
267 | { | ||
268 | BIO *dbio; | ||
269 | BIO_LINEBUFFER_CTX *ctx; | ||
270 | long ret=1; | ||
271 | char *p; | ||
272 | int r; | ||
273 | int obs; | ||
274 | |||
275 | ctx=(BIO_LINEBUFFER_CTX *)b->ptr; | ||
276 | |||
277 | switch (cmd) | ||
278 | { | ||
279 | case BIO_CTRL_RESET: | ||
280 | ctx->obuf_len=0; | ||
281 | if (b->next_bio == NULL) return(0); | ||
282 | ret=BIO_ctrl(b->next_bio,cmd,num,ptr); | ||
283 | break; | ||
284 | case BIO_CTRL_INFO: | ||
285 | ret=(long)ctx->obuf_len; | ||
286 | break; | ||
287 | case BIO_CTRL_WPENDING: | ||
288 | ret=(long)ctx->obuf_len; | ||
289 | if (ret == 0) | ||
290 | { | ||
291 | if (b->next_bio == NULL) return(0); | ||
292 | ret=BIO_ctrl(b->next_bio,cmd,num,ptr); | ||
293 | } | ||
294 | break; | ||
295 | case BIO_C_SET_BUFF_SIZE: | ||
296 | obs=(int)num; | ||
297 | p=ctx->obuf; | ||
298 | if ((obs > DEFAULT_LINEBUFFER_SIZE) && (obs != ctx->obuf_size)) | ||
299 | { | ||
300 | p=(char *)OPENSSL_malloc((int)num); | ||
301 | if (p == NULL) | ||
302 | goto malloc_error; | ||
303 | } | ||
304 | if (ctx->obuf != p) | ||
305 | { | ||
306 | if (ctx->obuf_len > obs) | ||
307 | { | ||
308 | ctx->obuf_len = obs; | ||
309 | } | ||
310 | memcpy(p, ctx->obuf, ctx->obuf_len); | ||
311 | OPENSSL_free(ctx->obuf); | ||
312 | ctx->obuf=p; | ||
313 | ctx->obuf_size=obs; | ||
314 | } | ||
315 | break; | ||
316 | case BIO_C_DO_STATE_MACHINE: | ||
317 | if (b->next_bio == NULL) return(0); | ||
318 | BIO_clear_retry_flags(b); | ||
319 | ret=BIO_ctrl(b->next_bio,cmd,num,ptr); | ||
320 | BIO_copy_next_retry(b); | ||
321 | break; | ||
322 | |||
323 | case BIO_CTRL_FLUSH: | ||
324 | if (b->next_bio == NULL) return(0); | ||
325 | if (ctx->obuf_len <= 0) | ||
326 | { | ||
327 | ret=BIO_ctrl(b->next_bio,cmd,num,ptr); | ||
328 | break; | ||
329 | } | ||
330 | |||
331 | for (;;) | ||
332 | { | ||
333 | BIO_clear_retry_flags(b); | ||
334 | if (ctx->obuf_len > 0) | ||
335 | { | ||
336 | r=BIO_write(b->next_bio, | ||
337 | ctx->obuf, ctx->obuf_len); | ||
338 | #if 0 | ||
339 | fprintf(stderr,"FLUSH %3d -> %3d\n",ctx->obuf_len,r); | ||
340 | #endif | ||
341 | BIO_copy_next_retry(b); | ||
342 | if (r <= 0) return((long)r); | ||
343 | if (r < ctx->obuf_len) | ||
344 | memmove(ctx->obuf, ctx->obuf + r, | ||
345 | ctx->obuf_len - r); | ||
346 | ctx->obuf_len-=r; | ||
347 | } | ||
348 | else | ||
349 | { | ||
350 | ctx->obuf_len=0; | ||
351 | ret=1; | ||
352 | break; | ||
353 | } | ||
354 | } | ||
355 | ret=BIO_ctrl(b->next_bio,cmd,num,ptr); | ||
356 | break; | ||
357 | case BIO_CTRL_DUP: | ||
358 | dbio=(BIO *)ptr; | ||
359 | if ( !BIO_set_write_buffer_size(dbio,ctx->obuf_size)) | ||
360 | ret=0; | ||
361 | break; | ||
362 | default: | ||
363 | if (b->next_bio == NULL) return(0); | ||
364 | ret=BIO_ctrl(b->next_bio,cmd,num,ptr); | ||
365 | break; | ||
366 | } | ||
367 | return(ret); | ||
368 | malloc_error: | ||
369 | BIOerr(BIO_F_LINEBUFFER_CTRL,ERR_R_MALLOC_FAILURE); | ||
370 | return(0); | ||
371 | } | ||
372 | |||
373 | static long linebuffer_callback_ctrl(BIO *b, int cmd, bio_info_cb *fp) | ||
374 | { | ||
375 | long ret=1; | ||
376 | |||
377 | if (b->next_bio == NULL) return(0); | ||
378 | switch (cmd) | ||
379 | { | ||
380 | default: | ||
381 | ret=BIO_callback_ctrl(b->next_bio,cmd,fp); | ||
382 | break; | ||
383 | } | ||
384 | return(ret); | ||
385 | } | ||
386 | |||
387 | static int linebuffer_gets(BIO *b, char *buf, int size) | ||
388 | { | ||
389 | if (b->next_bio == NULL) return(0); | ||
390 | return(BIO_gets(b->next_bio,buf,size)); | ||
391 | } | ||
392 | |||
393 | static int linebuffer_puts(BIO *b, const char *str) | ||
394 | { | ||
395 | return(linebuffer_write(b,str,strlen(str))); | ||
396 | } | ||
397 | |||
diff --git a/src/lib/libcrypto/bio/bf_nbio.c b/src/lib/libcrypto/bio/bf_nbio.c index 5e574b7231..413ef5c4c5 100644 --- a/src/lib/libcrypto/bio/bf_nbio.c +++ b/src/lib/libcrypto/bio/bf_nbio.c | |||
@@ -66,14 +66,14 @@ | |||
66 | /* BIO_put and BIO_get both add to the digest, | 66 | /* BIO_put and BIO_get both add to the digest, |
67 | * BIO_gets returns the digest */ | 67 | * BIO_gets returns the digest */ |
68 | 68 | ||
69 | static int nbiof_write(BIO *h,char *buf,int num); | 69 | static int nbiof_write(BIO *h,const char *buf,int num); |
70 | static int nbiof_read(BIO *h,char *buf,int size); | 70 | static int nbiof_read(BIO *h,char *buf,int size); |
71 | static int nbiof_puts(BIO *h,char *str); | 71 | static int nbiof_puts(BIO *h,const char *str); |
72 | static int nbiof_gets(BIO *h,char *str,int size); | 72 | static int nbiof_gets(BIO *h,char *str,int size); |
73 | static long nbiof_ctrl(BIO *h,int cmd,long arg1,char *arg2); | 73 | static long nbiof_ctrl(BIO *h,int cmd,long arg1,void *arg2); |
74 | static int nbiof_new(BIO *h); | 74 | static int nbiof_new(BIO *h); |
75 | static int nbiof_free(BIO *data); | 75 | static int nbiof_free(BIO *data); |
76 | static long nbiof_callback_ctrl(BIO *h,int cmd,void (*fp)()); | 76 | static long nbiof_callback_ctrl(BIO *h,int cmd,bio_info_cb *fp); |
77 | typedef struct nbio_test_st | 77 | typedef struct nbio_test_st |
78 | { | 78 | { |
79 | /* only set if we sent a 'should retry' error */ | 79 | /* only set if we sent a 'should retry' error */ |
@@ -104,7 +104,7 @@ static int nbiof_new(BIO *bi) | |||
104 | { | 104 | { |
105 | NBIO_TEST *nt; | 105 | NBIO_TEST *nt; |
106 | 106 | ||
107 | nt=(NBIO_TEST *)Malloc(sizeof(NBIO_TEST)); | 107 | nt=(NBIO_TEST *)OPENSSL_malloc(sizeof(NBIO_TEST)); |
108 | nt->lrn= -1; | 108 | nt->lrn= -1; |
109 | nt->lwn= -1; | 109 | nt->lwn= -1; |
110 | bi->ptr=(char *)nt; | 110 | bi->ptr=(char *)nt; |
@@ -117,7 +117,7 @@ static int nbiof_free(BIO *a) | |||
117 | { | 117 | { |
118 | if (a == NULL) return(0); | 118 | if (a == NULL) return(0); |
119 | if (a->ptr != NULL) | 119 | if (a->ptr != NULL) |
120 | Free(a->ptr); | 120 | OPENSSL_free(a->ptr); |
121 | a->ptr=NULL; | 121 | a->ptr=NULL; |
122 | a->init=0; | 122 | a->init=0; |
123 | a->flags=0; | 123 | a->flags=0; |
@@ -159,7 +159,7 @@ static int nbiof_read(BIO *b, char *out, int outl) | |||
159 | return(ret); | 159 | return(ret); |
160 | } | 160 | } |
161 | 161 | ||
162 | static int nbiof_write(BIO *b, char *in, int inl) | 162 | static int nbiof_write(BIO *b, const char *in, int inl) |
163 | { | 163 | { |
164 | NBIO_TEST *nt; | 164 | NBIO_TEST *nt; |
165 | int ret=0; | 165 | int ret=0; |
@@ -204,7 +204,7 @@ static int nbiof_write(BIO *b, char *in, int inl) | |||
204 | return(ret); | 204 | return(ret); |
205 | } | 205 | } |
206 | 206 | ||
207 | static long nbiof_ctrl(BIO *b, int cmd, long num, char *ptr) | 207 | static long nbiof_ctrl(BIO *b, int cmd, long num, void *ptr) |
208 | { | 208 | { |
209 | long ret; | 209 | long ret; |
210 | 210 | ||
@@ -226,7 +226,7 @@ static long nbiof_ctrl(BIO *b, int cmd, long num, char *ptr) | |||
226 | return(ret); | 226 | return(ret); |
227 | } | 227 | } |
228 | 228 | ||
229 | static long nbiof_callback_ctrl(BIO *b, int cmd, void (*fp)()) | 229 | static long nbiof_callback_ctrl(BIO *b, int cmd, bio_info_cb *fp) |
230 | { | 230 | { |
231 | long ret=1; | 231 | long ret=1; |
232 | 232 | ||
@@ -247,7 +247,7 @@ static int nbiof_gets(BIO *bp, char *buf, int size) | |||
247 | } | 247 | } |
248 | 248 | ||
249 | 249 | ||
250 | static int nbiof_puts(BIO *bp, char *str) | 250 | static int nbiof_puts(BIO *bp, const char *str) |
251 | { | 251 | { |
252 | if (bp->next_bio == NULL) return(0); | 252 | if (bp->next_bio == NULL) return(0); |
253 | return(BIO_puts(bp->next_bio,str)); | 253 | return(BIO_puts(bp->next_bio,str)); |
diff --git a/src/lib/libcrypto/bio/bf_null.c b/src/lib/libcrypto/bio/bf_null.c index 0d183a6d9a..2678a1a85d 100644 --- a/src/lib/libcrypto/bio/bf_null.c +++ b/src/lib/libcrypto/bio/bf_null.c | |||
@@ -65,14 +65,14 @@ | |||
65 | /* BIO_put and BIO_get both add to the digest, | 65 | /* BIO_put and BIO_get both add to the digest, |
66 | * BIO_gets returns the digest */ | 66 | * BIO_gets returns the digest */ |
67 | 67 | ||
68 | static int nullf_write(BIO *h,char *buf,int num); | 68 | static int nullf_write(BIO *h, const char *buf, int num); |
69 | static int nullf_read(BIO *h,char *buf,int size); | 69 | static int nullf_read(BIO *h, char *buf, int size); |
70 | static int nullf_puts(BIO *h,char *str); | 70 | static int nullf_puts(BIO *h, const char *str); |
71 | static int nullf_gets(BIO *h,char *str,int size); | 71 | static int nullf_gets(BIO *h, char *str, int size); |
72 | static long nullf_ctrl(BIO *h,int cmd,long arg1,char *arg2); | 72 | static long nullf_ctrl(BIO *h, int cmd, long arg1, void *arg2); |
73 | static int nullf_new(BIO *h); | 73 | static int nullf_new(BIO *h); |
74 | static int nullf_free(BIO *data); | 74 | static int nullf_free(BIO *data); |
75 | static long nullf_callback_ctrl(BIO *h,int cmd,void (*fp)()); | 75 | static long nullf_callback_ctrl(BIO *h, int cmd, bio_info_cb *fp); |
76 | static BIO_METHOD methods_nullf= | 76 | static BIO_METHOD methods_nullf= |
77 | { | 77 | { |
78 | BIO_TYPE_NULL_FILTER, | 78 | BIO_TYPE_NULL_FILTER, |
@@ -121,7 +121,7 @@ static int nullf_read(BIO *b, char *out, int outl) | |||
121 | return(ret); | 121 | return(ret); |
122 | } | 122 | } |
123 | 123 | ||
124 | static int nullf_write(BIO *b, char *in, int inl) | 124 | static int nullf_write(BIO *b, const char *in, int inl) |
125 | { | 125 | { |
126 | int ret=0; | 126 | int ret=0; |
127 | 127 | ||
@@ -133,7 +133,7 @@ static int nullf_write(BIO *b, char *in, int inl) | |||
133 | return(ret); | 133 | return(ret); |
134 | } | 134 | } |
135 | 135 | ||
136 | static long nullf_ctrl(BIO *b, int cmd, long num, char *ptr) | 136 | static long nullf_ctrl(BIO *b, int cmd, long num, void *ptr) |
137 | { | 137 | { |
138 | long ret; | 138 | long ret; |
139 | 139 | ||
@@ -154,7 +154,7 @@ static long nullf_ctrl(BIO *b, int cmd, long num, char *ptr) | |||
154 | return(ret); | 154 | return(ret); |
155 | } | 155 | } |
156 | 156 | ||
157 | static long nullf_callback_ctrl(BIO *b, int cmd, void (*fp)()) | 157 | static long nullf_callback_ctrl(BIO *b, int cmd, bio_info_cb *fp) |
158 | { | 158 | { |
159 | long ret=1; | 159 | long ret=1; |
160 | 160 | ||
@@ -175,7 +175,7 @@ static int nullf_gets(BIO *bp, char *buf, int size) | |||
175 | } | 175 | } |
176 | 176 | ||
177 | 177 | ||
178 | static int nullf_puts(BIO *bp, char *str) | 178 | static int nullf_puts(BIO *bp, const char *str) |
179 | { | 179 | { |
180 | if (bp->next_bio == NULL) return(0); | 180 | if (bp->next_bio == NULL) return(0); |
181 | return(BIO_puts(bp->next_bio,str)); | 181 | return(BIO_puts(bp->next_bio,str)); |
diff --git a/src/lib/libcrypto/bio/bio.h b/src/lib/libcrypto/bio/bio.h index ebdb18170b..97003b503c 100644 --- a/src/lib/libcrypto/bio/bio.h +++ b/src/lib/libcrypto/bio/bio.h | |||
@@ -59,14 +59,17 @@ | |||
59 | #ifndef HEADER_BIO_H | 59 | #ifndef HEADER_BIO_H |
60 | #define HEADER_BIO_H | 60 | #define HEADER_BIO_H |
61 | 61 | ||
62 | #ifdef __cplusplus | 62 | #ifndef NO_FP_API |
63 | extern "C" { | 63 | # include <stdio.h> |
64 | #endif | 64 | #endif |
65 | #include <stdarg.h> | ||
65 | 66 | ||
66 | #include <stdio.h> | ||
67 | #include <stdlib.h> | ||
68 | #include <openssl/crypto.h> | 67 | #include <openssl/crypto.h> |
69 | 68 | ||
69 | #ifdef __cplusplus | ||
70 | extern "C" { | ||
71 | #endif | ||
72 | |||
70 | /* These are the 'types' of BIOs */ | 73 | /* These are the 'types' of BIOs */ |
71 | #define BIO_TYPE_NONE 0 | 74 | #define BIO_TYPE_NONE 0 |
72 | #define BIO_TYPE_MEM (1|0x0400) | 75 | #define BIO_TYPE_MEM (1|0x0400) |
@@ -88,6 +91,7 @@ extern "C" { | |||
88 | #define BIO_TYPE_NULL_FILTER (17|0x0200) | 91 | #define BIO_TYPE_NULL_FILTER (17|0x0200) |
89 | #define BIO_TYPE_BER (18|0x0200) /* BER -> bin filter */ | 92 | #define BIO_TYPE_BER (18|0x0200) /* BER -> bin filter */ |
90 | #define BIO_TYPE_BIO (19|0x0400) /* (half a) BIO pair */ | 93 | #define BIO_TYPE_BIO (19|0x0400) /* (half a) BIO pair */ |
94 | #define BIO_TYPE_LINEBUFFER (20|0x0200) /* filter */ | ||
91 | 95 | ||
92 | #define BIO_TYPE_DESCRIPTOR 0x0100 /* socket, fd, connect or accept */ | 96 | #define BIO_TYPE_DESCRIPTOR 0x0100 /* socket, fd, connect or accept */ |
93 | #define BIO_TYPE_FILTER 0x0200 | 97 | #define BIO_TYPE_FILTER 0x0200 |
@@ -207,19 +211,23 @@ extern "C" { | |||
207 | #define BIO_method_name(b) ((b)->method->name) | 211 | #define BIO_method_name(b) ((b)->method->name) |
208 | #define BIO_method_type(b) ((b)->method->type) | 212 | #define BIO_method_type(b) ((b)->method->type) |
209 | 213 | ||
214 | typedef struct bio_st BIO; | ||
215 | |||
216 | typedef void bio_info_cb(struct bio_st *, int, const char *, int, long, long); | ||
217 | |||
210 | #ifndef WIN16 | 218 | #ifndef WIN16 |
211 | typedef struct bio_method_st | 219 | typedef struct bio_method_st |
212 | { | 220 | { |
213 | int type; | 221 | int type; |
214 | const char *name; | 222 | const char *name; |
215 | int (*bwrite)(); | 223 | int (*bwrite)(BIO *, const char *, int); |
216 | int (*bread)(); | 224 | int (*bread)(BIO *, char *, int); |
217 | int (*bputs)(); | 225 | int (*bputs)(BIO *, const char *); |
218 | int (*bgets)(); | 226 | int (*bgets)(BIO *, char *, int); |
219 | long (*ctrl)(); | 227 | long (*ctrl)(BIO *, int, long, void *); |
220 | int (*create)(); | 228 | int (*create)(BIO *); |
221 | int (*destroy)(); | 229 | int (*destroy)(BIO *); |
222 | long (*callback_ctrl)(); | 230 | long (*callback_ctrl)(BIO *, int, bio_info_cb *); |
223 | } BIO_METHOD; | 231 | } BIO_METHOD; |
224 | #else | 232 | #else |
225 | typedef struct bio_method_st | 233 | typedef struct bio_method_st |
@@ -237,7 +245,7 @@ typedef struct bio_method_st | |||
237 | } BIO_METHOD; | 245 | } BIO_METHOD; |
238 | #endif | 246 | #endif |
239 | 247 | ||
240 | typedef struct bio_st | 248 | struct bio_st |
241 | { | 249 | { |
242 | BIO_METHOD *method; | 250 | BIO_METHOD *method; |
243 | /* bio, mode, argp, argi, argl, ret */ | 251 | /* bio, mode, argp, argi, argl, ret */ |
@@ -257,7 +265,9 @@ typedef struct bio_st | |||
257 | unsigned long num_write; | 265 | unsigned long num_write; |
258 | 266 | ||
259 | CRYPTO_EX_DATA ex_data; | 267 | CRYPTO_EX_DATA ex_data; |
260 | } BIO; | 268 | }; |
269 | |||
270 | DECLARE_STACK_OF(BIO) | ||
261 | 271 | ||
262 | typedef struct bio_f_buffer_ctx_struct | 272 | typedef struct bio_f_buffer_ctx_struct |
263 | { | 273 | { |
@@ -454,8 +464,8 @@ int BIO_read_filename(BIO *b,const char *name); | |||
454 | size_t BIO_ctrl_pending(BIO *b); | 464 | size_t BIO_ctrl_pending(BIO *b); |
455 | size_t BIO_ctrl_wpending(BIO *b); | 465 | size_t BIO_ctrl_wpending(BIO *b); |
456 | #define BIO_flush(b) (int)BIO_ctrl(b,BIO_CTRL_FLUSH,0,NULL) | 466 | #define BIO_flush(b) (int)BIO_ctrl(b,BIO_CTRL_FLUSH,0,NULL) |
457 | #define BIO_get_info_callback(b,cbp) (int)BIO_ctrl(b,BIO_CTRL_GET_CALLBACK,0,(void (**)())(cbp)) | 467 | #define BIO_get_info_callback(b,cbp) (int)BIO_ctrl(b,BIO_CTRL_GET_CALLBACK,0,(bio_info_cb **)(cbp)) |
458 | #define BIO_set_info_callback(b,cb) (int)BIO_callback_ctrl(b,BIO_CTRL_SET_CALLBACK,(void (*)())(cb)) | 468 | #define BIO_set_info_callback(b,cb) (int)BIO_callback_ctrl(b,BIO_CTRL_SET_CALLBACK,(bio_info_cb *)(cb)) |
459 | 469 | ||
460 | /* For the BIO_f_buffer() type */ | 470 | /* For the BIO_f_buffer() type */ |
461 | #define BIO_buffer_get_num_lines(b) BIO_ctrl(b,BIO_CTRL_GET,0,NULL) | 471 | #define BIO_buffer_get_num_lines(b) BIO_ctrl(b,BIO_CTRL_GET,0,NULL) |
@@ -465,6 +475,7 @@ size_t BIO_ctrl_wpending(BIO *b); | |||
465 | #define BIO_get_write_buf_size(b,size) (size_t)BIO_ctrl(b,BIO_C_GET_WRITE_BUF_SIZE,size,NULL) | 475 | #define BIO_get_write_buf_size(b,size) (size_t)BIO_ctrl(b,BIO_C_GET_WRITE_BUF_SIZE,size,NULL) |
466 | #define BIO_make_bio_pair(b1,b2) (int)BIO_ctrl(b1,BIO_C_MAKE_BIO_PAIR,0,b2) | 476 | #define BIO_make_bio_pair(b1,b2) (int)BIO_ctrl(b1,BIO_C_MAKE_BIO_PAIR,0,b2) |
467 | #define BIO_destroy_bio_pair(b) (int)BIO_ctrl(b,BIO_C_DESTROY_BIO_PAIR,0,NULL) | 477 | #define BIO_destroy_bio_pair(b) (int)BIO_ctrl(b,BIO_C_DESTROY_BIO_PAIR,0,NULL) |
478 | #define BIO_shutdown_wr(b) (int)BIO_ctrl(b, BIO_C_SHUTDOWN_WR, 0, NULL) | ||
468 | /* macros with inappropriate type -- but ...pending macros use int too: */ | 479 | /* macros with inappropriate type -- but ...pending macros use int too: */ |
469 | #define BIO_get_write_guarantee(b) (int)BIO_ctrl(b,BIO_C_GET_WRITE_GUARANTEE,0,NULL) | 480 | #define BIO_get_write_guarantee(b) (int)BIO_ctrl(b,BIO_C_GET_WRITE_GUARANTEE,0,NULL) |
470 | #define BIO_get_read_request(b) (int)BIO_ctrl(b,BIO_C_GET_READ_REQUEST,0,NULL) | 481 | #define BIO_get_read_request(b) (int)BIO_ctrl(b,BIO_C_GET_READ_REQUEST,0,NULL) |
@@ -472,11 +483,6 @@ size_t BIO_ctrl_get_write_guarantee(BIO *b); | |||
472 | size_t BIO_ctrl_get_read_request(BIO *b); | 483 | size_t BIO_ctrl_get_read_request(BIO *b); |
473 | int BIO_ctrl_reset_read_request(BIO *b); | 484 | int BIO_ctrl_reset_read_request(BIO *b); |
474 | 485 | ||
475 | #ifdef NO_STDIO | ||
476 | #define NO_FP_API | ||
477 | #endif | ||
478 | |||
479 | |||
480 | /* These two aren't currently implemented */ | 486 | /* These two aren't currently implemented */ |
481 | /* int BIO_get_ex_num(BIO *bio); */ | 487 | /* int BIO_get_ex_num(BIO *bio); */ |
482 | /* void BIO_set_ex_free_func(BIO *bio,int idx,void (*cb)()); */ | 488 | /* void BIO_set_ex_free_func(BIO *bio,int idx,void (*cb)()); */ |
@@ -487,6 +493,7 @@ int BIO_get_ex_new_index(long argl, void *argp, CRYPTO_EX_new *new_func, | |||
487 | unsigned long BIO_number_read(BIO *bio); | 493 | unsigned long BIO_number_read(BIO *bio); |
488 | unsigned long BIO_number_written(BIO *bio); | 494 | unsigned long BIO_number_written(BIO *bio); |
489 | 495 | ||
496 | # ifndef NO_FP_API | ||
490 | # if defined(WIN16) && defined(_WINDLL) | 497 | # if defined(WIN16) && defined(_WINDLL) |
491 | BIO_METHOD *BIO_s_file_internal(void); | 498 | BIO_METHOD *BIO_s_file_internal(void); |
492 | BIO *BIO_new_file_internal(char *filename, char *mode); | 499 | BIO *BIO_new_file_internal(char *filename, char *mode); |
@@ -502,21 +509,24 @@ BIO *BIO_new_fp(FILE *stream, int close_flag); | |||
502 | # define BIO_new_file_internal BIO_new_file | 509 | # define BIO_new_file_internal BIO_new_file |
503 | # define BIO_new_fp_internal BIO_s_file | 510 | # define BIO_new_fp_internal BIO_s_file |
504 | # endif /* FP_API */ | 511 | # endif /* FP_API */ |
512 | # endif | ||
505 | BIO * BIO_new(BIO_METHOD *type); | 513 | BIO * BIO_new(BIO_METHOD *type); |
506 | int BIO_set(BIO *a,BIO_METHOD *type); | 514 | int BIO_set(BIO *a,BIO_METHOD *type); |
507 | int BIO_free(BIO *a); | 515 | int BIO_free(BIO *a); |
516 | void BIO_vfree(BIO *a); | ||
508 | int BIO_read(BIO *b, void *data, int len); | 517 | int BIO_read(BIO *b, void *data, int len); |
509 | int BIO_gets(BIO *bp,char *buf, int size); | 518 | int BIO_gets(BIO *bp,char *buf, int size); |
510 | int BIO_write(BIO *b, const void *data, int len); | 519 | int BIO_write(BIO *b, const void *data, int len); |
511 | int BIO_puts(BIO *bp,const char *buf); | 520 | int BIO_puts(BIO *bp,const char *buf); |
512 | long BIO_ctrl(BIO *bp,int cmd,long larg,void *parg); | 521 | long BIO_ctrl(BIO *bp,int cmd,long larg,void *parg); |
513 | long BIO_callback_ctrl(BIO *bp,int cmd,void (*fp)()); | 522 | long BIO_callback_ctrl(BIO *b, int cmd, void (*fp)(struct bio_st *, int, const char *, int, long, long)); |
514 | char * BIO_ptr_ctrl(BIO *bp,int cmd,long larg); | 523 | char * BIO_ptr_ctrl(BIO *bp,int cmd,long larg); |
515 | long BIO_int_ctrl(BIO *bp,int cmd,long larg,int iarg); | 524 | long BIO_int_ctrl(BIO *bp,int cmd,long larg,int iarg); |
516 | BIO * BIO_push(BIO *b,BIO *append); | 525 | BIO * BIO_push(BIO *b,BIO *append); |
517 | BIO * BIO_pop(BIO *b); | 526 | BIO * BIO_pop(BIO *b); |
518 | void BIO_free_all(BIO *a); | 527 | void BIO_free_all(BIO *a); |
519 | BIO * BIO_find_type(BIO *b,int bio_type); | 528 | BIO * BIO_find_type(BIO *b,int bio_type); |
529 | BIO * BIO_next(BIO *b); | ||
520 | BIO * BIO_get_retry_BIO(BIO *bio, int *reason); | 530 | BIO * BIO_get_retry_BIO(BIO *bio, int *reason); |
521 | int BIO_get_retry_reason(BIO *bio); | 531 | int BIO_get_retry_reason(BIO *bio); |
522 | BIO * BIO_dup_chain(BIO *in); | 532 | BIO * BIO_dup_chain(BIO *in); |
@@ -545,6 +555,9 @@ BIO_METHOD *BIO_s_bio(void); | |||
545 | BIO_METHOD *BIO_s_null(void); | 555 | BIO_METHOD *BIO_s_null(void); |
546 | BIO_METHOD *BIO_f_null(void); | 556 | BIO_METHOD *BIO_f_null(void); |
547 | BIO_METHOD *BIO_f_buffer(void); | 557 | BIO_METHOD *BIO_f_buffer(void); |
558 | #ifdef VMS | ||
559 | BIO_METHOD *BIO_f_linebuffer(void); | ||
560 | #endif | ||
548 | BIO_METHOD *BIO_f_nbio_test(void); | 561 | BIO_METHOD *BIO_f_nbio_test(void); |
549 | /* BIO_METHOD *BIO_f_ber(void); */ | 562 | /* BIO_METHOD *BIO_f_ber(void); */ |
550 | 563 | ||
@@ -553,6 +566,7 @@ int BIO_sock_non_fatal_error(int error); | |||
553 | int BIO_fd_should_retry(int i); | 566 | int BIO_fd_should_retry(int i); |
554 | int BIO_fd_non_fatal_error(int error); | 567 | int BIO_fd_non_fatal_error(int error); |
555 | int BIO_dump(BIO *b,const char *bytes,int len); | 568 | int BIO_dump(BIO *b,const char *bytes,int len); |
569 | int BIO_dump_indent(BIO *b,const char *bytes,int len,int indent); | ||
556 | 570 | ||
557 | struct hostent *BIO_gethostbyname(const char *name); | 571 | struct hostent *BIO_gethostbyname(const char *name); |
558 | /* We might want a thread-safe interface too: | 572 | /* We might want a thread-safe interface too: |
@@ -592,7 +606,10 @@ void BIO_copy_next_retry(BIO *b); | |||
592 | 606 | ||
593 | long BIO_ghbn_ctrl(int cmd,int iarg,char *parg); | 607 | long BIO_ghbn_ctrl(int cmd,int iarg,char *parg); |
594 | 608 | ||
595 | int BIO_printf(BIO *bio, ...); | 609 | int BIO_printf(BIO *bio, const char *format, ...); |
610 | int BIO_vprintf(BIO *bio, const char *format, va_list args); | ||
611 | int BIO_snprintf(char *buf, size_t n, const char *format, ...); | ||
612 | int BIO_vsnprintf(char *buf, size_t n, const char *format, va_list args); | ||
596 | 613 | ||
597 | /* BEGIN ERROR CODES */ | 614 | /* BEGIN ERROR CODES */ |
598 | /* The following lines are auto generated by the script mkerr.pl. Any changes | 615 | /* The following lines are auto generated by the script mkerr.pl. Any changes |
@@ -627,6 +644,8 @@ int BIO_printf(BIO *bio, ...); | |||
627 | #define BIO_F_CONN_CTRL 127 | 644 | #define BIO_F_CONN_CTRL 127 |
628 | #define BIO_F_CONN_STATE 115 | 645 | #define BIO_F_CONN_STATE 115 |
629 | #define BIO_F_FILE_CTRL 116 | 646 | #define BIO_F_FILE_CTRL 116 |
647 | #define BIO_F_LINEBUFFER_CTRL 129 | ||
648 | #define BIO_F_MEM_READ 128 | ||
630 | #define BIO_F_MEM_WRITE 117 | 649 | #define BIO_F_MEM_WRITE 117 |
631 | #define BIO_F_SSL_NEW 118 | 650 | #define BIO_F_SSL_NEW 118 |
632 | #define BIO_F_WSASTARTUP 119 | 651 | #define BIO_F_WSASTARTUP 119 |
@@ -637,6 +656,7 @@ int BIO_printf(BIO *bio, ...); | |||
637 | #define BIO_R_BAD_HOSTNAME_LOOKUP 102 | 656 | #define BIO_R_BAD_HOSTNAME_LOOKUP 102 |
638 | #define BIO_R_BROKEN_PIPE 124 | 657 | #define BIO_R_BROKEN_PIPE 124 |
639 | #define BIO_R_CONNECT_ERROR 103 | 658 | #define BIO_R_CONNECT_ERROR 103 |
659 | #define BIO_R_EOF_ON_MEMORY_BIO 127 | ||
640 | #define BIO_R_ERROR_SETTING_NBIO 104 | 660 | #define BIO_R_ERROR_SETTING_NBIO 104 |
641 | #define BIO_R_ERROR_SETTING_NBIO_ON_ACCEPTED_SOCKET 105 | 661 | #define BIO_R_ERROR_SETTING_NBIO_ON_ACCEPTED_SOCKET 105 |
642 | #define BIO_R_ERROR_SETTING_NBIO_ON_ACCEPT_SOCKET 106 | 662 | #define BIO_R_ERROR_SETTING_NBIO_ON_ACCEPT_SOCKET 106 |
diff --git a/src/lib/libcrypto/bio/bio_err.c b/src/lib/libcrypto/bio/bio_err.c index f38e7b9178..bb815fb1e6 100644 --- a/src/lib/libcrypto/bio/bio_err.c +++ b/src/lib/libcrypto/bio/bio_err.c | |||
@@ -91,6 +91,8 @@ static ERR_STRING_DATA BIO_str_functs[]= | |||
91 | {ERR_PACK(0,BIO_F_CONN_CTRL,0), "CONN_CTRL"}, | 91 | {ERR_PACK(0,BIO_F_CONN_CTRL,0), "CONN_CTRL"}, |
92 | {ERR_PACK(0,BIO_F_CONN_STATE,0), "CONN_STATE"}, | 92 | {ERR_PACK(0,BIO_F_CONN_STATE,0), "CONN_STATE"}, |
93 | {ERR_PACK(0,BIO_F_FILE_CTRL,0), "FILE_CTRL"}, | 93 | {ERR_PACK(0,BIO_F_FILE_CTRL,0), "FILE_CTRL"}, |
94 | {ERR_PACK(0,BIO_F_LINEBUFFER_CTRL,0), "LINEBUFFER_CTRL"}, | ||
95 | {ERR_PACK(0,BIO_F_MEM_READ,0), "MEM_READ"}, | ||
94 | {ERR_PACK(0,BIO_F_MEM_WRITE,0), "MEM_WRITE"}, | 96 | {ERR_PACK(0,BIO_F_MEM_WRITE,0), "MEM_WRITE"}, |
95 | {ERR_PACK(0,BIO_F_SSL_NEW,0), "SSL_new"}, | 97 | {ERR_PACK(0,BIO_F_SSL_NEW,0), "SSL_new"}, |
96 | {ERR_PACK(0,BIO_F_WSASTARTUP,0), "WSASTARTUP"}, | 98 | {ERR_PACK(0,BIO_F_WSASTARTUP,0), "WSASTARTUP"}, |
@@ -104,6 +106,7 @@ static ERR_STRING_DATA BIO_str_reasons[]= | |||
104 | {BIO_R_BAD_HOSTNAME_LOOKUP ,"bad hostname lookup"}, | 106 | {BIO_R_BAD_HOSTNAME_LOOKUP ,"bad hostname lookup"}, |
105 | {BIO_R_BROKEN_PIPE ,"broken pipe"}, | 107 | {BIO_R_BROKEN_PIPE ,"broken pipe"}, |
106 | {BIO_R_CONNECT_ERROR ,"connect error"}, | 108 | {BIO_R_CONNECT_ERROR ,"connect error"}, |
109 | {BIO_R_EOF_ON_MEMORY_BIO ,"EOF on memory BIO"}, | ||
107 | {BIO_R_ERROR_SETTING_NBIO ,"error setting nbio"}, | 110 | {BIO_R_ERROR_SETTING_NBIO ,"error setting nbio"}, |
108 | {BIO_R_ERROR_SETTING_NBIO_ON_ACCEPTED_SOCKET,"error setting nbio on accepted socket"}, | 111 | {BIO_R_ERROR_SETTING_NBIO_ON_ACCEPTED_SOCKET,"error setting nbio on accepted socket"}, |
109 | {BIO_R_ERROR_SETTING_NBIO_ON_ACCEPT_SOCKET,"error setting nbio on accept socket"}, | 112 | {BIO_R_ERROR_SETTING_NBIO_ON_ACCEPT_SOCKET,"error setting nbio on accept socket"}, |
@@ -124,8 +127,8 @@ static ERR_STRING_DATA BIO_str_reasons[]= | |||
124 | {BIO_R_UNABLE_TO_LISTEN_SOCKET ,"unable to listen socket"}, | 127 | {BIO_R_UNABLE_TO_LISTEN_SOCKET ,"unable to listen socket"}, |
125 | {BIO_R_UNINITIALIZED ,"uninitialized"}, | 128 | {BIO_R_UNINITIALIZED ,"uninitialized"}, |
126 | {BIO_R_UNSUPPORTED_METHOD ,"unsupported method"}, | 129 | {BIO_R_UNSUPPORTED_METHOD ,"unsupported method"}, |
127 | {BIO_R_WRITE_TO_READ_ONLY_BIO ,"write to read only bio"}, | 130 | {BIO_R_WRITE_TO_READ_ONLY_BIO ,"write to read only BIO"}, |
128 | {BIO_R_WSASTARTUP ,"wsastartup"}, | 131 | {BIO_R_WSASTARTUP ,"WSAStartup"}, |
129 | {0,NULL} | 132 | {0,NULL} |
130 | }; | 133 | }; |
131 | 134 | ||
diff --git a/src/lib/libcrypto/bio/bio_lib.c b/src/lib/libcrypto/bio/bio_lib.c index e88dcc80f3..381afc9b8e 100644 --- a/src/lib/libcrypto/bio/bio_lib.c +++ b/src/lib/libcrypto/bio/bio_lib.c | |||
@@ -70,7 +70,7 @@ BIO *BIO_new(BIO_METHOD *method) | |||
70 | { | 70 | { |
71 | BIO *ret=NULL; | 71 | BIO *ret=NULL; |
72 | 72 | ||
73 | ret=(BIO *)Malloc(sizeof(BIO)); | 73 | ret=(BIO *)OPENSSL_malloc(sizeof(BIO)); |
74 | if (ret == NULL) | 74 | if (ret == NULL) |
75 | { | 75 | { |
76 | BIOerr(BIO_F_BIO_NEW,ERR_R_MALLOC_FAILURE); | 76 | BIOerr(BIO_F_BIO_NEW,ERR_R_MALLOC_FAILURE); |
@@ -78,7 +78,7 @@ BIO *BIO_new(BIO_METHOD *method) | |||
78 | } | 78 | } |
79 | if (!BIO_set(ret,method)) | 79 | if (!BIO_set(ret,method)) |
80 | { | 80 | { |
81 | Free(ret); | 81 | OPENSSL_free(ret); |
82 | ret=NULL; | 82 | ret=NULL; |
83 | } | 83 | } |
84 | return(ret); | 84 | return(ret); |
@@ -133,10 +133,13 @@ int BIO_free(BIO *a) | |||
133 | 133 | ||
134 | if ((a->method == NULL) || (a->method->destroy == NULL)) return(1); | 134 | if ((a->method == NULL) || (a->method->destroy == NULL)) return(1); |
135 | ret=a->method->destroy(a); | 135 | ret=a->method->destroy(a); |
136 | Free(a); | 136 | OPENSSL_free(a); |
137 | return(1); | 137 | return(1); |
138 | } | 138 | } |
139 | 139 | ||
140 | void BIO_vfree(BIO *a) | ||
141 | { BIO_free(a); } | ||
142 | |||
140 | int BIO_read(BIO *b, void *out, int outl) | 143 | int BIO_read(BIO *b, void *out, int outl) |
141 | { | 144 | { |
142 | int i; | 145 | int i; |
@@ -198,13 +201,7 @@ int BIO_write(BIO *b, const void *in, int inl) | |||
198 | 201 | ||
199 | if (i > 0) b->num_write+=(unsigned long)i; | 202 | if (i > 0) b->num_write+=(unsigned long)i; |
200 | 203 | ||
201 | /* This is evil and not thread safe. If the BIO has been freed, | 204 | if (cb != NULL) |
202 | * we must not call the callback. The only way to be able to | ||
203 | * determine this is the reference count which is now invalid since | ||
204 | * the memory has been free()ed. | ||
205 | */ | ||
206 | if (b->references <= 0) abort(); | ||
207 | if (cb != NULL) /* && (b->references >= 1)) */ | ||
208 | i=(int)cb(b,BIO_CB_WRITE|BIO_CB_RETURN,in,inl, | 205 | i=(int)cb(b,BIO_CB_WRITE|BIO_CB_RETURN,in,inl, |
209 | 0L,(long)i); | 206 | 0L,(long)i); |
210 | return(i); | 207 | return(i); |
@@ -235,6 +232,8 @@ int BIO_puts(BIO *b, const char *in) | |||
235 | 232 | ||
236 | i=b->method->bputs(b,in); | 233 | i=b->method->bputs(b,in); |
237 | 234 | ||
235 | if (i > 0) b->num_write+=(unsigned long)i; | ||
236 | |||
238 | if (cb != NULL) | 237 | if (cb != NULL) |
239 | i=(int)cb(b,BIO_CB_PUTS|BIO_CB_RETURN,in,0, | 238 | i=(int)cb(b,BIO_CB_PUTS|BIO_CB_RETURN,in,0, |
240 | 0L,(long)i); | 239 | 0L,(long)i); |
@@ -317,7 +316,7 @@ long BIO_ctrl(BIO *b, int cmd, long larg, void *parg) | |||
317 | return(ret); | 316 | return(ret); |
318 | } | 317 | } |
319 | 318 | ||
320 | long BIO_callback_ctrl(BIO *b, int cmd, void (*fp)()) | 319 | long BIO_callback_ctrl(BIO *b, int cmd, void (*fp)(struct bio_st *, int, const char *, int, long, long)) |
321 | { | 320 | { |
322 | long ret; | 321 | long ret; |
323 | long (*cb)(); | 322 | long (*cb)(); |
@@ -419,6 +418,7 @@ BIO *BIO_find_type(BIO *bio, int type) | |||
419 | { | 418 | { |
420 | int mt,mask; | 419 | int mt,mask; |
421 | 420 | ||
421 | if(!bio) return NULL; | ||
422 | mask=type&0xff; | 422 | mask=type&0xff; |
423 | do { | 423 | do { |
424 | if (bio->method != NULL) | 424 | if (bio->method != NULL) |
@@ -437,6 +437,12 @@ BIO *BIO_find_type(BIO *bio, int type) | |||
437 | return(NULL); | 437 | return(NULL); |
438 | } | 438 | } |
439 | 439 | ||
440 | BIO *BIO_next(BIO *b) | ||
441 | { | ||
442 | if(!b) return NULL; | ||
443 | return b->next_bio; | ||
444 | } | ||
445 | |||
440 | void BIO_free_all(BIO *bio) | 446 | void BIO_free_all(BIO *bio) |
441 | { | 447 | { |
442 | BIO *b; | 448 | BIO *b; |
@@ -532,3 +538,5 @@ unsigned long BIO_number_written(BIO *bio) | |||
532 | if(bio) return bio->num_write; | 538 | if(bio) return bio->num_write; |
533 | return 0; | 539 | return 0; |
534 | } | 540 | } |
541 | |||
542 | IMPLEMENT_STACK_OF(BIO) | ||
diff --git a/src/lib/libcrypto/bio/bss_acpt.c b/src/lib/libcrypto/bio/bss_acpt.c index 9afa636406..4da5822062 100644 --- a/src/lib/libcrypto/bio/bss_acpt.c +++ b/src/lib/libcrypto/bio/bss_acpt.c | |||
@@ -92,10 +92,10 @@ typedef struct bio_accept_st | |||
92 | BIO *bio_chain; | 92 | BIO *bio_chain; |
93 | } BIO_ACCEPT; | 93 | } BIO_ACCEPT; |
94 | 94 | ||
95 | static int acpt_write(BIO *h,char *buf,int num); | 95 | static int acpt_write(BIO *h, const char *buf, int num); |
96 | static int acpt_read(BIO *h,char *buf,int size); | 96 | static int acpt_read(BIO *h, char *buf, int size); |
97 | static int acpt_puts(BIO *h,char *str); | 97 | static int acpt_puts(BIO *h, const char *str); |
98 | static long acpt_ctrl(BIO *h,int cmd,long arg1,char *arg2); | 98 | static long acpt_ctrl(BIO *h, int cmd, long arg1, void *arg2); |
99 | static int acpt_new(BIO *h); | 99 | static int acpt_new(BIO *h); |
100 | static int acpt_free(BIO *data); | 100 | static int acpt_free(BIO *data); |
101 | static int acpt_state(BIO *b, BIO_ACCEPT *c); | 101 | static int acpt_state(BIO *b, BIO_ACCEPT *c); |
@@ -145,7 +145,7 @@ BIO_ACCEPT *BIO_ACCEPT_new(void) | |||
145 | { | 145 | { |
146 | BIO_ACCEPT *ret; | 146 | BIO_ACCEPT *ret; |
147 | 147 | ||
148 | if ((ret=(BIO_ACCEPT *)Malloc(sizeof(BIO_ACCEPT))) == NULL) | 148 | if ((ret=(BIO_ACCEPT *)OPENSSL_malloc(sizeof(BIO_ACCEPT))) == NULL) |
149 | return(NULL); | 149 | return(NULL); |
150 | 150 | ||
151 | memset(ret,0,sizeof(BIO_ACCEPT)); | 151 | memset(ret,0,sizeof(BIO_ACCEPT)); |
@@ -159,10 +159,10 @@ void BIO_ACCEPT_free(BIO_ACCEPT *a) | |||
159 | if(a == NULL) | 159 | if(a == NULL) |
160 | return; | 160 | return; |
161 | 161 | ||
162 | if (a->param_addr != NULL) Free(a->param_addr); | 162 | if (a->param_addr != NULL) OPENSSL_free(a->param_addr); |
163 | if (a->addr != NULL) Free(a->addr); | 163 | if (a->addr != NULL) OPENSSL_free(a->addr); |
164 | if (a->bio_chain != NULL) BIO_free(a->bio_chain); | 164 | if (a->bio_chain != NULL) BIO_free(a->bio_chain); |
165 | Free(a); | 165 | OPENSSL_free(a); |
166 | } | 166 | } |
167 | 167 | ||
168 | static void acpt_close_socket(BIO *bio) | 168 | static void acpt_close_socket(BIO *bio) |
@@ -307,7 +307,7 @@ static int acpt_read(BIO *b, char *out, int outl) | |||
307 | return(ret); | 307 | return(ret); |
308 | } | 308 | } |
309 | 309 | ||
310 | static int acpt_write(BIO *b, char *in, int inl) | 310 | static int acpt_write(BIO *b, const char *in, int inl) |
311 | { | 311 | { |
312 | int ret; | 312 | int ret; |
313 | BIO_ACCEPT *data; | 313 | BIO_ACCEPT *data; |
@@ -326,7 +326,7 @@ static int acpt_write(BIO *b, char *in, int inl) | |||
326 | return(ret); | 326 | return(ret); |
327 | } | 327 | } |
328 | 328 | ||
329 | static long acpt_ctrl(BIO *b, int cmd, long num, char *ptr) | 329 | static long acpt_ctrl(BIO *b, int cmd, long num, void *ptr) |
330 | { | 330 | { |
331 | BIO *dbio; | 331 | BIO *dbio; |
332 | int *ip; | 332 | int *ip; |
@@ -355,7 +355,7 @@ static long acpt_ctrl(BIO *b, int cmd, long num, char *ptr) | |||
355 | { | 355 | { |
356 | b->init=1; | 356 | b->init=1; |
357 | if (data->param_addr != NULL) | 357 | if (data->param_addr != NULL) |
358 | Free(data->param_addr); | 358 | OPENSSL_free(data->param_addr); |
359 | data->param_addr=BUF_strdup(ptr); | 359 | data->param_addr=BUF_strdup(ptr); |
360 | } | 360 | } |
361 | else if (num == 1) | 361 | else if (num == 1) |
@@ -440,7 +440,7 @@ static long acpt_ctrl(BIO *b, int cmd, long num, char *ptr) | |||
440 | return(ret); | 440 | return(ret); |
441 | } | 441 | } |
442 | 442 | ||
443 | static int acpt_puts(BIO *bp, char *str) | 443 | static int acpt_puts(BIO *bp, const char *str) |
444 | { | 444 | { |
445 | int n,ret; | 445 | int n,ret; |
446 | 446 | ||
diff --git a/src/lib/libcrypto/bio/bss_bio.c b/src/lib/libcrypto/bio/bss_bio.c index 1e2d7491f2..78c6ab4fdd 100644 --- a/src/lib/libcrypto/bio/bss_bio.c +++ b/src/lib/libcrypto/bio/bss_bio.c | |||
@@ -30,9 +30,9 @@ | |||
30 | static int bio_new(BIO *bio); | 30 | static int bio_new(BIO *bio); |
31 | static int bio_free(BIO *bio); | 31 | static int bio_free(BIO *bio); |
32 | static int bio_read(BIO *bio, char *buf, int size); | 32 | static int bio_read(BIO *bio, char *buf, int size); |
33 | static int bio_write(BIO *bio, char *buf, int num); | 33 | static int bio_write(BIO *bio, const char *buf, int num); |
34 | static long bio_ctrl(BIO *bio, int cmd, long num, void *ptr); | 34 | static long bio_ctrl(BIO *bio, int cmd, long num, void *ptr); |
35 | static int bio_puts(BIO *bio, char *str); | 35 | static int bio_puts(BIO *bio, const char *str); |
36 | 36 | ||
37 | static int bio_make_pair(BIO *bio1, BIO *bio2); | 37 | static int bio_make_pair(BIO *bio1, BIO *bio2); |
38 | static void bio_destroy_pair(BIO *bio); | 38 | static void bio_destroy_pair(BIO *bio); |
@@ -80,7 +80,7 @@ static int bio_new(BIO *bio) | |||
80 | { | 80 | { |
81 | struct bio_bio_st *b; | 81 | struct bio_bio_st *b; |
82 | 82 | ||
83 | b = Malloc(sizeof *b); | 83 | b = OPENSSL_malloc(sizeof *b); |
84 | if (b == NULL) | 84 | if (b == NULL) |
85 | return 0; | 85 | return 0; |
86 | 86 | ||
@@ -108,10 +108,10 @@ static int bio_free(BIO *bio) | |||
108 | 108 | ||
109 | if (b->buf != NULL) | 109 | if (b->buf != NULL) |
110 | { | 110 | { |
111 | Free(b->buf); | 111 | OPENSSL_free(b->buf); |
112 | } | 112 | } |
113 | 113 | ||
114 | Free(b); | 114 | OPENSSL_free(b); |
115 | 115 | ||
116 | return 1; | 116 | return 1; |
117 | } | 117 | } |
@@ -283,7 +283,7 @@ static ssize_t bio_nread(BIO *bio, char **buf, size_t num_) | |||
283 | } | 283 | } |
284 | 284 | ||
285 | 285 | ||
286 | static int bio_write(BIO *bio, char *buf, int num_) | 286 | static int bio_write(BIO *bio, const char *buf, int num_) |
287 | { | 287 | { |
288 | size_t num = num_; | 288 | size_t num = num_; |
289 | size_t rest; | 289 | size_t rest; |
@@ -464,7 +464,7 @@ static long bio_ctrl(BIO *bio, int cmd, long num, void *ptr) | |||
464 | { | 464 | { |
465 | if (b->buf) | 465 | if (b->buf) |
466 | { | 466 | { |
467 | Free(b->buf); | 467 | OPENSSL_free(b->buf); |
468 | b->buf = NULL; | 468 | b->buf = NULL; |
469 | } | 469 | } |
470 | b->size = new_size; | 470 | b->size = new_size; |
@@ -628,7 +628,7 @@ static long bio_ctrl(BIO *bio, int cmd, long num, void *ptr) | |||
628 | return ret; | 628 | return ret; |
629 | } | 629 | } |
630 | 630 | ||
631 | static int bio_puts(BIO *bio, char *str) | 631 | static int bio_puts(BIO *bio, const char *str) |
632 | { | 632 | { |
633 | return bio_write(bio, str, strlen(str)); | 633 | return bio_write(bio, str, strlen(str)); |
634 | } | 634 | } |
@@ -652,7 +652,7 @@ static int bio_make_pair(BIO *bio1, BIO *bio2) | |||
652 | 652 | ||
653 | if (b1->buf == NULL) | 653 | if (b1->buf == NULL) |
654 | { | 654 | { |
655 | b1->buf = Malloc(b1->size); | 655 | b1->buf = OPENSSL_malloc(b1->size); |
656 | if (b1->buf == NULL) | 656 | if (b1->buf == NULL) |
657 | { | 657 | { |
658 | BIOerr(BIO_F_BIO_MAKE_PAIR, ERR_R_MALLOC_FAILURE); | 658 | BIOerr(BIO_F_BIO_MAKE_PAIR, ERR_R_MALLOC_FAILURE); |
@@ -664,7 +664,7 @@ static int bio_make_pair(BIO *bio1, BIO *bio2) | |||
664 | 664 | ||
665 | if (b2->buf == NULL) | 665 | if (b2->buf == NULL) |
666 | { | 666 | { |
667 | b2->buf = Malloc(b2->size); | 667 | b2->buf = OPENSSL_malloc(b2->size); |
668 | if (b2->buf == NULL) | 668 | if (b2->buf == NULL) |
669 | { | 669 | { |
670 | BIOerr(BIO_F_BIO_MAKE_PAIR, ERR_R_MALLOC_FAILURE); | 670 | BIOerr(BIO_F_BIO_MAKE_PAIR, ERR_R_MALLOC_FAILURE); |
diff --git a/src/lib/libcrypto/bio/bss_conn.c b/src/lib/libcrypto/bio/bss_conn.c index 22d00b369e..a6b77a2cb9 100644 --- a/src/lib/libcrypto/bio/bss_conn.c +++ b/src/lib/libcrypto/bio/bss_conn.c | |||
@@ -98,13 +98,13 @@ typedef struct bio_connect_st | |||
98 | int (*info_callback)(); | 98 | int (*info_callback)(); |
99 | } BIO_CONNECT; | 99 | } BIO_CONNECT; |
100 | 100 | ||
101 | static int conn_write(BIO *h,char *buf,int num); | 101 | static int conn_write(BIO *h, const char *buf, int num); |
102 | static int conn_read(BIO *h,char *buf,int size); | 102 | static int conn_read(BIO *h, char *buf, int size); |
103 | static int conn_puts(BIO *h,char *str); | 103 | static int conn_puts(BIO *h, const char *str); |
104 | static long conn_ctrl(BIO *h,int cmd,long arg1,char *arg2); | 104 | static long conn_ctrl(BIO *h, int cmd, long arg1, void *arg2); |
105 | static int conn_new(BIO *h); | 105 | static int conn_new(BIO *h); |
106 | static int conn_free(BIO *data); | 106 | static int conn_free(BIO *data); |
107 | static long conn_callback_ctrl(BIO *h,int cmd,void *(*fp)()); | 107 | static long conn_callback_ctrl(BIO *h, int cmd, bio_info_cb *); |
108 | 108 | ||
109 | static int conn_state(BIO *b, BIO_CONNECT *c); | 109 | static int conn_state(BIO *b, BIO_CONNECT *c); |
110 | static void conn_close_socket(BIO *data); | 110 | static void conn_close_socket(BIO *data); |
@@ -165,7 +165,7 @@ static int conn_state(BIO *b, BIO_CONNECT *c) | |||
165 | break; | 165 | break; |
166 | } | 166 | } |
167 | if (c->param_port != NULL) | 167 | if (c->param_port != NULL) |
168 | Free(c->param_port); | 168 | OPENSSL_free(c->param_port); |
169 | c->param_port=BUF_strdup(p); | 169 | c->param_port=BUF_strdup(p); |
170 | } | 170 | } |
171 | } | 171 | } |
@@ -188,7 +188,7 @@ static int conn_state(BIO *b, BIO_CONNECT *c) | |||
188 | case BIO_CONN_S_GET_PORT: | 188 | case BIO_CONN_S_GET_PORT: |
189 | if (c->param_port == NULL) | 189 | if (c->param_port == NULL) |
190 | { | 190 | { |
191 | abort(); | 191 | /* abort(); */ |
192 | goto exit_loop; | 192 | goto exit_loop; |
193 | } | 193 | } |
194 | else if (BIO_get_port(c->param_port,&c->port) <= 0) | 194 | else if (BIO_get_port(c->param_port,&c->port) <= 0) |
@@ -236,7 +236,7 @@ static int conn_state(BIO *b, BIO_CONNECT *c) | |||
236 | } | 236 | } |
237 | c->state=BIO_CONN_S_CONNECT; | 237 | c->state=BIO_CONN_S_CONNECT; |
238 | 238 | ||
239 | #ifdef SO_KEEPALIVE | 239 | #if defined(SO_KEEPALIVE) && !defined(MPE) |
240 | i=1; | 240 | i=1; |
241 | i=setsockopt(b->num,SOL_SOCKET,SO_KEEPALIVE,(char *)&i,sizeof(i)); | 241 | i=setsockopt(b->num,SOL_SOCKET,SO_KEEPALIVE,(char *)&i,sizeof(i)); |
242 | if (i < 0) | 242 | if (i < 0) |
@@ -299,7 +299,7 @@ static int conn_state(BIO *b, BIO_CONNECT *c) | |||
299 | ret=1; | 299 | ret=1; |
300 | goto exit_loop; | 300 | goto exit_loop; |
301 | default: | 301 | default: |
302 | abort(); | 302 | /* abort(); */ |
303 | goto exit_loop; | 303 | goto exit_loop; |
304 | } | 304 | } |
305 | 305 | ||
@@ -322,7 +322,7 @@ BIO_CONNECT *BIO_CONNECT_new(void) | |||
322 | { | 322 | { |
323 | BIO_CONNECT *ret; | 323 | BIO_CONNECT *ret; |
324 | 324 | ||
325 | if ((ret=(BIO_CONNECT *)Malloc(sizeof(BIO_CONNECT))) == NULL) | 325 | if ((ret=(BIO_CONNECT *)OPENSSL_malloc(sizeof(BIO_CONNECT))) == NULL) |
326 | return(NULL); | 326 | return(NULL); |
327 | ret->state=BIO_CONN_S_BEFORE; | 327 | ret->state=BIO_CONN_S_BEFORE; |
328 | ret->param_hostname=NULL; | 328 | ret->param_hostname=NULL; |
@@ -344,10 +344,10 @@ void BIO_CONNECT_free(BIO_CONNECT *a) | |||
344 | return; | 344 | return; |
345 | 345 | ||
346 | if (a->param_hostname != NULL) | 346 | if (a->param_hostname != NULL) |
347 | Free(a->param_hostname); | 347 | OPENSSL_free(a->param_hostname); |
348 | if (a->param_port != NULL) | 348 | if (a->param_port != NULL) |
349 | Free(a->param_port); | 349 | OPENSSL_free(a->param_port); |
350 | Free(a); | 350 | OPENSSL_free(a); |
351 | } | 351 | } |
352 | 352 | ||
353 | BIO_METHOD *BIO_s_connect(void) | 353 | BIO_METHOD *BIO_s_connect(void) |
@@ -426,7 +426,7 @@ static int conn_read(BIO *b, char *out, int outl) | |||
426 | return(ret); | 426 | return(ret); |
427 | } | 427 | } |
428 | 428 | ||
429 | static int conn_write(BIO *b, char *in, int inl) | 429 | static int conn_write(BIO *b, const char *in, int inl) |
430 | { | 430 | { |
431 | int ret; | 431 | int ret; |
432 | BIO_CONNECT *data; | 432 | BIO_CONNECT *data; |
@@ -449,7 +449,7 @@ static int conn_write(BIO *b, char *in, int inl) | |||
449 | return(ret); | 449 | return(ret); |
450 | } | 450 | } |
451 | 451 | ||
452 | static long conn_ctrl(BIO *b, int cmd, long num, char *ptr) | 452 | static long conn_ctrl(BIO *b, int cmd, long num, void *ptr) |
453 | { | 453 | { |
454 | BIO *dbio; | 454 | BIO *dbio; |
455 | int *ip; | 455 | int *ip; |
@@ -507,23 +507,24 @@ static long conn_ctrl(BIO *b, int cmd, long num, char *ptr) | |||
507 | if (num == 0) | 507 | if (num == 0) |
508 | { | 508 | { |
509 | if (data->param_hostname != NULL) | 509 | if (data->param_hostname != NULL) |
510 | Free(data->param_hostname); | 510 | OPENSSL_free(data->param_hostname); |
511 | data->param_hostname=BUF_strdup(ptr); | 511 | data->param_hostname=BUF_strdup(ptr); |
512 | } | 512 | } |
513 | else if (num == 1) | 513 | else if (num == 1) |
514 | { | 514 | { |
515 | if (data->param_port != NULL) | 515 | if (data->param_port != NULL) |
516 | Free(data->param_port); | 516 | OPENSSL_free(data->param_port); |
517 | data->param_port=BUF_strdup(ptr); | 517 | data->param_port=BUF_strdup(ptr); |
518 | } | 518 | } |
519 | else if (num == 2) | 519 | else if (num == 2) |
520 | { | 520 | { |
521 | char buf[16]; | 521 | char buf[16]; |
522 | char *p = ptr; | ||
522 | 523 | ||
523 | sprintf(buf,"%d.%d.%d.%d", | 524 | sprintf(buf,"%d.%d.%d.%d", |
524 | ptr[0],ptr[1],ptr[2],ptr[3]); | 525 | p[0],p[1],p[2],p[3]); |
525 | if (data->param_hostname != NULL) | 526 | if (data->param_hostname != NULL) |
526 | Free(data->param_hostname); | 527 | OPENSSL_free(data->param_hostname); |
527 | data->param_hostname=BUF_strdup(buf); | 528 | data->param_hostname=BUF_strdup(buf); |
528 | memcpy(&(data->ip[0]),ptr,4); | 529 | memcpy(&(data->ip[0]),ptr,4); |
529 | } | 530 | } |
@@ -533,7 +534,7 @@ static long conn_ctrl(BIO *b, int cmd, long num, char *ptr) | |||
533 | 534 | ||
534 | sprintf(buf,"%d",*(int *)ptr); | 535 | sprintf(buf,"%d",*(int *)ptr); |
535 | if (data->param_port != NULL) | 536 | if (data->param_port != NULL) |
536 | Free(data->param_port); | 537 | OPENSSL_free(data->param_port); |
537 | data->param_port=BUF_strdup(buf); | 538 | data->param_port=BUF_strdup(buf); |
538 | data->port= *(int *)ptr; | 539 | data->port= *(int *)ptr; |
539 | } | 540 | } |
@@ -573,7 +574,7 @@ static long conn_ctrl(BIO *b, int cmd, long num, char *ptr) | |||
573 | if (data->param_hostname) | 574 | if (data->param_hostname) |
574 | BIO_set_conn_hostname(dbio,data->param_hostname); | 575 | BIO_set_conn_hostname(dbio,data->param_hostname); |
575 | BIO_set_nbio(dbio,data->nbio); | 576 | BIO_set_nbio(dbio,data->nbio); |
576 | (void)BIO_set_info_callback(dbio,(void *(*)())(data->info_callback)); | 577 | (void)BIO_set_info_callback(dbio,data->info_callback); |
577 | } | 578 | } |
578 | break; | 579 | break; |
579 | case BIO_CTRL_SET_CALLBACK: | 580 | case BIO_CTRL_SET_CALLBACK: |
@@ -601,7 +602,7 @@ static long conn_ctrl(BIO *b, int cmd, long num, char *ptr) | |||
601 | return(ret); | 602 | return(ret); |
602 | } | 603 | } |
603 | 604 | ||
604 | static long conn_callback_ctrl(BIO *b, int cmd, void *(*fp)()) | 605 | static long conn_callback_ctrl(BIO *b, int cmd, bio_info_cb *fp) |
605 | { | 606 | { |
606 | long ret=1; | 607 | long ret=1; |
607 | BIO_CONNECT *data; | 608 | BIO_CONNECT *data; |
@@ -622,7 +623,7 @@ static long conn_callback_ctrl(BIO *b, int cmd, void *(*fp)()) | |||
622 | return(ret); | 623 | return(ret); |
623 | } | 624 | } |
624 | 625 | ||
625 | static int conn_puts(BIO *bp, char *str) | 626 | static int conn_puts(BIO *bp, const char *str) |
626 | { | 627 | { |
627 | int n,ret; | 628 | int n,ret; |
628 | 629 | ||
diff --git a/src/lib/libcrypto/bio/bss_file.c b/src/lib/libcrypto/bio/bss_file.c index 0d44dc3889..1f770b390f 100644 --- a/src/lib/libcrypto/bio/bss_file.c +++ b/src/lib/libcrypto/bio/bss_file.c | |||
@@ -73,11 +73,11 @@ | |||
73 | 73 | ||
74 | #if !defined(NO_STDIO) | 74 | #if !defined(NO_STDIO) |
75 | 75 | ||
76 | static int MS_CALLBACK file_write(BIO *h,char *buf,int num); | 76 | static int MS_CALLBACK file_write(BIO *h, const char *buf, int num); |
77 | static int MS_CALLBACK file_read(BIO *h,char *buf,int size); | 77 | static int MS_CALLBACK file_read(BIO *h, char *buf, int size); |
78 | static int MS_CALLBACK file_puts(BIO *h,char *str); | 78 | static int MS_CALLBACK file_puts(BIO *h, const char *str); |
79 | static int MS_CALLBACK file_gets(BIO *h,char *str,int size); | 79 | static int MS_CALLBACK file_gets(BIO *h, char *str, int size); |
80 | static long MS_CALLBACK file_ctrl(BIO *h,int cmd,long arg1,char *arg2); | 80 | static long MS_CALLBACK file_ctrl(BIO *h, int cmd, long arg1, void *arg2); |
81 | static int MS_CALLBACK file_new(BIO *h); | 81 | static int MS_CALLBACK file_new(BIO *h); |
82 | static int MS_CALLBACK file_free(BIO *data); | 82 | static int MS_CALLBACK file_free(BIO *data); |
83 | static BIO_METHOD methods_filep= | 83 | static BIO_METHOD methods_filep= |
@@ -163,7 +163,7 @@ static int MS_CALLBACK file_read(BIO *b, char *out, int outl) | |||
163 | return(ret); | 163 | return(ret); |
164 | } | 164 | } |
165 | 165 | ||
166 | static int MS_CALLBACK file_write(BIO *b, char *in, int inl) | 166 | static int MS_CALLBACK file_write(BIO *b, const char *in, int inl) |
167 | { | 167 | { |
168 | int ret=0; | 168 | int ret=0; |
169 | 169 | ||
@@ -179,7 +179,7 @@ static int MS_CALLBACK file_write(BIO *b, char *in, int inl) | |||
179 | return(ret); | 179 | return(ret); |
180 | } | 180 | } |
181 | 181 | ||
182 | static long MS_CALLBACK file_ctrl(BIO *b, int cmd, long num, char *ptr) | 182 | static long MS_CALLBACK file_ctrl(BIO *b, int cmd, long num, void *ptr) |
183 | { | 183 | { |
184 | long ret=1; | 184 | long ret=1; |
185 | FILE *fp=(FILE *)b->ptr; | 185 | FILE *fp=(FILE *)b->ptr; |
@@ -294,7 +294,7 @@ static int MS_CALLBACK file_gets(BIO *bp, char *buf, int size) | |||
294 | return(ret); | 294 | return(ret); |
295 | } | 295 | } |
296 | 296 | ||
297 | static int MS_CALLBACK file_puts(BIO *bp, char *str) | 297 | static int MS_CALLBACK file_puts(BIO *bp, const char *str) |
298 | { | 298 | { |
299 | int n,ret; | 299 | int n,ret; |
300 | 300 | ||
diff --git a/src/lib/libcrypto/bio/bss_log.c b/src/lib/libcrypto/bio/bss_log.c index 497eb1af72..1edf16a76f 100644 --- a/src/lib/libcrypto/bio/bss_log.c +++ b/src/lib/libcrypto/bio/bss_log.c | |||
@@ -110,14 +110,26 @@ | |||
110 | #define LOG_DAEMON OPC$M_NM_NTWORK | 110 | #define LOG_DAEMON OPC$M_NM_NTWORK |
111 | #endif | 111 | #endif |
112 | 112 | ||
113 | static int MS_CALLBACK slg_write(BIO *h,char *buf,int num); | 113 | static int MS_CALLBACK slg_write(BIO *h, const char *buf, int num); |
114 | static int MS_CALLBACK slg_puts(BIO *h,char *str); | 114 | static int MS_CALLBACK slg_puts(BIO *h, const char *str); |
115 | static long MS_CALLBACK slg_ctrl(BIO *h,int cmd,long arg1,char *arg2); | 115 | static long MS_CALLBACK slg_ctrl(BIO *h, int cmd, long arg1, void *arg2); |
116 | static int MS_CALLBACK slg_new(BIO *h); | 116 | static int MS_CALLBACK slg_new(BIO *h); |
117 | static int MS_CALLBACK slg_free(BIO *data); | 117 | static int MS_CALLBACK slg_free(BIO *data); |
118 | static void xopenlog(BIO* bp, const char* name, int level); | 118 | static void xopenlog(BIO* bp, char* name, int level); |
119 | static void xsyslog(BIO* bp, int priority, const char* string); | 119 | static void xsyslog(BIO* bp, int priority, const char* string); |
120 | static void xcloselog(BIO* bp); | 120 | static void xcloselog(BIO* bp); |
121 | #ifdef WIN32 | ||
122 | LONG (WINAPI *go_for_advapi)() = RegOpenKeyEx; | ||
123 | HANDLE (WINAPI *register_event_source)() = NULL; | ||
124 | BOOL (WINAPI *deregister_event_source)() = NULL; | ||
125 | BOOL (WINAPI *report_event)() = NULL; | ||
126 | #define DL_PROC(m,f) (GetProcAddress( m, f )) | ||
127 | #ifdef UNICODE | ||
128 | #define DL_PROC_X(m,f) DL_PROC( m, f "W" ) | ||
129 | #else | ||
130 | #define DL_PROC_X(m,f) DL_PROC( m, f "A" ) | ||
131 | #endif | ||
132 | #endif | ||
121 | 133 | ||
122 | static BIO_METHOD methods_slg= | 134 | static BIO_METHOD methods_slg= |
123 | { | 135 | { |
@@ -153,40 +165,60 @@ static int MS_CALLBACK slg_free(BIO *a) | |||
153 | return(1); | 165 | return(1); |
154 | } | 166 | } |
155 | 167 | ||
156 | static int MS_CALLBACK slg_write(BIO *b, char *in, int inl) | 168 | static int MS_CALLBACK slg_write(BIO *b, const char *in, int inl) |
157 | { | 169 | { |
158 | int ret= inl; | 170 | int ret= inl; |
159 | char* buf= in; | 171 | char* buf; |
160 | char* pp; | 172 | char* pp; |
161 | int priority; | 173 | int priority, i; |
162 | 174 | static struct | |
163 | if((buf= (char *)Malloc(inl+ 1)) == NULL){ | 175 | { |
176 | int strl; | ||
177 | char str[10]; | ||
178 | int log_level; | ||
179 | } | ||
180 | mapping[] = | ||
181 | { | ||
182 | { 6, "PANIC ", LOG_EMERG }, | ||
183 | { 6, "EMERG ", LOG_EMERG }, | ||
184 | { 4, "EMR ", LOG_EMERG }, | ||
185 | { 6, "ALERT ", LOG_ALERT }, | ||
186 | { 4, "ALR ", LOG_ALERT }, | ||
187 | { 5, "CRIT ", LOG_CRIT }, | ||
188 | { 4, "CRI ", LOG_CRIT }, | ||
189 | { 6, "ERROR ", LOG_ERR }, | ||
190 | { 4, "ERR ", LOG_ERR }, | ||
191 | { 8, "WARNING ", LOG_WARNING }, | ||
192 | { 5, "WARN ", LOG_WARNING }, | ||
193 | { 4, "WAR ", LOG_WARNING }, | ||
194 | { 7, "NOTICE ", LOG_NOTICE }, | ||
195 | { 5, "NOTE ", LOG_NOTICE }, | ||
196 | { 4, "NOT ", LOG_NOTICE }, | ||
197 | { 5, "INFO ", LOG_INFO }, | ||
198 | { 4, "INF ", LOG_INFO }, | ||
199 | { 6, "DEBUG ", LOG_DEBUG }, | ||
200 | { 4, "DBG ", LOG_DEBUG }, | ||
201 | { 0, "", LOG_ERR } /* The default */ | ||
202 | }; | ||
203 | |||
204 | if((buf= (char *)OPENSSL_malloc(inl+ 1)) == NULL){ | ||
164 | return(0); | 205 | return(0); |
165 | } | 206 | } |
166 | strncpy(buf, in, inl); | 207 | strncpy(buf, in, inl); |
167 | buf[inl]= '\0'; | 208 | buf[inl]= '\0'; |
168 | 209 | ||
169 | if(strncmp(buf, "ERR ", 4) == 0){ | 210 | i = 0; |
170 | priority= LOG_ERR; | 211 | while(strncmp(buf, mapping[i].str, mapping[i].strl) != 0) i++; |
171 | pp= buf+ 4; | 212 | priority = mapping[i].log_level; |
172 | }else if(strncmp(buf, "WAR ", 4) == 0){ | 213 | pp = buf + mapping[i].strl; |
173 | priority= LOG_WARNING; | ||
174 | pp= buf+ 4; | ||
175 | }else if(strncmp(buf, "INF ", 4) == 0){ | ||
176 | priority= LOG_INFO; | ||
177 | pp= buf+ 4; | ||
178 | }else{ | ||
179 | priority= LOG_ERR; | ||
180 | pp= buf; | ||
181 | } | ||
182 | 214 | ||
183 | xsyslog(b, priority, pp); | 215 | xsyslog(b, priority, pp); |
184 | 216 | ||
185 | Free(buf); | 217 | OPENSSL_free(buf); |
186 | return(ret); | 218 | return(ret); |
187 | } | 219 | } |
188 | 220 | ||
189 | static long MS_CALLBACK slg_ctrl(BIO *b, int cmd, long num, char *ptr) | 221 | static long MS_CALLBACK slg_ctrl(BIO *b, int cmd, long num, void *ptr) |
190 | { | 222 | { |
191 | switch (cmd) | 223 | switch (cmd) |
192 | { | 224 | { |
@@ -200,7 +232,7 @@ static long MS_CALLBACK slg_ctrl(BIO *b, int cmd, long num, char *ptr) | |||
200 | return(0); | 232 | return(0); |
201 | } | 233 | } |
202 | 234 | ||
203 | static int MS_CALLBACK slg_puts(BIO *bp, char *str) | 235 | static int MS_CALLBACK slg_puts(BIO *bp, const char *str) |
204 | { | 236 | { |
205 | int n,ret; | 237 | int n,ret; |
206 | 238 | ||
@@ -211,9 +243,29 @@ static int MS_CALLBACK slg_puts(BIO *bp, char *str) | |||
211 | 243 | ||
212 | #if defined(WIN32) | 244 | #if defined(WIN32) |
213 | 245 | ||
214 | static void xopenlog(BIO* bp, const char* name, int level) | 246 | static void xopenlog(BIO* bp, char* name, int level) |
215 | { | 247 | { |
216 | bp->ptr= (char *)RegisterEventSource(NULL, name); | 248 | if ( !register_event_source ) |
249 | { | ||
250 | HANDLE advapi; | ||
251 | if ( !(advapi = GetModuleHandle("advapi32")) ) | ||
252 | return; | ||
253 | register_event_source = (HANDLE (WINAPI *)())DL_PROC_X(advapi, | ||
254 | "RegisterEventSource" ); | ||
255 | deregister_event_source = (BOOL (WINAPI *)())DL_PROC(advapi, | ||
256 | "DeregisterEventSource"); | ||
257 | report_event = (BOOL (WINAPI *)())DL_PROC_X(advapi, | ||
258 | "ReportEvent" ); | ||
259 | if ( !(register_event_source && deregister_event_source && | ||
260 | report_event) ) | ||
261 | { | ||
262 | register_event_source = NULL; | ||
263 | deregister_event_source = NULL; | ||
264 | report_event = NULL; | ||
265 | return; | ||
266 | } | ||
267 | } | ||
268 | bp->ptr= (char *)register_event_source(NULL, name); | ||
217 | } | 269 | } |
218 | 270 | ||
219 | static void xsyslog(BIO *bp, int priority, const char *string) | 271 | static void xsyslog(BIO *bp, int priority, const char *string) |
@@ -225,16 +277,22 @@ static void xsyslog(BIO *bp, int priority, const char *string) | |||
225 | 277 | ||
226 | switch (priority) | 278 | switch (priority) |
227 | { | 279 | { |
280 | case LOG_EMERG: | ||
281 | case LOG_ALERT: | ||
282 | case LOG_CRIT: | ||
228 | case LOG_ERR: | 283 | case LOG_ERR: |
229 | evtype = EVENTLOG_ERROR_TYPE; | 284 | evtype = EVENTLOG_ERROR_TYPE; |
230 | break; | 285 | break; |
231 | case LOG_WARNING: | 286 | case LOG_WARNING: |
232 | evtype = EVENTLOG_WARNING_TYPE; | 287 | evtype = EVENTLOG_WARNING_TYPE; |
233 | break; | 288 | break; |
289 | case LOG_NOTICE: | ||
234 | case LOG_INFO: | 290 | case LOG_INFO: |
291 | case LOG_DEBUG: | ||
235 | evtype = EVENTLOG_INFORMATION_TYPE; | 292 | evtype = EVENTLOG_INFORMATION_TYPE; |
236 | break; | 293 | break; |
237 | default: | 294 | default: /* Should never happen, but set it |
295 | as error anyway. */ | ||
238 | evtype = EVENTLOG_ERROR_TYPE; | 296 | evtype = EVENTLOG_ERROR_TYPE; |
239 | break; | 297 | break; |
240 | } | 298 | } |
@@ -243,15 +301,15 @@ static void xsyslog(BIO *bp, int priority, const char *string) | |||
243 | lpszStrings[0] = pidbuf; | 301 | lpszStrings[0] = pidbuf; |
244 | lpszStrings[1] = string; | 302 | lpszStrings[1] = string; |
245 | 303 | ||
246 | if(bp->ptr) | 304 | if(report_event && bp->ptr) |
247 | ReportEvent(bp->ptr, evtype, 0, 1024, NULL, 2, 0, | 305 | report_event(bp->ptr, evtype, 0, 1024, NULL, 2, 0, |
248 | lpszStrings, NULL); | 306 | lpszStrings, NULL); |
249 | } | 307 | } |
250 | 308 | ||
251 | static void xcloselog(BIO* bp) | 309 | static void xcloselog(BIO* bp) |
252 | { | 310 | { |
253 | if(bp->ptr) | 311 | if(deregister_event_source && bp->ptr) |
254 | DeregisterEventSource((HANDLE)(bp->ptr)); | 312 | deregister_event_source((HANDLE)(bp->ptr)); |
255 | bp->ptr= NULL; | 313 | bp->ptr= NULL; |
256 | } | 314 | } |
257 | 315 | ||
@@ -259,7 +317,7 @@ static void xcloselog(BIO* bp) | |||
259 | 317 | ||
260 | static int VMS_OPC_target = LOG_DAEMON; | 318 | static int VMS_OPC_target = LOG_DAEMON; |
261 | 319 | ||
262 | static void xopenlog(BIO* bp, const char* name, int level) | 320 | static void xopenlog(BIO* bp, char* name, int level) |
263 | { | 321 | { |
264 | VMS_OPC_target = level; | 322 | VMS_OPC_target = level; |
265 | } | 323 | } |
@@ -294,7 +352,7 @@ static void xsyslog(BIO *bp, int priority, const char *string) | |||
294 | lib$sys_fao(&fao_cmd, &len, &buf_dsc, priority_tag, string); | 352 | lib$sys_fao(&fao_cmd, &len, &buf_dsc, priority_tag, string); |
295 | 353 | ||
296 | /* we know there's an 8 byte header. That's documented */ | 354 | /* we know there's an 8 byte header. That's documented */ |
297 | opcdef_p = (struct opcdef *) Malloc(8 + len); | 355 | opcdef_p = (struct opcdef *) OPENSSL_malloc(8 + len); |
298 | opcdef_p->opc$b_ms_type = OPC$_RQ_RQST; | 356 | opcdef_p->opc$b_ms_type = OPC$_RQ_RQST; |
299 | memcpy(opcdef_p->opc$z_ms_target_classes, &VMS_OPC_target, 3); | 357 | memcpy(opcdef_p->opc$z_ms_target_classes, &VMS_OPC_target, 3); |
300 | opcdef_p->opc$l_ms_rqstid = 0; | 358 | opcdef_p->opc$l_ms_rqstid = 0; |
@@ -307,7 +365,7 @@ static void xsyslog(BIO *bp, int priority, const char *string) | |||
307 | 365 | ||
308 | sys$sndopr(opc_dsc, 0); | 366 | sys$sndopr(opc_dsc, 0); |
309 | 367 | ||
310 | Free(opcdef_p); | 368 | OPENSSL_free(opcdef_p); |
311 | } | 369 | } |
312 | 370 | ||
313 | static void xcloselog(BIO* bp) | 371 | static void xcloselog(BIO* bp) |
@@ -316,7 +374,7 @@ static void xcloselog(BIO* bp) | |||
316 | 374 | ||
317 | #else /* Unix */ | 375 | #else /* Unix */ |
318 | 376 | ||
319 | static void xopenlog(BIO* bp, const char* name, int level) | 377 | static void xopenlog(BIO* bp, char* name, int level) |
320 | { | 378 | { |
321 | openlog(name, LOG_PID|LOG_CONS, level); | 379 | openlog(name, LOG_PID|LOG_CONS, level); |
322 | } | 380 | } |
diff --git a/src/lib/libcrypto/bio/bss_mem.c b/src/lib/libcrypto/bio/bss_mem.c index 41eab92415..28ff7582bf 100644 --- a/src/lib/libcrypto/bio/bss_mem.c +++ b/src/lib/libcrypto/bio/bss_mem.c | |||
@@ -61,11 +61,11 @@ | |||
61 | #include "cryptlib.h" | 61 | #include "cryptlib.h" |
62 | #include <openssl/bio.h> | 62 | #include <openssl/bio.h> |
63 | 63 | ||
64 | static int mem_write(BIO *h,char *buf,int num); | 64 | static int mem_write(BIO *h, const char *buf, int num); |
65 | static int mem_read(BIO *h,char *buf,int size); | 65 | static int mem_read(BIO *h, char *buf, int size); |
66 | static int mem_puts(BIO *h,char *str); | 66 | static int mem_puts(BIO *h, const char *str); |
67 | static int mem_gets(BIO *h,char *str,int size); | 67 | static int mem_gets(BIO *h, char *str, int size); |
68 | static long mem_ctrl(BIO *h,int cmd,long arg1,char *arg2); | 68 | static long mem_ctrl(BIO *h, int cmd, long arg1, void *arg2); |
69 | static int mem_new(BIO *h); | 69 | static int mem_new(BIO *h); |
70 | static int mem_free(BIO *data); | 70 | static int mem_free(BIO *data); |
71 | static BIO_METHOD mem_method= | 71 | static BIO_METHOD mem_method= |
@@ -163,14 +163,14 @@ static int mem_read(BIO *b, char *out, int outl) | |||
163 | } | 163 | } |
164 | } else if (bm->length == 0) | 164 | } else if (bm->length == 0) |
165 | { | 165 | { |
166 | if (b->num != 0) | 166 | ret = b->num; |
167 | if (ret != 0) | ||
167 | BIO_set_retry_read(b); | 168 | BIO_set_retry_read(b); |
168 | ret= b->num; | ||
169 | } | 169 | } |
170 | return(ret); | 170 | return(ret); |
171 | } | 171 | } |
172 | 172 | ||
173 | static int mem_write(BIO *b, char *in, int inl) | 173 | static int mem_write(BIO *b, const char *in, int inl) |
174 | { | 174 | { |
175 | int ret= -1; | 175 | int ret= -1; |
176 | int blen; | 176 | int blen; |
@@ -198,7 +198,7 @@ end: | |||
198 | return(ret); | 198 | return(ret); |
199 | } | 199 | } |
200 | 200 | ||
201 | static long mem_ctrl(BIO *b, int cmd, long num, char *ptr) | 201 | static long mem_ctrl(BIO *b, int cmd, long num, void *ptr) |
202 | { | 202 | { |
203 | long ret=1; | 203 | long ret=1; |
204 | char **pptr; | 204 | char **pptr; |
@@ -208,15 +208,20 @@ static long mem_ctrl(BIO *b, int cmd, long num, char *ptr) | |||
208 | switch (cmd) | 208 | switch (cmd) |
209 | { | 209 | { |
210 | case BIO_CTRL_RESET: | 210 | case BIO_CTRL_RESET: |
211 | if (bm->data != NULL) { | 211 | if (bm->data != NULL) |
212 | { | ||
212 | /* For read only case reset to the start again */ | 213 | /* For read only case reset to the start again */ |
213 | if(b->flags & BIO_FLAGS_MEM_RDONLY) | 214 | if(b->flags & BIO_FLAGS_MEM_RDONLY) |
214 | bm->data -= bm->max - bm->length; | 215 | { |
215 | else { | 216 | bm->data -= bm->max - bm->length; |
217 | bm->length = bm->max; | ||
218 | } | ||
219 | else | ||
220 | { | ||
216 | memset(bm->data,0,bm->max); | 221 | memset(bm->data,0,bm->max); |
217 | bm->length=0; | 222 | bm->length=0; |
223 | } | ||
218 | } | 224 | } |
219 | } | ||
220 | break; | 225 | break; |
221 | case BIO_CTRL_EOF: | 226 | case BIO_CTRL_EOF: |
222 | ret=(long)(bm->length == 0); | 227 | ret=(long)(bm->length == 0); |
@@ -300,7 +305,7 @@ static int mem_gets(BIO *bp, char *buf, int size) | |||
300 | return(ret); | 305 | return(ret); |
301 | } | 306 | } |
302 | 307 | ||
303 | static int mem_puts(BIO *bp, char *str) | 308 | static int mem_puts(BIO *bp, const char *str) |
304 | { | 309 | { |
305 | int n,ret; | 310 | int n,ret; |
306 | 311 | ||
diff --git a/src/lib/libcrypto/bio/bss_null.c b/src/lib/libcrypto/bio/bss_null.c index aee18e3ada..46b73339df 100644 --- a/src/lib/libcrypto/bio/bss_null.c +++ b/src/lib/libcrypto/bio/bss_null.c | |||
@@ -61,11 +61,11 @@ | |||
61 | #include "cryptlib.h" | 61 | #include "cryptlib.h" |
62 | #include <openssl/bio.h> | 62 | #include <openssl/bio.h> |
63 | 63 | ||
64 | static int null_write(BIO *h,char *buf,int num); | 64 | static int null_write(BIO *h, const char *buf, int num); |
65 | static int null_read(BIO *h,char *buf,int size); | 65 | static int null_read(BIO *h, char *buf, int size); |
66 | static int null_puts(BIO *h,char *str); | 66 | static int null_puts(BIO *h, const char *str); |
67 | static int null_gets(BIO *h,char *str,int size); | 67 | static int null_gets(BIO *h, char *str, int size); |
68 | static long null_ctrl(BIO *h,int cmd,long arg1,char *arg2); | 68 | static long null_ctrl(BIO *h, int cmd, long arg1, void *arg2); |
69 | static int null_new(BIO *h); | 69 | static int null_new(BIO *h); |
70 | static int null_free(BIO *data); | 70 | static int null_free(BIO *data); |
71 | static BIO_METHOD null_method= | 71 | static BIO_METHOD null_method= |
@@ -106,12 +106,12 @@ static int null_read(BIO *b, char *out, int outl) | |||
106 | return(0); | 106 | return(0); |
107 | } | 107 | } |
108 | 108 | ||
109 | static int null_write(BIO *b, char *in, int inl) | 109 | static int null_write(BIO *b, const char *in, int inl) |
110 | { | 110 | { |
111 | return(inl); | 111 | return(inl); |
112 | } | 112 | } |
113 | 113 | ||
114 | static long null_ctrl(BIO *b, int cmd, long num, char *ptr) | 114 | static long null_ctrl(BIO *b, int cmd, long num, void *ptr) |
115 | { | 115 | { |
116 | long ret=1; | 116 | long ret=1; |
117 | 117 | ||
@@ -142,7 +142,7 @@ static int null_gets(BIO *bp, char *buf, int size) | |||
142 | return(0); | 142 | return(0); |
143 | } | 143 | } |
144 | 144 | ||
145 | static int null_puts(BIO *bp, char *str) | 145 | static int null_puts(BIO *bp, const char *str) |
146 | { | 146 | { |
147 | if (str == NULL) return(0); | 147 | if (str == NULL) return(0); |
148 | return(strlen(str)); | 148 | return(strlen(str)); |
diff --git a/src/lib/libcrypto/bio/bss_rtcp.c b/src/lib/libcrypto/bio/bss_rtcp.c index 4ad0739464..7dae485564 100644 --- a/src/lib/libcrypto/bio/bss_rtcp.c +++ b/src/lib/libcrypto/bio/bss_rtcp.c | |||
@@ -88,11 +88,11 @@ struct rpc_ctx { | |||
88 | struct rpc_msg msg; | 88 | struct rpc_msg msg; |
89 | }; | 89 | }; |
90 | 90 | ||
91 | static int rtcp_write(BIO *h,char *buf,int num); | 91 | static int rtcp_write(BIO *h,const char *buf,int num); |
92 | static int rtcp_read(BIO *h,char *buf,int size); | 92 | static int rtcp_read(BIO *h,char *buf,int size); |
93 | static int rtcp_puts(BIO *h,char *str); | 93 | static int rtcp_puts(BIO *h,const char *str); |
94 | static int rtcp_gets(BIO *h,char *str,int size); | 94 | static int rtcp_gets(BIO *h,char *str,int size); |
95 | static long rtcp_ctrl(BIO *h,int cmd,long arg1,char *arg2); | 95 | static long rtcp_ctrl(BIO *h,int cmd,long arg1,void *arg2); |
96 | static int rtcp_new(BIO *h); | 96 | static int rtcp_new(BIO *h); |
97 | static int rtcp_free(BIO *data); | 97 | static int rtcp_free(BIO *data); |
98 | 98 | ||
@@ -156,7 +156,7 @@ static int rtcp_new(BIO *bi) | |||
156 | bi->init=1; | 156 | bi->init=1; |
157 | bi->num=0; | 157 | bi->num=0; |
158 | bi->flags = 0; | 158 | bi->flags = 0; |
159 | bi->ptr=Malloc(sizeof(struct rpc_ctx)); | 159 | bi->ptr=OPENSSL_malloc(sizeof(struct rpc_ctx)); |
160 | ctx = (struct rpc_ctx *) bi->ptr; | 160 | ctx = (struct rpc_ctx *) bi->ptr; |
161 | ctx->filled = 0; | 161 | ctx->filled = 0; |
162 | ctx->pos = 0; | 162 | ctx->pos = 0; |
@@ -166,7 +166,7 @@ static int rtcp_new(BIO *bi) | |||
166 | static int rtcp_free(BIO *a) | 166 | static int rtcp_free(BIO *a) |
167 | { | 167 | { |
168 | if (a == NULL) return(0); | 168 | if (a == NULL) return(0); |
169 | if ( a->ptr ) Free ( a->ptr ); | 169 | if ( a->ptr ) OPENSSL_free ( a->ptr ); |
170 | a->ptr = NULL; | 170 | a->ptr = NULL; |
171 | return(1); | 171 | return(1); |
172 | } | 172 | } |
@@ -218,7 +218,7 @@ static int rtcp_read(BIO *b, char *out, int outl) | |||
218 | return length; | 218 | return length; |
219 | } | 219 | } |
220 | 220 | ||
221 | static int rtcp_write(BIO *b, char *in, int inl) | 221 | static int rtcp_write(BIO *b, const char *in, int inl) |
222 | { | 222 | { |
223 | int status, i, segment, length; | 223 | int status, i, segment, length; |
224 | struct rpc_ctx *ctx; | 224 | struct rpc_ctx *ctx; |
@@ -247,7 +247,7 @@ static int rtcp_write(BIO *b, char *in, int inl) | |||
247 | return(i); | 247 | return(i); |
248 | } | 248 | } |
249 | 249 | ||
250 | static long rtcp_ctrl(BIO *b, int cmd, long num, char *ptr) | 250 | static long rtcp_ctrl(BIO *b, int cmd, long num, void *ptr) |
251 | { | 251 | { |
252 | long ret=1; | 252 | long ret=1; |
253 | 253 | ||
@@ -283,7 +283,7 @@ static int rtcp_gets(BIO *bp, char *buf, int size) | |||
283 | return(0); | 283 | return(0); |
284 | } | 284 | } |
285 | 285 | ||
286 | static int rtcp_puts(BIO *bp, char *str) | 286 | static int rtcp_puts(BIO *bp, const char *str) |
287 | { | 287 | { |
288 | int length; | 288 | int length; |
289 | if (str == NULL) return(0); | 289 | if (str == NULL) return(0); |
diff --git a/src/lib/libcrypto/bio/bss_sock.c b/src/lib/libcrypto/bio/bss_sock.c index 8ce80ef68d..50c6744c06 100644 --- a/src/lib/libcrypto/bio/bss_sock.c +++ b/src/lib/libcrypto/bio/bss_sock.c | |||
@@ -65,19 +65,19 @@ | |||
65 | #include <openssl/bio.h> | 65 | #include <openssl/bio.h> |
66 | 66 | ||
67 | #ifndef BIO_FD | 67 | #ifndef BIO_FD |
68 | static int sock_write(BIO *h,char *buf,int num); | 68 | static int sock_write(BIO *h, const char *buf, int num); |
69 | static int sock_read(BIO *h,char *buf,int size); | 69 | static int sock_read(BIO *h, char *buf, int size); |
70 | static int sock_puts(BIO *h,char *str); | 70 | static int sock_puts(BIO *h, const char *str); |
71 | static long sock_ctrl(BIO *h,int cmd,long arg1,char *arg2); | 71 | static long sock_ctrl(BIO *h, int cmd, long arg1, void *arg2); |
72 | static int sock_new(BIO *h); | 72 | static int sock_new(BIO *h); |
73 | static int sock_free(BIO *data); | 73 | static int sock_free(BIO *data); |
74 | int BIO_sock_should_retry(int s); | 74 | int BIO_sock_should_retry(int s); |
75 | #else | 75 | #else |
76 | 76 | ||
77 | static int fd_write(BIO *h,char *buf,int num); | 77 | static int fd_write(BIO *h, const char *buf, int num); |
78 | static int fd_read(BIO *h,char *buf,int size); | 78 | static int fd_read(BIO *h, char *buf, int size); |
79 | static int fd_puts(BIO *h,char *str); | 79 | static int fd_puts(BIO *h, const char *str); |
80 | static long fd_ctrl(BIO *h,int cmd,long arg1,char *arg2); | 80 | static long fd_ctrl(BIO *h, int cmd, long arg1, void *arg2); |
81 | static int fd_new(BIO *h); | 81 | static int fd_new(BIO *h); |
82 | static int fd_free(BIO *data); | 82 | static int fd_free(BIO *data); |
83 | int BIO_fd_should_retry(int s); | 83 | int BIO_fd_should_retry(int s); |
@@ -209,9 +209,9 @@ static int fd_read(BIO *b, char *out,int outl) | |||
209 | } | 209 | } |
210 | 210 | ||
211 | #ifndef BIO_FD | 211 | #ifndef BIO_FD |
212 | static int sock_write(BIO *b, char *in, int inl) | 212 | static int sock_write(BIO *b, const char *in, int inl) |
213 | #else | 213 | #else |
214 | static int fd_write(BIO *b, char *in, int inl) | 214 | static int fd_write(BIO *b, const char *in, int inl) |
215 | #endif | 215 | #endif |
216 | { | 216 | { |
217 | int ret; | 217 | int ret; |
@@ -237,9 +237,9 @@ static int fd_write(BIO *b, char *in, int inl) | |||
237 | } | 237 | } |
238 | 238 | ||
239 | #ifndef BIO_FD | 239 | #ifndef BIO_FD |
240 | static long sock_ctrl(BIO *b, int cmd, long num, char *ptr) | 240 | static long sock_ctrl(BIO *b, int cmd, long num, void *ptr) |
241 | #else | 241 | #else |
242 | static long fd_ctrl(BIO *b, int cmd, long num, char *ptr) | 242 | static long fd_ctrl(BIO *b, int cmd, long num, void *ptr) |
243 | #endif | 243 | #endif |
244 | { | 244 | { |
245 | long ret=1; | 245 | long ret=1; |
@@ -313,9 +313,9 @@ static int sock_gets(BIO *bp, char *buf,int size) | |||
313 | #endif | 313 | #endif |
314 | 314 | ||
315 | #ifndef BIO_FD | 315 | #ifndef BIO_FD |
316 | static int sock_puts(BIO *bp, char *str) | 316 | static int sock_puts(BIO *bp, const char *str) |
317 | #else | 317 | #else |
318 | static int fd_puts(BIO *bp, char *str) | 318 | static int fd_puts(BIO *bp, const char *str) |
319 | #endif | 319 | #endif |
320 | { | 320 | { |
321 | int n,ret; | 321 | int n,ret; |