* [ECOS] ipv6 question
@ 2012-12-24 6:51 cyl cyl
2012-12-31 5:06 ` [ECOS] " cyl cyl
0 siblings, 1 reply; 5+ messages in thread
From: cyl cyl @ 2012-12-24 6:51 UTC (permalink / raw)
To: eCos Users
Hello:
In function init_net_IPv6, I set "fe80::219:dbff:fea9:f3d5"
for my eth0 ipv6 address. But _show_all_interfaces says my ip is
"fe80:1::219:dbff:fea9:f3d5". I don't know why it adds a "1" in it.
The prefix I set is "fe80:0:0:0" .
ipv6: fe80::219:dbff:fea9:f3d5, in6mask64: ff ff ff ff ff ff ff ff
0xa0b53204 - eth0 - 192.168.1.239
0xa0b53220 - eth0 - fe80:1::200:ff:fe6c:18f0
0xa0b5323c - eth0 - fe80:1::219:dbff:fea9:f3d5
0xa0b53274 - lo0 - ::1
0xa0b53290 can_send: 1
--
Before posting, please read the FAQ: http://ecos.sourceware.org/fom/ecos
and search the list archive: http://ecos.sourceware.org/ml/ecos-discuss
^ permalink raw reply [flat|nested] 5+ messages in thread
* [ECOS] Re: ipv6 question
2012-12-24 6:51 [ECOS] ipv6 question cyl cyl
@ 2012-12-31 5:06 ` cyl cyl
2013-01-05 3:45 ` cyl cyl
0 siblings, 1 reply; 5+ messages in thread
From: cyl cyl @ 2012-12-31 5:06 UTC (permalink / raw)
To: eCos Users
I found it. If the ip I set is a linklocal ip (fe80) , then
s6_adr16[1] will change to ifp->if_index.
if (sa6 && sa6->sin6_family == AF_INET6) {
if (IN6_IS_ADDR_LINKLOCAL(&sa6->sin6_addr)) {
if (sa6->sin6_addr.s6_addr16[1] == 0) {
/* link ID is not embedded by the user */
sa6->sin6_addr.s6_addr16[1] =
htons(ifp->if_index);
} else if (sa6->sin6_addr.s6_addr16[1] !=
htons(ifp->if_index)) {
return(EINVAL); /* link ID contradicts */
}
So I set another IP (3ffe .....) ,and it works OK.
2012/12/24 cyl cyl <cylecos@gmail.com>:
> Hello:
>
> In function init_net_IPv6, I set "fe80::219:dbff:fea9:f3d5"
> for my eth0 ipv6 address. But _show_all_interfaces says my ip is
> "fe80:1::219:dbff:fea9:f3d5". I don't know why it adds a "1" in it.
> The prefix I set is "fe80:0:0:0" .
>
>
> ipv6: fe80::219:dbff:fea9:f3d5, in6mask64: ff ff ff ff ff ff ff ff
>
> 0xa0b53204 - eth0 - 192.168.1.239
> 0xa0b53220 - eth0 - fe80:1::200:ff:fe6c:18f0
> 0xa0b5323c - eth0 - fe80:1::219:dbff:fea9:f3d5
> 0xa0b53274 - lo0 - ::1
> 0xa0b53290 can_send: 1
--
Before posting, please read the FAQ: http://ecos.sourceware.org/fom/ecos
and search the list archive: http://ecos.sourceware.org/ml/ecos-discuss
^ permalink raw reply [flat|nested] 5+ messages in thread
* [ECOS] Re: ipv6 question
2012-12-31 5:06 ` [ECOS] " cyl cyl
@ 2013-01-05 3:45 ` cyl cyl
2013-01-05 8:20 ` cyl cyl
0 siblings, 1 reply; 5+ messages in thread
From: cyl cyl @ 2013-01-05 3:45 UTC (permalink / raw)
To: eCos Users
Hello:
Is anyone familiar with ipv6? My UDP works well now, but TCP is
not . My computer connects my ecos equipment fail .
This is ipv4 connect : (IPV4 works well.)
ISR
INT_STATUS: 8a
RPIdx 3 RCIdx 2
total_len 78 rx_status[2] = c400004d rx_len 78
lpc2xxx_eth_recv: sg_len 2
bil: 0 sg_list[0].len: 14 bnl: 14
bib: 78 buffer_pos: 0
(1) memcpy(0xA0A721DA, 0x7FE00CB8, 14) [0xA0A721DA - 0xA0A721E8]
bil: 0 sg_list[1].len: 64 bnl: 64
bib: 78 buffer_pos: 14
(2) memcpy(0xA0A3BB2C, 0x7FE00CC6, 64)[0xA0A3BB2C - 0xA0A3BB6C]
RCIdx++ 3
RPIdx 3 RCIdx 3 Iterator 2
can_send: 1
TPI: 6 TCI: 6
TX: sg_len 1, total_len 74, key 0xA0A3BB00
TPI: 7 TCI: 6
ISR
can_send: 0
INT_STATUS: ca
TX finished - key: 0xA0A3BB00
This is IPV6 connect :
ISR
INT_STATUS: 8a
RPIdx 3 RCIdx 2
total_len 98 rx_status[2] = c4000061 rx_len 98
lpc2xxx_eth_recv: sg_len 2
bil: 0 sg_list[0].len: 14 bnl: 14
bib: 98 buffer_pos: 0
(1) memcpy(0xA0A721DA, 0x7FE00CB8, 14) [0xA0A721DA - 0xA0A721E8]
bil: 0 sg_list[1].len: 84 bnl: 84
bib: 98 buffer_pos: 14
(2) memcpy(0xA0A3B7AC, 0x7FE00CC6, 84)[0xA0A3B7AC - 0xA0A3B800]
RCIdx++ 3
RPIdx 3 RCIdx 3 Iterator 2
can_send: 1
TPI: 6 TCI: 6
TX: sg_len 2, total_len 74, key 0xA0A3BA00
TPI: 8 TCI: 6
ISR
can_send: 0
INT_STATUS: c2
TX finished - key: 0xA0A3BA00
The "tx total_len" of ipv4 and ipv6 both are 74. I'm not familiar with
TCP/IP but I think They should not be the same. Does anyone hit this
problem before?
2012/12/31 cyl cyl <cylecos@gmail.com>:
> I found it. If the ip I set is a linklocal ip (fe80) , then
> s6_adr16[1] will change to ifp->if_index.
>
> if (sa6 && sa6->sin6_family == AF_INET6) {
> if (IN6_IS_ADDR_LINKLOCAL(&sa6->sin6_addr)) {
> if (sa6->sin6_addr.s6_addr16[1] == 0) {
> /* link ID is not embedded by the user */
> sa6->sin6_addr.s6_addr16[1] =
> htons(ifp->if_index);
> } else if (sa6->sin6_addr.s6_addr16[1] !=
> htons(ifp->if_index)) {
> return(EINVAL); /* link ID contradicts */
> }
>
> So I set another IP (3ffe .....) ,and it works OK.
>
> 2012/12/24 cyl cyl <cylecos@gmail.com>:
>> Hello:
>>
>> In function init_net_IPv6, I set "fe80::219:dbff:fea9:f3d5"
>> for my eth0 ipv6 address. But _show_all_interfaces says my ip is
>> "fe80:1::219:dbff:fea9:f3d5". I don't know why it adds a "1" in it.
>> The prefix I set is "fe80:0:0:0" .
>>
>>
>> ipv6: fe80::219:dbff:fea9:f3d5, in6mask64: ff ff ff ff ff ff ff ff
>>
>> 0xa0b53204 - eth0 - 192.168.1.239
>> 0xa0b53220 - eth0 - fe80:1::200:ff:fe6c:18f0
>> 0xa0b5323c - eth0 - fe80:1::219:dbff:fea9:f3d5
>> 0xa0b53274 - lo0 - ::1
>> 0xa0b53290 can_send: 1
--
Before posting, please read the FAQ: http://ecos.sourceware.org/fom/ecos
and search the list archive: http://ecos.sourceware.org/ml/ecos-discuss
^ permalink raw reply [flat|nested] 5+ messages in thread
* [ECOS] Re: ipv6 question
2013-01-05 3:45 ` cyl cyl
@ 2013-01-05 8:20 ` cyl cyl
2013-01-06 4:19 ` cyl cyl
0 siblings, 1 reply; 5+ messages in thread
From: cyl cyl @ 2013-01-05 8:20 UTC (permalink / raw)
To: eCos Users
I used wireshark . And found the reset bit of the response package was
set 1. May anyone tell me which file or function does this work? So I
can trace it.
Flags: 0x014 (RST, ACK)
2013/1/5 cyl cyl <cylecos@gmail.com>:
> Hello:
> Is anyone familiar with ipv6? My UDP works well now, but TCP is
> not . My computer connects my ecos equipment fail .
>
> This is ipv4 connect : (IPV4 works well.)
>
> ISR
> INT_STATUS: 8a
>
>
> RPIdx 3 RCIdx 2
> total_len 78 rx_status[2] = c400004d rx_len 78
> lpc2xxx_eth_recv: sg_len 2
> bil: 0 sg_list[0].len: 14 bnl: 14
> bib: 78 buffer_pos: 0
> (1) memcpy(0xA0A721DA, 0x7FE00CB8, 14) [0xA0A721DA - 0xA0A721E8]
> bil: 0 sg_list[1].len: 64 bnl: 64
> bib: 78 buffer_pos: 14
> (2) memcpy(0xA0A3BB2C, 0x7FE00CC6, 64)[0xA0A3BB2C - 0xA0A3BB6C]
> RCIdx++ 3
> RPIdx 3 RCIdx 3 Iterator 2
> can_send: 1
> TPI: 6 TCI: 6
> TX: sg_len 1, total_len 74, key 0xA0A3BB00
> TPI: 7 TCI: 6
> ISR
> can_send: 0
> INT_STATUS: ca
> TX finished - key: 0xA0A3BB00
>
> This is IPV6 connect :
>
> ISR
> INT_STATUS: 8a
>
>
> RPIdx 3 RCIdx 2
> total_len 98 rx_status[2] = c4000061 rx_len 98
> lpc2xxx_eth_recv: sg_len 2
> bil: 0 sg_list[0].len: 14 bnl: 14
> bib: 98 buffer_pos: 0
> (1) memcpy(0xA0A721DA, 0x7FE00CB8, 14) [0xA0A721DA - 0xA0A721E8]
> bil: 0 sg_list[1].len: 84 bnl: 84
> bib: 98 buffer_pos: 14
> (2) memcpy(0xA0A3B7AC, 0x7FE00CC6, 84)[0xA0A3B7AC - 0xA0A3B800]
> RCIdx++ 3
> RPIdx 3 RCIdx 3 Iterator 2
> can_send: 1
> TPI: 6 TCI: 6
> TX: sg_len 2, total_len 74, key 0xA0A3BA00
> TPI: 8 TCI: 6
> ISR
> can_send: 0
> INT_STATUS: c2
> TX finished - key: 0xA0A3BA00
>
> The "tx total_len" of ipv4 and ipv6 both are 74. I'm not familiar with
> TCP/IP but I think They should not be the same. Does anyone hit this
> problem before?
>
> 2012/12/31 cyl cyl <cylecos@gmail.com>:
>> I found it. If the ip I set is a linklocal ip (fe80) , then
>> s6_adr16[1] will change to ifp->if_index.
>>
>> if (sa6 && sa6->sin6_family == AF_INET6) {
>> if (IN6_IS_ADDR_LINKLOCAL(&sa6->sin6_addr)) {
>> if (sa6->sin6_addr.s6_addr16[1] == 0) {
>> /* link ID is not embedded by the user */
>> sa6->sin6_addr.s6_addr16[1] =
>> htons(ifp->if_index);
>> } else if (sa6->sin6_addr.s6_addr16[1] !=
>> htons(ifp->if_index)) {
>> return(EINVAL); /* link ID contradicts */
>> }
>>
>> So I set another IP (3ffe .....) ,and it works OK.
>>
>> 2012/12/24 cyl cyl <cylecos@gmail.com>:
>>> Hello:
>>>
>>> In function init_net_IPv6, I set "fe80::219:dbff:fea9:f3d5"
>>> for my eth0 ipv6 address. But _show_all_interfaces says my ip is
>>> "fe80:1::219:dbff:fea9:f3d5". I don't know why it adds a "1" in it.
>>> The prefix I set is "fe80:0:0:0" .
>>>
>>>
>>> ipv6: fe80::219:dbff:fea9:f3d5, in6mask64: ff ff ff ff ff ff ff ff
>>>
>>> 0xa0b53204 - eth0 - 192.168.1.239
>>> 0xa0b53220 - eth0 - fe80:1::200:ff:fe6c:18f0
>>> 0xa0b5323c - eth0 - fe80:1::219:dbff:fea9:f3d5
>>> 0xa0b53274 - lo0 - ::1
>>> 0xa0b53290 can_send: 1
--
Before posting, please read the FAQ: http://ecos.sourceware.org/fom/ecos
and search the list archive: http://ecos.sourceware.org/ml/ecos-discuss
^ permalink raw reply [flat|nested] 5+ messages in thread
* [ECOS] Re: ipv6 question
2013-01-05 8:20 ` cyl cyl
@ 2013-01-06 4:19 ` cyl cyl
0 siblings, 0 replies; 5+ messages in thread
From: cyl cyl @ 2013-01-06 4:19 UTC (permalink / raw)
To: eCos Users
I think it's a little bug in in6_pcbbind(inp, nam, p) of file in6_pcb.c
I add
if (nam->sa_len == 0) nam->sa_len = sizeof(*sin6); (IPV4 bind
already added it)
And it's OK now.
2013/1/5 cyl cyl <cylecos@gmail.com>:
> I used wireshark . And found the reset bit of the response package was
> set 1. May anyone tell me which file or function does this work? So I
> can trace it.
>
> Flags: 0x014 (RST, ACK)
>
>
>
> 2013/1/5 cyl cyl <cylecos@gmail.com>:
>> Hello:
>> Is anyone familiar with ipv6? My UDP works well now, but TCP is
>> not . My computer connects my ecos equipment fail .
>>
>> This is ipv4 connect : (IPV4 works well.)
>>
>> ISR
>> INT_STATUS: 8a
>>
>>
>> RPIdx 3 RCIdx 2
>> total_len 78 rx_status[2] = c400004d rx_len 78
>> lpc2xxx_eth_recv: sg_len 2
>> bil: 0 sg_list[0].len: 14 bnl: 14
>> bib: 78 buffer_pos: 0
>> (1) memcpy(0xA0A721DA, 0x7FE00CB8, 14) [0xA0A721DA - 0xA0A721E8]
>> bil: 0 sg_list[1].len: 64 bnl: 64
>> bib: 78 buffer_pos: 14
>> (2) memcpy(0xA0A3BB2C, 0x7FE00CC6, 64)[0xA0A3BB2C - 0xA0A3BB6C]
>> RCIdx++ 3
>> RPIdx 3 RCIdx 3 Iterator 2
>> can_send: 1
>> TPI: 6 TCI: 6
>> TX: sg_len 1, total_len 74, key 0xA0A3BB00
>> TPI: 7 TCI: 6
>> ISR
>> can_send: 0
>> INT_STATUS: ca
>> TX finished - key: 0xA0A3BB00
>>
>> This is IPV6 connect :
>>
>> ISR
>> INT_STATUS: 8a
>>
>>
>> RPIdx 3 RCIdx 2
>> total_len 98 rx_status[2] = c4000061 rx_len 98
>> lpc2xxx_eth_recv: sg_len 2
>> bil: 0 sg_list[0].len: 14 bnl: 14
>> bib: 98 buffer_pos: 0
>> (1) memcpy(0xA0A721DA, 0x7FE00CB8, 14) [0xA0A721DA - 0xA0A721E8]
>> bil: 0 sg_list[1].len: 84 bnl: 84
>> bib: 98 buffer_pos: 14
>> (2) memcpy(0xA0A3B7AC, 0x7FE00CC6, 84)[0xA0A3B7AC - 0xA0A3B800]
>> RCIdx++ 3
>> RPIdx 3 RCIdx 3 Iterator 2
>> can_send: 1
>> TPI: 6 TCI: 6
>> TX: sg_len 2, total_len 74, key 0xA0A3BA00
>> TPI: 8 TCI: 6
>> ISR
>> can_send: 0
>> INT_STATUS: c2
>> TX finished - key: 0xA0A3BA00
>>
>> The "tx total_len" of ipv4 and ipv6 both are 74. I'm not familiar with
>> TCP/IP but I think They should not be the same. Does anyone hit this
>> problem before?
>>
>> 2012/12/31 cyl cyl <cylecos@gmail.com>:
>>> I found it. If the ip I set is a linklocal ip (fe80) , then
>>> s6_adr16[1] will change to ifp->if_index.
>>>
>>> if (sa6 && sa6->sin6_family == AF_INET6) {
>>> if (IN6_IS_ADDR_LINKLOCAL(&sa6->sin6_addr)) {
>>> if (sa6->sin6_addr.s6_addr16[1] == 0) {
>>> /* link ID is not embedded by the user */
>>> sa6->sin6_addr.s6_addr16[1] =
>>> htons(ifp->if_index);
>>> } else if (sa6->sin6_addr.s6_addr16[1] !=
>>> htons(ifp->if_index)) {
>>> return(EINVAL); /* link ID contradicts */
>>> }
>>>
>>> So I set another IP (3ffe .....) ,and it works OK.
>>>
>>> 2012/12/24 cyl cyl <cylecos@gmail.com>:
>>>> Hello:
>>>>
>>>> In function init_net_IPv6, I set "fe80::219:dbff:fea9:f3d5"
>>>> for my eth0 ipv6 address. But _show_all_interfaces says my ip is
>>>> "fe80:1::219:dbff:fea9:f3d5". I don't know why it adds a "1" in it.
>>>> The prefix I set is "fe80:0:0:0" .
>>>>
>>>>
>>>> ipv6: fe80::219:dbff:fea9:f3d5, in6mask64: ff ff ff ff ff ff ff ff
>>>>
>>>> 0xa0b53204 - eth0 - 192.168.1.239
>>>> 0xa0b53220 - eth0 - fe80:1::200:ff:fe6c:18f0
>>>> 0xa0b5323c - eth0 - fe80:1::219:dbff:fea9:f3d5
>>>> 0xa0b53274 - lo0 - ::1
>>>> 0xa0b53290 can_send: 1
--
Before posting, please read the FAQ: http://ecos.sourceware.org/fom/ecos
and search the list archive: http://ecos.sourceware.org/ml/ecos-discuss
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2013-01-06 4:19 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2012-12-24 6:51 [ECOS] ipv6 question cyl cyl
2012-12-31 5:06 ` [ECOS] " cyl cyl
2013-01-05 3:45 ` cyl cyl
2013-01-05 8:20 ` cyl cyl
2013-01-06 4:19 ` cyl cyl
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).