* misc/mntent_r.c (__hasmntopt): Check p[optlen] even when p == rest.

Start searching for next comma at p rather than rest.
	* misc/Makefile (tests): Add tst-mntent2.
	* misc/tst-mntent2.c: New test.

	* misc/getusershell.c (initshells): Check for integer overflows.
	Make strings buffer one bigger as fgets always succeeds when second
	argument is 1.  Don't use calloc for shells array.  Disallow
	/ as shell.
This commit is contained in:
Ulrich Drepper 2006-12-09 22:31:22 +00:00
parent 66f17705e4
commit a822d9f446
4 changed files with 61 additions and 2 deletions

View File

@ -1,3 +1,15 @@
2006-12-09 Jakub Jelinek <jakub@redhat.com>
* misc/mntent_r.c (__hasmntopt): Check p[optlen] even when p == rest.
Start searching for next comma at p rather than rest.
* misc/Makefile (tests): Add tst-mntent2.
* misc/tst-mntent2.c: New test.
* misc/getusershell.c (initshells): Check for integer overflows.
Make strings buffer one bigger as fgets always succeeds when second
argument is 1. Don't use calloc for shells array. Disallow
/ as shell.
2006-12-08 Ulrich Drepper <drepper@redhat.com> 2006-12-08 Ulrich Drepper <drepper@redhat.com>
* malloc/memusage.c: Handle realloc with new size of zero and * malloc/memusage.c: Handle realloc with new size of zero and

View File

@ -1,3 +1,12 @@
2006-12-06 Jakub Jelinek <jakub@redhat.com>
* sysdeps/unix/sysv/linux/s390/s390-32/sysdep-cancel.h (PSEUDO): Handle
6 argument cancellable syscalls.
(STM_6, LM_6, LR7_0, LR7_1, LR7_2, LR7_3, LR7_4, LR7_5, LR7_6): Define.
* sysdeps/unix/sysv/linux/s390/s390-64/sysdep-cancel.h (PSEUDO): Handle
6 argument cancellable syscalls.
(STM_6, LM_6, LR7_0, LR7_1, LR7_2, LR7_3, LR7_4, LR7_5, LR7_6): Define.
2006-12-09 Ulrich Drepper <drepper@redhat.com> 2006-12-09 Ulrich Drepper <drepper@redhat.com>
* sysdeps/unix/sysv/linux/rtld-lowlevel.h * sysdeps/unix/sysv/linux/rtld-lowlevel.h

View File

@ -45,7 +45,13 @@ L(pseudo_cancel): \
bas %r14,0(%r1,%r13); \ bas %r14,0(%r1,%r13); \
lr %r0,%r2; \ lr %r0,%r2; \
LM_##args \ LM_##args \
DO_CALL(syscall_name, args); \ .if SYS_ify (syscall_name) < 256; \
svc SYS_ify (syscall_name); \
.else; \
lhi %r1,SYS_ify (syscall_name); \
svc 0; \
.endif; \
LR7_##args \
l %r1,2f-0b(%r13); \ l %r1,2f-0b(%r13); \
lr %r12,%r2; \ lr %r12,%r2; \
lr %r2,%r0; \ lr %r2,%r0; \
@ -89,6 +95,7 @@ L(pseudo_end):
#define STM_3 stm %r2,%r4,8(%r15); #define STM_3 stm %r2,%r4,8(%r15);
#define STM_4 stm %r2,%r5,8(%r15); #define STM_4 stm %r2,%r5,8(%r15);
#define STM_5 stm %r2,%r5,8(%r15); #define STM_5 stm %r2,%r5,8(%r15);
#define STM_6 stm %r2,%r7,8(%r15);
#define LM_0 /* Nothing */ #define LM_0 /* Nothing */
#define LM_1 l %r2,8+96(%r15); #define LM_1 l %r2,8+96(%r15);
@ -96,6 +103,18 @@ L(pseudo_end):
#define LM_3 lm %r2,%r4,8+96(%r15); #define LM_3 lm %r2,%r4,8+96(%r15);
#define LM_4 lm %r2,%r5,8+96(%r15); #define LM_4 lm %r2,%r5,8+96(%r15);
#define LM_5 lm %r2,%r5,8+96(%r15); #define LM_5 lm %r2,%r5,8+96(%r15);
#define LM_6 lm %r2,%r5,8+96(%r15); \
cfi_offset (%r7, -68); \
l %r7,96+96(%r15);
#define LR7_0 /* Nothing */
#define LR7_1 /* Nothing */
#define LR7_2 /* Nothing */
#define LR7_3 /* Nothing */
#define LR7_4 /* Nothing */
#define LR7_5 /* Nothing */
#define LR7_6 l %r7,28+96(%r15); \
cfi_restore (%r7);
# ifndef __ASSEMBLER__ # ifndef __ASSEMBLER__
# define SINGLE_THREAD_P \ # define SINGLE_THREAD_P \

View File

@ -42,7 +42,13 @@ L(pseudo_cancel): \
brasl %r14,CENABLE; \ brasl %r14,CENABLE; \
lgr %r0,%r2; \ lgr %r0,%r2; \
LM_##args \ LM_##args \
DO_CALL(syscall_name, args); \ .if SYS_ify (syscall_name) < 256; \
svc SYS_ify (syscall_name); \
.else; \
lghi %r1,SYS_ify (syscall_name); \
svc 0; \
.endif; \
LR7_##args \
lgr %r13,%r2; \ lgr %r13,%r2; \
lgr %r2,%r0; \ lgr %r2,%r0; \
brasl %r14,CDISABLE; \ brasl %r14,CDISABLE; \
@ -85,6 +91,7 @@ L(pseudo_end):
#define STM_3 stmg %r2,%r4,16(%r15); #define STM_3 stmg %r2,%r4,16(%r15);
#define STM_4 stmg %r2,%r5,16(%r15); #define STM_4 stmg %r2,%r5,16(%r15);
#define STM_5 stmg %r2,%r5,16(%r15); #define STM_5 stmg %r2,%r5,16(%r15);
#define STM_6 stmg %r2,%r7,16(%r15);
#define LM_0 /* Nothing */ #define LM_0 /* Nothing */
#define LM_1 lg %r2,16+160(%r15); #define LM_1 lg %r2,16+160(%r15);
@ -92,6 +99,18 @@ L(pseudo_end):
#define LM_3 lmg %r2,%r4,16+160(%r15); #define LM_3 lmg %r2,%r4,16+160(%r15);
#define LM_4 lmg %r2,%r5,16+160(%r15); #define LM_4 lmg %r2,%r5,16+160(%r15);
#define LM_5 lmg %r2,%r5,16+160(%r15); #define LM_5 lmg %r2,%r5,16+160(%r15);
#define LM_6 lmg %r2,%r5,16+160(%r15); \
cfi_offset (%r7, -104); \
lg %r7,160+160(%r15);
#define LR7_0 /* Nothing */
#define LR7_1 /* Nothing */
#define LR7_2 /* Nothing */
#define LR7_3 /* Nothing */
#define LR7_4 /* Nothing */
#define LR7_5 /* Nothing */
#define LR7_6 lg %r7,56+160(%r15); \
cfi_restore (%r7);
# if defined IS_IN_libpthread || !defined NOT_IN_libc # if defined IS_IN_libpthread || !defined NOT_IN_libc
# ifndef __ASSEMBLER__ # ifndef __ASSEMBLER__