Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
8f72957e
D
dragonwell8_jdk
项目概览
openanolis
/
dragonwell8_jdk
通知
4
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell8_jdk
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
8f72957e
编写于
3月 18, 2013
作者:
J
jzavgren
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8007607: security native code doesn't always use malloc, realloc, and calloc correctly
Reviewed-by: chegar, dsamersoff, valeriep
上级
75cdfab3
变更
5
显示空白变更内容
内联
并排
Showing
5 changed file
with
79 addition
and
15 deletion
+79
-15
src/share/native/sun/security/jgss/wrapper/GSSLibStub.c
src/share/native/sun/security/jgss/wrapper/GSSLibStub.c
+39
-5
src/share/native/sun/security/jgss/wrapper/NativeUtil.c
src/share/native/sun/security/jgss/wrapper/NativeUtil.c
+12
-0
src/solaris/native/com/sun/security/auth/module/Solaris.c
src/solaris/native/com/sun/security/auth/module/Solaris.c
+14
-3
src/solaris/native/com/sun/security/auth/module/Unix.c
src/solaris/native/com/sun/security/auth/module/Unix.c
+14
-4
src/solaris/native/sun/security/smartcardio/pcsc_md.c
src/solaris/native/sun/security/smartcardio/pcsc_md.c
+0
-3
未找到文件。
src/share/native/sun/security/jgss/wrapper/GSSLibStub.c
浏览文件 @
8f72957e
...
...
@@ -27,8 +27,22 @@
#include "NativeUtil.h"
#include "NativeFunc.h"
#include "jlong.h"
#include <jni.h>
/* Constants for indicating what type of info is needed for inqueries */
/* Throws a Java Exception by name */
void
throwByName
(
JNIEnv
*
env
,
const
char
*
name
,
const
char
*
msg
)
{
jclass
cls
=
(
*
env
)
->
FindClass
(
env
,
name
);
if
(
cls
!=
0
)
/* Otherwise an exception has already been thrown */
(
*
env
)
->
ThrowNew
(
env
,
cls
,
msg
);
}
void
throwOutOfMemoryError
(
JNIEnv
*
env
,
const
char
*
message
)
{
throwByName
(
env
,
"java/lang/OutOfMemoryError"
,
message
);
}
/* Constants for indicating what type of info is needed for inquiries */
const
int
TYPE_CRED_NAME
=
10
;
const
int
TYPE_CRED_TIME
=
11
;
const
int
TYPE_CRED_USAGE
=
12
;
...
...
@@ -117,7 +131,14 @@ gss_channel_bindings_t getGSSCB(JNIEnv *env, jobject jcb) {
if
(
jcb
==
NULL
)
{
return
GSS_C_NO_CHANNEL_BINDINGS
;
}
cb
=
malloc
(
sizeof
(
struct
gss_channel_bindings_struct
));
if
(
cb
==
NULL
)
{
throwOutOfMemoryError
(
env
,
NULL
);
return
NULL
;
}
/* set up initiator address */
jinetAddr
=
(
*
env
)
->
CallObjectMethod
(
env
,
jcb
,
...
...
@@ -301,12 +322,15 @@ Java_sun_security_jgss_wrapper_GSSLibStub_importName(JNIEnv *env,
gss_buffer_desc
nameVal
;
gss_OID
nameType
;
gss_name_t
nameHdl
;
nameHdl
=
GSS_C_NO_NAME
;
debug
(
env
,
"[GSSLibStub_importName]"
);
initGSSBuffer
(
env
,
jnameVal
,
&
nameVal
);
nameType
=
newGSSOID
(
env
,
jnameType
);
nameHdl
=
GSS_C_NO_NAME
;
if
((
*
env
)
->
ExceptionCheck
(
env
))
{
return
jlong_zero
;
}
/* gss_import_name(...) => GSS_S_BAD_NAMETYPE, GSS_S_BAD_NAME,
GSS_S_BAD_MECH */
...
...
@@ -509,15 +533,18 @@ Java_sun_security_jgss_wrapper_GSSLibStub_acquireCred(JNIEnv *env,
gss_cred_usage_t
credUsage
;
gss_name_t
nameHdl
;
gss_cred_id_t
credHdl
;
credHdl
=
GSS_C_NO_CREDENTIAL
;
debug
(
env
,
"[GSSLibStub_acquireCred]"
);
mech
=
(
gss_OID
)
jlong_to_ptr
((
*
env
)
->
GetLongField
(
env
,
jobj
,
FID_GSSLibStub_pMech
));
mechs
=
newGSSOIDSet
(
env
,
mech
);
if
((
*
env
)
->
ExceptionCheck
(
env
))
{
return
jlong_zero
;
}
credUsage
=
(
gss_cred_usage_t
)
usage
;
nameHdl
=
(
gss_name_t
)
jlong_to_ptr
(
pName
);
credHdl
=
GSS_C_NO_CREDENTIAL
;
sprintf
(
debugBuf
,
"[GSSLibStub_acquireCred] pName=%ld, usage=%d"
,
(
long
)
pName
,
usage
);
...
...
@@ -628,7 +655,7 @@ Java_sun_security_jgss_wrapper_GSSLibStub_getCredName(JNIEnv *env,
/* return immediately if an exception has occurred */
if
((
*
env
)
->
ExceptionCheck
(
env
))
{
return
0
;
return
jlong_zero
;
}
sprintf
(
debugBuf
,
"[GSSLibStub_getCredName] pName=%ld"
,
(
long
)
nameHdl
);
...
...
@@ -795,6 +822,10 @@ Java_sun_security_jgss_wrapper_GSSLibStub_initContext(JNIEnv *env,
time
=
getGSSTime
((
*
env
)
->
GetIntField
(
env
,
jcontextSpi
,
FID_NativeGSSContext_lifetime
));
cb
=
getGSSCB
(
env
,
jcb
);
if
((
*
env
)
->
ExceptionCheck
(
env
))
{
return
NULL
;
}
initGSSBuffer
(
env
,
jinToken
,
&
inToken
);
sprintf
(
debugBuf
,
...
...
@@ -895,6 +926,9 @@ Java_sun_security_jgss_wrapper_GSSLibStub_acceptContext(JNIEnv *env,
credHdl
=
(
gss_cred_id_t
)
jlong_to_ptr
(
pCred
);
initGSSBuffer
(
env
,
jinToken
,
&
inToken
);
cb
=
getGSSCB
(
env
,
jcb
);
if
((
*
env
)
->
ExceptionCheck
(
env
))
{
return
NULL
;
}
srcName
=
GSS_C_NO_NAME
;
delCred
=
GSS_C_NO_CREDENTIAL
;
setTarget
=
(
credHdl
==
GSS_C_NO_CREDENTIAL
);
...
...
@@ -1130,7 +1164,7 @@ Java_sun_security_jgss_wrapper_GSSLibStub_getContextName(JNIEnv *env,
checkStatus
(
env
,
jobj
,
major
,
minor
,
"[GSSLibStub_inquireContextAll]"
);
/* return immediately if an exception has occurred */
if
((
*
env
)
->
ExceptionCheck
(
env
))
{
return
ptr_to_jlong
(
NULL
)
;
return
jlong_zero
;
}
sprintf
(
debugBuf
,
"[GSSLibStub_getContextName] pName=%ld"
,
(
long
)
nameHdl
);
...
...
src/share/native/sun/security/jgss/wrapper/NativeUtil.c
浏览文件 @
8f72957e
...
...
@@ -26,6 +26,9 @@
#include "NativeUtil.h"
#include "NativeFunc.h"
#include "jlong.h"
#include <jni.h>
extern
void
throwOutOfMemoryError
(
JNIEnv
*
env
,
const
char
*
message
);
const
int
JAVA_DUPLICATE_TOKEN_CODE
=
19
;
/* DUPLICATE_TOKEN */
const
int
JAVA_OLD_TOKEN_CODE
=
20
;
/* OLD_TOKEN */
...
...
@@ -615,8 +618,17 @@ gss_OID newGSSOID(JNIEnv *env, jobject jOid) {
(
*
env
)
->
Throw
(
env
,
gssEx
);
}
cOid
=
malloc
(
sizeof
(
struct
gss_OID_desc_struct
));
if
(
cOid
==
NULL
)
{
throwOutOfMemoryError
(
env
,
NULL
);
return
GSS_C_NO_OID
;
}
cOid
->
length
=
(
*
env
)
->
GetArrayLength
(
env
,
jbytes
)
-
2
;
cOid
->
elements
=
malloc
(
cOid
->
length
);
if
(
cOid
->
elements
==
NULL
)
{
throwOutOfMemoryError
(
env
,
NULL
);
free
(
cOid
);
return
GSS_C_NO_OID
;
}
(
*
env
)
->
GetByteArrayRegion
(
env
,
jbytes
,
2
,
cOid
->
length
,
cOid
->
elements
);
(
*
env
)
->
DeleteLocalRef
(
env
,
jbytes
);
...
...
src/solaris/native/com/sun/security/auth/module/Solaris.c
浏览文件 @
8f72957e
...
...
@@ -31,6 +31,7 @@
#include <stdlib.h>
#include <string.h>
#include <pwd.h>
JNIEXPORT
void
JNICALL
Java_com_sun_security_auth_module_SolarisSystem_getSolarisInfo
(
JNIEnv
*
env
,
jobject
obj
)
{
...
...
@@ -39,13 +40,23 @@ Java_com_sun_security_auth_module_SolarisSystem_getSolarisInfo
char
pwd_buf
[
1024
];
struct
passwd
pwd
;
jsize
numSuppGroups
=
getgroups
(
0
,
NULL
);
gid_t
*
groups
=
(
gid_t
*
)
calloc
(
numSuppGroups
,
sizeof
(
gid_t
));
jfieldID
fid
;
jstring
jstr
;
jlongArray
jgroups
;
jlong
*
jgroupsAsArray
;
jclass
cls
=
(
*
env
)
->
GetObjectClass
(
env
,
obj
);
gid_t
*
groups
;
jclass
cls
;
groups
=
(
gid_t
*
)
calloc
(
numSuppGroups
,
sizeof
(
gid_t
));
if
(
groups
==
NULL
)
{
jclass
cls
=
(
*
env
)
->
FindClass
(
env
,
"java/lang/OutOfMemoryError"
);
if
(
cls
!=
0
)
(
*
env
)
->
ThrowNew
(
env
,
cls
,
NULL
);
return
;
}
cls
=
(
*
env
)
->
GetObjectClass
(
env
,
obj
);
memset
(
pwd_buf
,
0
,
sizeof
(
pwd_buf
));
if
(
getpwuid_r
(
getuid
(),
&
pwd
,
pwd_buf
,
sizeof
(
pwd_buf
))
!=
NULL
&&
...
...
src/solaris/native/com/sun/security/auth/module/Unix.c
浏览文件 @
8f72957e
...
...
@@ -44,9 +44,6 @@ Java_com_sun_security_auth_module_UnixSystem_getUnixInfo
char
pwd_buf
[
1024
];
struct
passwd
*
pwd
;
struct
passwd
resbuf
;
jsize
numSuppGroups
=
getgroups
(
0
,
NULL
);
gid_t
*
groups
=
(
gid_t
*
)
calloc
(
numSuppGroups
,
sizeof
(
gid_t
));
jfieldID
userNameID
;
jfieldID
userID
;
jfieldID
groupID
;
...
...
@@ -55,7 +52,20 @@ Java_com_sun_security_auth_module_UnixSystem_getUnixInfo
jstring
jstr
;
jlongArray
jgroups
;
jlong
*
jgroupsAsArray
;
jclass
cls
=
(
*
env
)
->
GetObjectClass
(
env
,
obj
);
jsize
numSuppGroups
;
gid_t
*
groups
;
jclass
cls
;
numSuppGroups
=
getgroups
(
0
,
NULL
);
groups
=
(
gid_t
*
)
calloc
(
numSuppGroups
,
sizeof
(
gid_t
));
if
(
groups
==
NULL
)
{
jclass
cls
=
(
*
env
)
->
FindClass
(
env
,
"java/lang/OutOfMemoryError"
);
if
(
cls
!=
0
)
(
*
env
)
->
ThrowNew
(
env
,
cls
,
NULL
);
return
;
}
cls
=
(
*
env
)
->
GetObjectClass
(
env
,
obj
);
memset
(
pwd_buf
,
0
,
sizeof
(
pwd_buf
));
...
...
src/solaris/native/sun/security/smartcardio/pcsc_md.c
浏览文件 @
8f72957e
...
...
@@ -32,8 +32,6 @@
#include <winscard.h>
#include <jni_util.h>
#include "sun_security_smartcardio_PlatformPCSC.h"
#include "pcsc_md.h"
...
...
@@ -77,7 +75,6 @@ void throwIOException(JNIEnv *env, const char *msg)
throwByName
(
env
,
"java/io/IOException"
,
msg
);
}
void
*
findFunction
(
JNIEnv
*
env
,
void
*
hModule
,
char
*
functionName
)
{
void
*
fAddress
=
dlsym
(
hModule
,
functionName
);
if
(
fAddress
==
NULL
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录