Bug #11185 ยป 0001-openssl-use-RB_GC_GUARD-instead-of-volatile.patch
ext/openssl/ossl_asn1.c | ||
---|---|---|
ossl_asn1_traverse(VALUE self, VALUE obj)
|
||
{
|
||
unsigned char *p;
|
||
volatile VALUE tmp;
|
||
VALUE tmp;
|
||
long len, read = 0, offset = 0;
|
||
obj = ossl_to_der_if_possible(obj);
|
||
... | ... | |
p = (unsigned char *)RSTRING_PTR(tmp);
|
||
len = RSTRING_LEN(tmp);
|
||
ossl_asn1_decode0(&p, len, &offset, 0, 1, &read);
|
||
RB_GC_GUARD(tmp);
|
||
int_ossl_decode_sanity_check(len, read, offset);
|
||
return Qnil;
|
||
}
|
||
... | ... | |
{
|
||
VALUE ret;
|
||
unsigned char *p;
|
||
volatile VALUE tmp;
|
||
VALUE tmp;
|
||
long len, read = 0, offset = 0;
|
||
obj = ossl_to_der_if_possible(obj);
|
||
... | ... | |
p = (unsigned char *)RSTRING_PTR(tmp);
|
||
len = RSTRING_LEN(tmp);
|
||
ret = ossl_asn1_decode0(&p, len, &offset, 0, 0, &read);
|
||
RB_GC_GUARD(tmp);
|
||
int_ossl_decode_sanity_check(len, read, offset);
|
||
return ret;
|
||
}
|
||
... | ... | |
VALUE ary, val;
|
||
unsigned char *p;
|
||
long len, tmp_len = 0, read = 0, offset = 0;
|
||
volatile VALUE tmp;
|
||
VALUE tmp;
|
||
obj = ossl_to_der_if_possible(obj);
|
||
tmp = rb_str_new4(StringValue(obj));
|
||
... | ... | |
read += tmp_read;
|
||
tmp_len -= tmp_read;
|
||
}
|
||
RB_GC_GUARD(tmp);
|
||
int_ossl_decode_sanity_check(len, read, offset);
|
||
return ary;
|
||
}
|
||
-
|