mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-18 06:30:05 +00:00
[BZ #9881]
* inet/inet6_rth.c (inet6_rth_add): Add some error checking. Patch mostly by Yang Hongyang <yanghy@cn.fujitsu.com>. * inet/Makefile (tests): Add tst-inet6_rth. * inet/tst-inet6_rth.c: New file. alignment of La_x86_64_regs. Store xmm parameters.
This commit is contained in:
parent
71a5bd3e17
commit
906dd40db3
@ -1,5 +1,11 @@
|
|||||||
2009-03-15 Ulrich Drepper <drepper@redhat.com>
|
2009-03-15 Ulrich Drepper <drepper@redhat.com>
|
||||||
|
|
||||||
|
[BZ #9881]
|
||||||
|
* inet/inet6_rth.c (inet6_rth_add): Add some error checking.
|
||||||
|
Patch mostly by Yang Hongyang <yanghy@cn.fujitsu.com>.
|
||||||
|
* inet/Makefile (tests): Add tst-inet6_rth.
|
||||||
|
* inet/tst-inet6_rth.c: New file.
|
||||||
|
|
||||||
[BZ #5807]
|
[BZ #5807]
|
||||||
* string/strlen.c (strlen): Fix omission in the expression to test
|
* string/strlen.c (strlen): Fix omission in the expression to test
|
||||||
for NUL bytes.
|
for NUL bytes.
|
||||||
@ -22,7 +28,7 @@
|
|||||||
|
|
||||||
[BZ #9893]
|
[BZ #9893]
|
||||||
* sysdeps/x86_64/dl-trampoline.S (_dl_runtime_profile): Fix
|
* sysdeps/x86_64/dl-trampoline.S (_dl_runtime_profile): Fix
|
||||||
alignement of La_x86_64_regs. Store xmm parameters.
|
alignment of La_x86_64_regs. Store xmm parameters.
|
||||||
Patch mostly by Jiri Olsa <olsajiri@gmail.com>.
|
Patch mostly by Jiri Olsa <olsajiri@gmail.com>.
|
||||||
|
|
||||||
[BZ #9913]
|
[BZ #9913]
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# Copyright (C) 1991-2006, 2007 Free Software Foundation, Inc.
|
# Copyright (C) 1991-2006, 2007, 2009 Free Software Foundation, Inc.
|
||||||
# This file is part of the GNU C Library.
|
# This file is part of the GNU C Library.
|
||||||
|
|
||||||
# The GNU C Library is free software; you can redistribute it and/or
|
# The GNU C Library is free software; you can redistribute it and/or
|
||||||
@ -53,7 +53,7 @@ aux := check_pf check_native ifreq
|
|||||||
|
|
||||||
tests := htontest test_ifindex tst-ntoa tst-ether_aton tst-network \
|
tests := htontest test_ifindex tst-ntoa tst-ether_aton tst-network \
|
||||||
tst-gethnm test-ifaddrs bug-if1 test-inet6_opt tst-ether_line \
|
tst-gethnm test-ifaddrs bug-if1 test-inet6_opt tst-ether_line \
|
||||||
tst-getni1 tst-getni2
|
tst-getni1 tst-getni2 tst-inet6_rth
|
||||||
|
|
||||||
include ../Rules
|
include ../Rules
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* Copyright (C) 2006 Free Software Foundation, Inc.
|
/* Copyright (C) 2006, 2009 Free Software Foundation, Inc.
|
||||||
This file is part of the GNU C Library.
|
This file is part of the GNU C Library.
|
||||||
Contributed by Ulrich Drepper <drepper@redhat.com>, 2006.
|
Contributed by Ulrich Drepper <drepper@redhat.com>, 2006.
|
||||||
|
|
||||||
@ -93,6 +93,9 @@ inet6_rth_add (void *bp, const struct in6_addr *addr)
|
|||||||
struct ip6_rthdr0 *rthdr0;
|
struct ip6_rthdr0 *rthdr0;
|
||||||
case IPV6_RTHDR_TYPE_0:
|
case IPV6_RTHDR_TYPE_0:
|
||||||
rthdr0 = (struct ip6_rthdr0 *) rthdr;
|
rthdr0 = (struct ip6_rthdr0 *) rthdr;
|
||||||
|
if (rthdr0->ip6r0_len * 8 / sizeof (struct in6_addr)
|
||||||
|
- rthdr0->ip6r0_segleft < 1)
|
||||||
|
return -1;
|
||||||
|
|
||||||
memcpy (&rthdr0->ip6r0_addr[rthdr0->ip6r0_segleft++],
|
memcpy (&rthdr0->ip6r0_addr[rthdr0->ip6r0_segleft++],
|
||||||
addr, sizeof (struct in6_addr));
|
addr, sizeof (struct in6_addr));
|
||||||
|
36
inet/tst-inet6_rth.c
Normal file
36
inet/tst-inet6_rth.c
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
#include <netinet/ip6.h>
|
||||||
|
|
||||||
|
static int
|
||||||
|
do_test (void)
|
||||||
|
{
|
||||||
|
int res = 0;
|
||||||
|
char buf[1000];
|
||||||
|
void *p = inet6_rth_init (buf, 24, IPV6_RTHDR_TYPE_0, 0);
|
||||||
|
if (p == NULL)
|
||||||
|
{
|
||||||
|
puts ("first inet6_rth_init failed");
|
||||||
|
res = 1;
|
||||||
|
}
|
||||||
|
else if (inet6_rth_add (p, &in6addr_any) == 0)
|
||||||
|
{
|
||||||
|
puts ("first inet6_rth_add succeeded");
|
||||||
|
res = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
p = inet6_rth_init (buf, 24, IPV6_RTHDR_TYPE_0, 1);
|
||||||
|
if (p == NULL)
|
||||||
|
{
|
||||||
|
puts ("second inet6_rth_init failed");
|
||||||
|
res = 1;
|
||||||
|
}
|
||||||
|
else if (inet6_rth_add (p, &in6addr_any) != 0)
|
||||||
|
{
|
||||||
|
puts ("second inet6_rth_add failed");
|
||||||
|
res = 1;
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
#define TEST_FUNCTION do_test ()
|
||||||
|
#include "../test-skeleton.c"
|
@ -1,3 +1,9 @@
|
|||||||
|
2009-03-15 Ulrich Drepper <drepper@redhat.com>
|
||||||
|
|
||||||
|
[BZ #9891]
|
||||||
|
* locales/mt_MT: Fix spelling of August (Awwissu).
|
||||||
|
Patch by Martin Pitt.
|
||||||
|
|
||||||
2009-03-14 Ulrich Drepper <drepper@redhat.com>
|
2009-03-14 Ulrich Drepper <drepper@redhat.com>
|
||||||
|
|
||||||
[BZ #9916]
|
[BZ #9916]
|
||||||
|
@ -188,7 +188,7 @@ day "<U0069><U006C><U002D><U0126><U0061><U0064><U0064>";/
|
|||||||
abmon "<U004A><U0061><U006E>";"<U0046><U0072><U0061>";/
|
abmon "<U004A><U0061><U006E>";"<U0046><U0072><U0061>";/
|
||||||
"<U004D><U0061><U0072>";"<U0041><U0070><U0072>";/
|
"<U004D><U0061><U0072>";"<U0041><U0070><U0072>";/
|
||||||
"<U004D><U0065><U006A>";"<U0120><U0075><U006E>";/
|
"<U004D><U0065><U006A>";"<U0120><U0075><U006E>";/
|
||||||
"<U004C><U0075><U006C>";"<U0041><U0077><U0069>";/
|
"<U004C><U0075><U006C>";"<U0041><U0077><U0077>";/
|
||||||
"<U0053><U0065><U0074>";"<U004F><U0074><U0074>";/
|
"<U0053><U0065><U0074>";"<U004F><U0074><U0074>";/
|
||||||
"<U004E><U006F><U0076>";"<U0044><U0069><U010B>"
|
"<U004E><U006F><U0076>";"<U0044><U0069><U010B>"
|
||||||
%
|
%
|
||||||
@ -200,7 +200,7 @@ mon "<U004A><U0061><U006E><U006E><U0061><U0072>";/
|
|||||||
"<U004D><U0065><U006A><U006A><U0075>";/
|
"<U004D><U0065><U006A><U006A><U0075>";/
|
||||||
"<U0120><U0075><U006E><U006A><U0075>";/
|
"<U0120><U0075><U006E><U006A><U0075>";/
|
||||||
"<U004C><U0075><U006C><U006A><U0075>";/
|
"<U004C><U0075><U006C><U006A><U0075>";/
|
||||||
"<U0041><U0077><U0069><U0073><U0073><U0075>";/
|
"<U0041><U0077><U0077><U0069><U0073><U0073><U0075>";/
|
||||||
"<U0053><U0065><U0074><U0074><U0065><U006D><U0062><U0072><U0075>";/
|
"<U0053><U0065><U0074><U0074><U0065><U006D><U0062><U0072><U0075>";/
|
||||||
"<U004F><U0074><U0074><U0075><U0062><U0072><U0075>";/
|
"<U004F><U0074><U0074><U0075><U0062><U0072><U0075>";/
|
||||||
"<U004E><U006F><U0076><U0065><U006D><U0062><U0072><U0075>";/
|
"<U004E><U006F><U0076><U0065><U006D><U0062><U0072><U0075>";/
|
||||||
|
@ -35,7 +35,7 @@ _dl_runtime_resolve:
|
|||||||
movq %r8, 40(%rsp)
|
movq %r8, 40(%rsp)
|
||||||
movq %r9, 48(%rsp)
|
movq %r9, 48(%rsp)
|
||||||
movq 64(%rsp), %rsi # Copy args pushed by PLT in register.
|
movq 64(%rsp), %rsi # Copy args pushed by PLT in register.
|
||||||
movq 56(%rsp), %rdi # %rdi: link_map, %rsi: reloc_offset
|
movq 56(%rsp), %rdi # %rdi: link_map, %rsi: reloc_index
|
||||||
call _dl_fixup # Call resolver.
|
call _dl_fixup # Call resolver.
|
||||||
movq %rax, %r11 # Save return value
|
movq %rax, %r11 # Save return value
|
||||||
movq 48(%rsp), %r9 # Get register content back.
|
movq 48(%rsp), %r9 # Get register content back.
|
||||||
@ -112,7 +112,7 @@ _dl_runtime_profile:
|
|||||||
movq %rsp, %rcx # La_x86_64_regs pointer to %rcx.
|
movq %rsp, %rcx # La_x86_64_regs pointer to %rcx.
|
||||||
movq 48(%rbx), %rdx # Load return address if needed.
|
movq 48(%rbx), %rdx # Load return address if needed.
|
||||||
movq 40(%rbx), %rsi # Copy args pushed by PLT in register.
|
movq 40(%rbx), %rsi # Copy args pushed by PLT in register.
|
||||||
movq 32(%rbx), %rdi # %rdi: link_map, %rsi: reloc_offset
|
movq 32(%rbx), %rdi # %rdi: link_map, %rsi: reloc_index
|
||||||
leaq 16(%rbx), %r8
|
leaq 16(%rbx), %r8
|
||||||
call _dl_profile_fixup # Call resolver.
|
call _dl_profile_fixup # Call resolver.
|
||||||
|
|
||||||
@ -196,7 +196,7 @@ _dl_runtime_profile:
|
|||||||
|
|
||||||
movq 24(%rbx), %rdx # La_x86_64_regs argument to %rdx.
|
movq 24(%rbx), %rdx # La_x86_64_regs argument to %rdx.
|
||||||
movq 40(%rbx), %rsi # Copy args pushed by PLT in register.
|
movq 40(%rbx), %rsi # Copy args pushed by PLT in register.
|
||||||
movq 32(%rbx), %rdi # %rdi: link_map, %rsi: reloc_offset
|
movq 32(%rbx), %rdi # %rdi: link_map, %rsi: reloc_index
|
||||||
call _dl_call_pltexit
|
call _dl_call_pltexit
|
||||||
|
|
||||||
movq (%rsp), %rax # Restore return registers.
|
movq (%rsp), %rax # Restore return registers.
|
||||||
|
Loading…
Reference in New Issue
Block a user