Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
de8a64df
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看板
提交
de8a64df
编写于
1月 25, 2010
作者:
C
chegar
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
6707289: InterfaceAddress.getNetworkPrefixLength() does not conform to Javadoc
Reviewed-by: michaelm
上级
15e5d3d4
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
107 addition
and
7 deletion
+107
-7
src/windows/native/java/net/NetworkInterface_winXP.c
src/windows/native/java/net/NetworkInterface_winXP.c
+23
-7
test/java/net/InterfaceAddress/NetworkPrefixLength.java
test/java/net/InterfaceAddress/NetworkPrefixLength.java
+84
-0
未找到文件。
src/windows/native/java/net/NetworkInterface_winXP.c
浏览文件 @
de8a64df
...
@@ -172,7 +172,7 @@ int getAllInterfacesAndAddresses (JNIEnv *env, netif **netifPP)
...
@@ -172,7 +172,7 @@ int getAllInterfacesAndAddresses (JNIEnv *env, netif **netifPP)
DWORD
ret
;
DWORD
ret
;
IP_ADAPTER_ADDRESSES
*
ptr
,
*
adapters
=
0
;
IP_ADAPTER_ADDRESSES
*
ptr
,
*
adapters
=
0
;
ULONG
len
=
ipinflen
,
count
=
0
;
ULONG
len
=
ipinflen
,
count
=
0
;
netif
*
nif
=
0
,
*
dup_nif
,
*
last
=
0
,
*
loopif
=
0
;
netif
*
nif
=
0
,
*
dup_nif
,
*
last
=
0
,
*
loopif
=
0
,
*
curr
;
int
tun
=
0
,
net
=
0
;
int
tun
=
0
,
net
=
0
;
*
netifPP
=
0
;
*
netifPP
=
0
;
...
@@ -197,6 +197,20 @@ int getAllInterfacesAndAddresses (JNIEnv *env, netif **netifPP)
...
@@ -197,6 +197,20 @@ int getAllInterfacesAndAddresses (JNIEnv *env, netif **netifPP)
last
=
nif
;
last
=
nif
;
}
}
// Retrieve IPv4 addresses with the IP Helper API
curr
=
*
netifPP
;
while
(
curr
!=
NULL
)
{
netaddr
*
netaddrP
;
ret
=
enumAddresses_win
(
env
,
curr
,
&
netaddrP
);
if
((
*
env
)
->
ExceptionOccurred
(
env
))
{
free_netaddr
(
netaddrP
);
return
-
1
;
}
curr
->
addrs
=
netaddrP
;
curr
->
naddrs
+=
ret
;
curr
=
curr
->
next
;
}
ret
=
getAdapters
(
env
,
&
adapters
);
ret
=
getAdapters
(
env
,
&
adapters
);
if
(
ret
!=
ERROR_SUCCESS
)
{
if
(
ret
!=
ERROR_SUCCESS
)
{
goto
err
;
goto
err
;
...
@@ -350,6 +364,14 @@ static int getAddrsFromAdapter(IP_ADAPTER_ADDRESSES *ptr, netaddr **netaddrPP) {
...
@@ -350,6 +364,14 @@ static int getAddrsFromAdapter(IP_ADAPTER_ADDRESSES *ptr, netaddr **netaddrPP) {
/* address is only usable if dad state is preferred or deprecated */
/* address is only usable if dad state is preferred or deprecated */
if
(
uni_addr
->
DadState
==
IpDadStateDeprecated
||
if
(
uni_addr
->
DadState
==
IpDadStateDeprecated
||
uni_addr
->
DadState
==
IpDadStatePreferred
)
{
uni_addr
->
DadState
==
IpDadStatePreferred
)
{
sock
=
uni_addr
->
Address
.
lpSockaddr
;
// IPv4 addresses already retrieved with enumAddresses_win
if
(
sock
->
sa_family
==
AF_INET
)
{
uni_addr
=
uni_addr
->
Next
;
continue
;
}
curr
=
(
netaddr
*
)
calloc
(
1
,
sizeof
(
netaddr
));
curr
=
(
netaddr
*
)
calloc
(
1
,
sizeof
(
netaddr
));
if
(
curr
==
0
)
{
if
(
curr
==
0
)
{
return
-
1
;
return
-
1
;
...
@@ -361,15 +383,9 @@ static int getAddrsFromAdapter(IP_ADAPTER_ADDRESSES *ptr, netaddr **netaddrPP) {
...
@@ -361,15 +383,9 @@ static int getAddrsFromAdapter(IP_ADAPTER_ADDRESSES *ptr, netaddr **netaddrPP) {
prev
->
next
=
curr
;
prev
->
next
=
curr
;
}
}
prev
=
curr
;
prev
=
curr
;
sock
=
uni_addr
->
Address
.
lpSockaddr
;
SOCKETADDRESS_COPY
(
&
curr
->
addr
,
sock
);
SOCKETADDRESS_COPY
(
&
curr
->
addr
,
sock
);
if
(
prefix
!=
NULL
)
{
if
(
prefix
!=
NULL
)
{
curr
->
mask
=
(
short
)
prefix
->
PrefixLength
;
curr
->
mask
=
(
short
)
prefix
->
PrefixLength
;
if
(
sock
->
sa_family
==
AF_INET
)
{
sock
=
prefix
->
Address
.
lpSockaddr
;
SOCKETADDRESS_COPY
(
&
curr
->
brdcast
,
sock
);
curr
->
brdcast
.
him4
.
sin_addr
.
s_addr
|=
htonl
((
0xffffffff
>>
curr
->
mask
));
}
prefix
=
prefix
->
Next
;
prefix
=
prefix
->
Next
;
}
}
count
++
;
count
++
;
...
...
test/java/net/InterfaceAddress/NetworkPrefixLength.java
0 → 100644
浏览文件 @
de8a64df
/*
* Copyright 2010 Sun Microsystems, Inc. All Rights Reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
* CA 95054 USA or visit www.sun.com if you need additional information or
* have any questions.
*/
/* @test
* @bug 6707289
* @summary InterfaceAddress.getNetworkPrefixLength() does not conform to Javadoc
*/
import
java.net.InetAddress
;
import
java.net.Inet4Address
;
import
java.net.InterfaceAddress
;
import
java.net.NetworkInterface
;
import
java.util.Enumeration
;
import
static
java
.
lang
.
System
.
out
;
public
class
NetworkPrefixLength
{
static
boolean
passed
=
true
;
public
static
void
main
(
String
[]
args
)
throws
Exception
{
Enumeration
<
NetworkInterface
>
nics
=
NetworkInterface
.
getNetworkInterfaces
();
while
(
nics
.
hasMoreElements
())
{
NetworkInterface
nic
=
nics
.
nextElement
();
for
(
InterfaceAddress
iaddr
:
nic
.
getInterfaceAddresses
())
{
boolean
valid
=
checkPrefix
(
iaddr
);
if
(!
valid
)
{
passed
=
false
;
debug
(
nic
.
getName
(),
iaddr
);
}
}
}
if
(!
passed
)
throw
new
RuntimeException
(
"Failed: some interfaces have invalid prefix lengths"
);
}
static
boolean
checkPrefix
(
InterfaceAddress
iaddr
)
{
InetAddress
addr
=
iaddr
.
getAddress
();
if
(
addr
instanceof
Inet4Address
)
return
checkIPv4PrefixLength
(
iaddr
.
getNetworkPrefixLength
());
else
return
checkIPv6PrefixLength
(
iaddr
.
getNetworkPrefixLength
());
}
static
boolean
checkIPv4PrefixLength
(
int
prefix
)
{
if
(
prefix
>=
0
&&
prefix
<=
32
)
return
true
;
return
false
;
}
static
boolean
checkIPv6PrefixLength
(
int
prefix
)
{
if
(
prefix
>=
0
&&
prefix
<=
128
)
return
true
;
return
false
;
}
static
void
debug
(
String
nicName
,
InterfaceAddress
iaddr
)
{
out
.
println
(
"NIC "
+
nicName
+
" has an address with an invalid prefix length:\n"
+
iaddr
);
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录