* 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:
Ulrich Drepper 2009-03-15 19:16:16 +00:00
parent 71a5bd3e17
commit 906dd40db3
7 changed files with 60 additions and 9 deletions

View File

@ -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]

View File

@ -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

View File

@ -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
View 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"

View File

@ -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]

View File

@ -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>";/

View File

@ -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.