projects
/
oweals
/
openssl.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
correct+extend publication info
[oweals/openssl.git]
/
crypto
/
bio
/
bf_nbio.c
diff --git
a/crypto/bio/bf_nbio.c
b/crypto/bio/bf_nbio.c
index a525e79d4fb28f68b82b62a094176da52c048cfd..c72a23c2e1b289417543fb372f90a5a3a86115e8 100644
(file)
--- a/
crypto/bio/bf_nbio.c
+++ b/
crypto/bio/bf_nbio.c
@@
-61,18
+61,18
@@
#include "cryptlib.h"
#include <openssl/rand.h>
#include <openssl/bio.h>
#include "cryptlib.h"
#include <openssl/rand.h>
#include <openssl/bio.h>
-#include <openssl/evp.h>
/* BIO_put and BIO_get both add to the digest,
* BIO_gets returns the digest */
/* BIO_put and BIO_get both add to the digest,
* BIO_gets returns the digest */
-static int nbiof_write(BIO *h,char *buf,int num);
+static int nbiof_write(BIO *h,c
onst c
har *buf,int num);
static int nbiof_read(BIO *h,char *buf,int size);
static int nbiof_read(BIO *h,char *buf,int size);
-static int nbiof_puts(BIO *h,char *str);
+static int nbiof_puts(BIO *h,c
onst c
har *str);
static int nbiof_gets(BIO *h,char *str,int size);
static int nbiof_gets(BIO *h,char *str,int size);
-static long nbiof_ctrl(BIO *h,int cmd,long arg1,
char
*arg2);
+static long nbiof_ctrl(BIO *h,int cmd,long arg1,
void
*arg2);
static int nbiof_new(BIO *h);
static int nbiof_free(BIO *data);
static int nbiof_new(BIO *h);
static int nbiof_free(BIO *data);
+static long nbiof_callback_ctrl(BIO *h,int cmd,bio_info_cb *fp);
typedef struct nbio_test_st
{
/* only set if we sent a 'should retry' error */
typedef struct nbio_test_st
{
/* only set if we sent a 'should retry' error */
@@
-91,6
+91,7
@@
static BIO_METHOD methods_nbiof=
nbiof_ctrl,
nbiof_new,
nbiof_free,
nbiof_ctrl,
nbiof_new,
nbiof_free,
+ nbiof_callback_ctrl,
};
BIO_METHOD *BIO_f_nbio_test(void)
};
BIO_METHOD *BIO_f_nbio_test(void)
@@
-102,7
+103,7
@@
static int nbiof_new(BIO *bi)
{
NBIO_TEST *nt;
{
NBIO_TEST *nt;
-
nt=(NBIO_TEST *)Malloc(sizeof(NBIO_TEST)
);
+
if (!(nt=(NBIO_TEST *)OPENSSL_malloc(sizeof(NBIO_TEST)))) return(0
);
nt->lrn= -1;
nt->lwn= -1;
bi->ptr=(char *)nt;
nt->lrn= -1;
nt->lwn= -1;
bi->ptr=(char *)nt;
@@
-115,7
+116,7
@@
static int nbiof_free(BIO *a)
{
if (a == NULL) return(0);
if (a->ptr != NULL)
{
if (a == NULL) return(0);
if (a->ptr != NULL)
-
F
ree(a->ptr);
+
OPENSSL_f
ree(a->ptr);
a->ptr=NULL;
a->init=0;
a->flags=0;
a->ptr=NULL;
a->init=0;
a->flags=0;
@@
-126,7
+127,7
@@
static int nbiof_read(BIO *b, char *out, int outl)
{
NBIO_TEST *nt;
int ret=0;
{
NBIO_TEST *nt;
int ret=0;
-#if
0
+#if
1
int num;
unsigned char n;
#endif
int num;
unsigned char n;
#endif
@@
-136,7
+137,7
@@
static int nbiof_read(BIO *b, char *out, int outl)
nt=(NBIO_TEST *)b->ptr;
BIO_clear_retry_flags(b);
nt=(NBIO_TEST *)b->ptr;
BIO_clear_retry_flags(b);
-#if
0
+#if
1
RAND_pseudo_bytes(&n,1);
num=(n&0x07);
RAND_pseudo_bytes(&n,1);
num=(n&0x07);
@@
-157,7
+158,7
@@
static int nbiof_read(BIO *b, char *out, int outl)
return(ret);
}
return(ret);
}
-static int nbiof_write(BIO *b, char *in, int inl)
+static int nbiof_write(BIO *b, c
onst c
har *in, int inl)
{
NBIO_TEST *nt;
int ret=0;
{
NBIO_TEST *nt;
int ret=0;
@@
-202,7
+203,7
@@
static int nbiof_write(BIO *b, char *in, int inl)
return(ret);
}
return(ret);
}
-static long nbiof_ctrl(BIO *b, int cmd, long num,
char
*ptr)
+static long nbiof_ctrl(BIO *b, int cmd, long num,
void
*ptr)
{
long ret;
{
long ret;
@@
-224,6
+225,20
@@
static long nbiof_ctrl(BIO *b, int cmd, long num, char *ptr)
return(ret);
}
return(ret);
}
+static long nbiof_callback_ctrl(BIO *b, int cmd, bio_info_cb *fp)
+ {
+ long ret=1;
+
+ if (b->next_bio == NULL) return(0);
+ switch (cmd)
+ {
+ default:
+ ret=BIO_callback_ctrl(b->next_bio,cmd,fp);
+ break;
+ }
+ return(ret);
+ }
+
static int nbiof_gets(BIO *bp, char *buf, int size)
{
if (bp->next_bio == NULL) return(0);
static int nbiof_gets(BIO *bp, char *buf, int size)
{
if (bp->next_bio == NULL) return(0);
@@
-231,7
+246,7
@@
static int nbiof_gets(BIO *bp, char *buf, int size)
}
}
-static int nbiof_puts(BIO *bp, char *str)
+static int nbiof_puts(BIO *bp, c
onst c
har *str)
{
if (bp->next_bio == NULL) return(0);
return(BIO_puts(bp->next_bio,str));
{
if (bp->next_bio == NULL) return(0);
return(BIO_puts(bp->next_bio,str));