Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
f51218f1
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看板
提交
f51218f1
编写于
5月 31, 2013
作者:
C
chegar
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
7107883: getNetworkPrefixLength() does not return correct prefix length
Reviewed-by: alanb, michaelm
上级
14cf8bf6
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
12 addition
and
7 deletion
+12
-7
src/solaris/native/java/net/NetworkInterface.c
src/solaris/native/java/net/NetworkInterface.c
+3
-6
test/java/net/InterfaceAddress/NetworkPrefixLength.java
test/java/net/InterfaceAddress/NetworkPrefixLength.java
+9
-1
未找到文件。
src/solaris/native/java/net/NetworkInterface.c
浏览文件 @
f51218f1
...
@@ -658,9 +658,9 @@ jobject createNetworkInterface(JNIEnv *env, netif *ifs) {
...
@@ -658,9 +658,9 @@ jobject createNetworkInterface(JNIEnv *env, netif *ifs) {
if
(
ia2Obj
)
{
if
(
ia2Obj
)
{
setInetAddress_addr
(
env
,
ia2Obj
,
htonl
(((
struct
sockaddr_in
*
)
addrP
->
brdcast
)
->
sin_addr
.
s_addr
));
setInetAddress_addr
(
env
,
ia2Obj
,
htonl
(((
struct
sockaddr_in
*
)
addrP
->
brdcast
)
->
sin_addr
.
s_addr
));
(
*
env
)
->
SetObjectField
(
env
,
ibObj
,
ni_ib4broadcastID
,
ia2Obj
);
(
*
env
)
->
SetObjectField
(
env
,
ibObj
,
ni_ib4broadcastID
,
ia2Obj
);
(
*
env
)
->
SetShortField
(
env
,
ibObj
,
ni_ib4maskID
,
addrP
->
mask
);
}
}
}
}
(
*
env
)
->
SetShortField
(
env
,
ibObj
,
ni_ib4maskID
,
addrP
->
mask
);
(
*
env
)
->
SetObjectArrayElement
(
env
,
bindArr
,
bind_index
++
,
ibObj
);
(
*
env
)
->
SetObjectArrayElement
(
env
,
bindArr
,
bind_index
++
,
ibObj
);
}
}
}
}
...
@@ -887,15 +887,12 @@ netif *addif(JNIEnv *env, int sock, const char * if_name,
...
@@ -887,15 +887,12 @@ netif *addif(JNIEnv *env, int sock, const char * if_name,
addrP
->
mask
=
prefix
;
addrP
->
mask
=
prefix
;
addrP
->
next
=
0
;
addrP
->
next
=
0
;
if
(
family
==
AF_INET
)
{
if
(
family
==
AF_INET
)
{
/*
// Deal with broadcast addr & subnet mask
* Deal with broadcast addr & subnet mask
*/
struct
sockaddr
*
brdcast_to
=
(
struct
sockaddr
*
)
((
char
*
)
addrP
+
sizeof
(
netaddr
)
+
addr_size
);
struct
sockaddr
*
brdcast_to
=
(
struct
sockaddr
*
)
((
char
*
)
addrP
+
sizeof
(
netaddr
)
+
addr_size
);
addrP
->
brdcast
=
getBroadcast
(
env
,
sock
,
name
,
brdcast_to
);
addrP
->
brdcast
=
getBroadcast
(
env
,
sock
,
name
,
brdcast_to
);
if
(
addrP
->
brdcast
&&
(
mask
=
getSubnet
(
env
,
sock
,
name
))
!=
-
1
)
{
if
(
(
mask
=
getSubnet
(
env
,
sock
,
name
))
!=
-
1
)
addrP
->
mask
=
mask
;
addrP
->
mask
=
mask
;
}
}
}
/**
/**
...
...
test/java/net/InterfaceAddress/NetworkPrefixLength.java
浏览文件 @
f51218f1
...
@@ -22,7 +22,7 @@
...
@@ -22,7 +22,7 @@
*/
*/
/* @test
/* @test
* @bug 6707289
* @bug 6707289
7107883
* @summary InterfaceAddress.getNetworkPrefixLength() does not conform to Javadoc
* @summary InterfaceAddress.getNetworkPrefixLength() does not conform to Javadoc
*/
*/
...
@@ -47,6 +47,14 @@ public class NetworkPrefixLength {
...
@@ -47,6 +47,14 @@ public class NetworkPrefixLength {
passed
=
false
;
passed
=
false
;
debug
(
nic
.
getName
(),
iaddr
);
debug
(
nic
.
getName
(),
iaddr
);
}
}
InetAddress
ia
=
iaddr
.
getAddress
();
if
(
ia
.
isLoopbackAddress
()
&&
ia
instanceof
Inet4Address
)
{
// assumption: prefix length will always be 8
if
(
iaddr
.
getNetworkPrefixLength
()
!=
8
)
{
out
.
println
(
"Expected prefix of 8, got "
+
iaddr
);
passed
=
false
;
}
}
}
}
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录