mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-03 08:11:08 +00:00
Thu Feb 15 13:57:08 1996 Roland McGrath <roland@charlie-brown.gnu.ai.mit.edu>
* mach/Machrules: Use -include for $(*.ir). * hurd/hurd/ioctl.h (_HURD_HANDLE_IOCTLS): Mask off type bits in request values. * sysdeps/mach/hurd/ioctls.h (_IOC_NOTYPE): New macro. (_IOT_COUNT2): Field is 3 bits, not 2. * sysdeps/mach/hurd/ioctl.c: Ignore handler if it fails with ENOTTY. * hurd/hurdioctl.c (_hurd_lookup_ioctl_handler): Mask off type bits before looking up handler. (fioctl): Use __hurd_dfail. (fioctl, fioclex): Use ENOTTY for bogus request instead of EGRATUITOUS. Wed Feb 14 00:21:17 1996 David Mosberger-Tang <davidm@azstarnet.com> * sysdeps/alpha/memchr.c (memchr): loop searching for matching character bailed out one too early; changed constant 6 to 7 to fix this.
This commit is contained in:
parent
a1c46301bb
commit
9e3db9cd59
20
ChangeLog
20
ChangeLog
@ -1,3 +1,23 @@
|
|||||||
|
Thu Feb 15 13:57:08 1996 Roland McGrath <roland@charlie-brown.gnu.ai.mit.edu>
|
||||||
|
|
||||||
|
* mach/Machrules: Use -include for $(*.ir).
|
||||||
|
|
||||||
|
* hurd/hurd/ioctl.h (_HURD_HANDLE_IOCTLS): Mask off type bits in
|
||||||
|
request values.
|
||||||
|
* sysdeps/mach/hurd/ioctls.h (_IOC_NOTYPE): New macro.
|
||||||
|
(_IOT_COUNT2): Field is 3 bits, not 2.
|
||||||
|
* sysdeps/mach/hurd/ioctl.c: Ignore handler if it fails with ENOTTY.
|
||||||
|
* hurd/hurdioctl.c (_hurd_lookup_ioctl_handler): Mask off type
|
||||||
|
bits before looking up handler.
|
||||||
|
(fioctl): Use __hurd_dfail.
|
||||||
|
(fioctl, fioclex): Use ENOTTY for bogus request instead of EGRATUITOUS.
|
||||||
|
|
||||||
|
Wed Feb 14 00:21:17 1996 David Mosberger-Tang <davidm@azstarnet.com>
|
||||||
|
|
||||||
|
* sysdeps/alpha/memchr.c (memchr): loop searching for matching
|
||||||
|
character bailed out one too early; changed constant 6 to
|
||||||
|
7 to fix this.
|
||||||
|
|
||||||
Wed Feb 14 01:08:58 1996 Roland McGrath <roland@charlie-brown.gnu.ai.mit.edu>
|
Wed Feb 14 01:08:58 1996 Roland McGrath <roland@charlie-brown.gnu.ai.mit.edu>
|
||||||
|
|
||||||
* posix/execvp.c: When executing shell on script, first arg is
|
* posix/execvp.c: When executing shell on script, first arg is
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/* User-registered handlers for specific `ioctl' requests.
|
/* User-registered handlers for specific `ioctl' requests.
|
||||||
Copyright (C) 1993, 1994, 1995 Free Software Foundation, Inc.
|
Copyright (C) 1993, 1994, 1995, 1996 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
|
||||||
@ -22,6 +22,7 @@ Cambridge, MA 02139, USA. */
|
|||||||
|
|
||||||
#define __need___va_list
|
#define __need___va_list
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
|
#include <ioctls.h>
|
||||||
|
|
||||||
|
|
||||||
/* Type of handler function, called like ioctl to do its entire job. */
|
/* Type of handler function, called like ioctl to do its entire job. */
|
||||||
@ -30,7 +31,8 @@ typedef int (*ioctl_handler_t) (int fd, int request, void *arg);
|
|||||||
/* Structure that records an ioctl handler. */
|
/* Structure that records an ioctl handler. */
|
||||||
struct ioctl_handler
|
struct ioctl_handler
|
||||||
{
|
{
|
||||||
int first_request, last_request; /* Range of handled request values. */
|
/* Range of handled _IOC_NOTYPE (REQUEST) values. */
|
||||||
|
int first_request, last_request;
|
||||||
|
|
||||||
/* Handler function, called like ioctl to do its entire job. */
|
/* Handler function, called like ioctl to do its entire job. */
|
||||||
ioctl_handler_t handler;
|
ioctl_handler_t handler;
|
||||||
@ -54,7 +56,8 @@ extern int hurd_register_ioctl_handler (int first_request, int last_request,
|
|||||||
#define _HURD_HANDLE_IOCTLS(handler, first, last) \
|
#define _HURD_HANDLE_IOCTLS(handler, first, last) \
|
||||||
static const struct ioctl_handler handler##_ioctl_handler \
|
static const struct ioctl_handler handler##_ioctl_handler \
|
||||||
__attribute__ ((__unused__)) = \
|
__attribute__ ((__unused__)) = \
|
||||||
{ (first), (last), (int (*) (int, int, void *)) (handler), NULL }; \
|
{ _IOC_NOTYPE (first), _IOC_NOTYPE (last), \
|
||||||
|
(int (*) (int, int, void *)) (handler), NULL }; \
|
||||||
text_set_element (_hurd_ioctl_handler_lists, ##handler##_ioctl_handler)
|
text_set_element (_hurd_ioctl_handler_lists, ##handler##_ioctl_handler)
|
||||||
|
|
||||||
/* Define a library-internal handler for a single ioctl command. */
|
/* Define a library-internal handler for a single ioctl command. */
|
||||||
|
@ -36,6 +36,10 @@ _hurd_lookup_ioctl_handler (int request)
|
|||||||
void *const *ptr;
|
void *const *ptr;
|
||||||
const struct ioctl_handler *h;
|
const struct ioctl_handler *h;
|
||||||
|
|
||||||
|
/* Mask off the type bits, so that we see requests in a single group as a
|
||||||
|
contiguous block of values. */
|
||||||
|
request = _IOC_NOTYPE (request);
|
||||||
|
|
||||||
for (ptr = symbol_set_first_element (_hurd_ioctl_handler_lists);
|
for (ptr = symbol_set_first_element (_hurd_ioctl_handler_lists);
|
||||||
!symbol_set_end_p (_hurd_ioctl_handler_lists, ptr);
|
!symbol_set_end_p (_hurd_ioctl_handler_lists, ptr);
|
||||||
++ptr)
|
++ptr)
|
||||||
@ -62,7 +66,7 @@ fioctl (int fd,
|
|||||||
switch (request)
|
switch (request)
|
||||||
{
|
{
|
||||||
default:
|
default:
|
||||||
err = EGRATUITOUS;
|
err = ENOTTY;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case FIONREAD:
|
case FIONREAD:
|
||||||
@ -97,7 +101,7 @@ fioctl (int fd,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return err ? __hurd_fail (err) : 0;
|
return err ? __hurd_dfail (fd, err) : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
_HURD_HANDLE_IOCTLS (fioctl, FIOGETOWN, FIONREAD);
|
_HURD_HANDLE_IOCTLS (fioctl, FIOGETOWN, FIONREAD);
|
||||||
@ -112,7 +116,7 @@ fioclex (int fd,
|
|||||||
switch (request)
|
switch (request)
|
||||||
{
|
{
|
||||||
default:
|
default:
|
||||||
return __hurd_fail (EGRATUITOUS);
|
return __hurd_fail (ENOTTY);
|
||||||
case FIOCLEX:
|
case FIOCLEX:
|
||||||
flag = FD_CLOEXEC;
|
flag = FD_CLOEXEC;
|
||||||
break;
|
break;
|
||||||
@ -123,7 +127,7 @@ fioclex (int fd,
|
|||||||
|
|
||||||
return __fcntl (fd, F_SETFD, flag);
|
return __fcntl (fd, F_SETFD, flag);
|
||||||
}
|
}
|
||||||
_HURD_HANDLE_IOCTLS (fioclex, FIOCLEX, FIONCLEX);
|
_HURD_HANDLE_IOCTL (fioclex, FIOCLEX, FIONCLEX);
|
||||||
|
|
||||||
#include <hurd/term.h>
|
#include <hurd/term.h>
|
||||||
#include <hurd/tioctl.h>
|
#include <hurd/tioctl.h>
|
||||||
|
@ -60,7 +60,7 @@ ifdef user-interfaces
|
|||||||
*.ir := $(addprefix $(objpfx),$(foreach if,$(user-interfaces),$(if).ir))
|
*.ir := $(addprefix $(objpfx),$(foreach if,$(user-interfaces),$(if).ir))
|
||||||
ifndef no_deps
|
ifndef no_deps
|
||||||
ifndef inhibit_interface_rules
|
ifndef inhibit_interface_rules
|
||||||
include $(*.ir)
|
-include $(*.ir)
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
ifneq "$(*.ir)" "$(wildcard $(*.ir))"
|
ifneq "$(*.ir)" "$(wildcard $(*.ir))"
|
||||||
|
@ -72,7 +72,7 @@ memchr (const void *s, int c, size_t n)
|
|||||||
unsigned char *cp = (unsigned char *) (longword_ptr - 1);
|
unsigned char *cp = (unsigned char *) (longword_ptr - 1);
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < 6; i++)
|
for (i = 0; i < 7; i++)
|
||||||
if (cp[i] == c)
|
if (cp[i] == c)
|
||||||
return &cp[i];
|
return &cp[i];
|
||||||
return &cp[7];
|
return &cp[7];
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* This file generated by gawk ../manual/errno.texi ../../mach/mach/message.h ../../mach/mach/kern_return.h ../../mach/mach/mig_errors.h ../../mach/device/device_types.h. */
|
/* This file generated by gawk ../manual/errno.texi /gd4/gnu/mach/mach/message.h /gd4/gnu/mach/mach/kern_return.h /gd4/gnu/mach/mach/mig_errors.h /gd4/gnu/mach/device/device_types.h. */
|
||||||
|
|
||||||
/* The Hurd uses Mach error system 0x10, currently only subsystem 0. */
|
/* The Hurd uses Mach error system 0x10, currently only subsystem 0. */
|
||||||
#ifndef _HURD_ERRNO
|
#ifndef _HURD_ERRNO
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* Copyright (C) 1992, 1993, 1994, 1995 Free Software Foundation, Inc.
|
/* Copyright (C) 1992, 1993, 1994, 1995, 1996 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
|
||||||
@ -129,8 +129,17 @@ DEFUN(__ioctl, (fd, request),
|
|||||||
/* Check for a registered handler for REQUEST. */
|
/* Check for a registered handler for REQUEST. */
|
||||||
ioctl_handler_t handler = _hurd_lookup_ioctl_handler (request);
|
ioctl_handler_t handler = _hurd_lookup_ioctl_handler (request);
|
||||||
if (handler)
|
if (handler)
|
||||||
/* This handler groks REQUEST. Se lo puntamonos. */
|
{
|
||||||
return (*handler) (fd, request, arg);
|
/* This handler groks REQUEST. Se lo puntamonos. */
|
||||||
|
int save = errno;
|
||||||
|
int result = (*handler) (fd, request, arg);
|
||||||
|
if (result != -1 || errno != ENOTTY)
|
||||||
|
return result;
|
||||||
|
|
||||||
|
/* The handler doesn't really grok this one.
|
||||||
|
Try the normal RPC translation. */
|
||||||
|
errno = save;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Compute the Mach message ID for the RPC from the group and command
|
/* Compute the Mach message ID for the RPC from the group and command
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* Copyright (C) 1992, 1993 Free Software Foundation, Inc.
|
/* Copyright (C) 1992, 1993, 1996 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
|
||||||
@ -21,16 +21,20 @@ Cambridge, MA 02139, USA. */
|
|||||||
#define _IOCTLS_H 1
|
#define _IOCTLS_H 1
|
||||||
|
|
||||||
/* Hurd ioctl request are made up of several fields:
|
/* Hurd ioctl request are made up of several fields:
|
||||||
bits 31-30: inout direction (enum __ioctl_dir)
|
|
||||||
bits 29-12: type encoding as follows; zero count indicates omitted datum
|
10987654321098765432109876543210
|
||||||
29-28: datum #0 type (enum __ioctl_datum)
|
IOt0t1t2cc0c0cc1c1cc2ggggccccccc
|
||||||
27-26: datum #1 type (enum __ioctl_datum)
|
|
||||||
25-24: datum #2 type (enum __ioctl_datum)
|
bits [31,30]: inout direction (enum __ioctl_dir)
|
||||||
23-19: datum #0 count [0..31]
|
bits [29,11]: type encoding as follows; zero count indicates omitted datum
|
||||||
18-14: datum #1 count [0..31]
|
[29,28]: datum #0 type (enum __ioctl_datum)
|
||||||
13-12: datum #2 count [0..3]
|
[27,26]: datum #1 type (enum __ioctl_datum)
|
||||||
bits 11- 8: group (letter - 'f': ['f'..'v'])
|
[24,25]: datum #2 type (enum __ioctl_datum)
|
||||||
bits 7- 0: command [0..127]
|
[23,19]: datum #0 count [0,31]
|
||||||
|
[18,14]: datum #1 count [0,31]
|
||||||
|
[13,11]: datum #2 count [0,3]
|
||||||
|
bits [07,10]: group (letter - 'f': ['f','v'])
|
||||||
|
bits [00,06]: command [0,127]
|
||||||
|
|
||||||
The following macros construct and dissect these fields. */
|
The following macros construct and dissect these fields. */
|
||||||
|
|
||||||
@ -50,9 +54,10 @@ enum __ioctl_datum { IOC_8, IOC_16, IOC_32 };
|
|||||||
|
|
||||||
/* Dissect an ioctl into its component fields. */
|
/* Dissect an ioctl into its component fields. */
|
||||||
#define _IOC_INOUT(request) (((unsigned int) (request) >> 30) & IOC_INOUT)
|
#define _IOC_INOUT(request) (((unsigned int) (request) >> 30) & IOC_INOUT)
|
||||||
#define _IOC_GROUP(request) ('f' + (((unsigned int) (request) >> 7) & 15))
|
#define _IOC_GROUP(request) ('f' + (((unsigned int) (request) >> 7) & 0xf))
|
||||||
#define _IOC_COMMAND(request) ((unsigned int) (request) & 0x7f)
|
#define _IOC_COMMAND(request) ((unsigned int) (request) & 0x7f)
|
||||||
#define _IOC_TYPE(request) (((unsigned int) (request) >> 11) & 0x7ffff)
|
#define _IOC_TYPE(request) (((unsigned int) (request) >> 11) & 0x7ffff)
|
||||||
|
#define _IOC_NOTYPE(request) ((unsigned int) (request) & 0x3ff)
|
||||||
|
|
||||||
/* Construct a type information field from
|
/* Construct a type information field from
|
||||||
the broken-out type and count fields. */
|
the broken-out type and count fields. */
|
||||||
@ -65,7 +70,7 @@ enum __ioctl_datum { IOC_8, IOC_16, IOC_32 };
|
|||||||
#define _IOT_TYPE2(type) (((unsigned int) (type) >> 13) & 3)
|
#define _IOT_TYPE2(type) (((unsigned int) (type) >> 13) & 3)
|
||||||
#define _IOT_COUNT0(type) (((unsigned int) (type) >> 8) & 0x1f)
|
#define _IOT_COUNT0(type) (((unsigned int) (type) >> 8) & 0x1f)
|
||||||
#define _IOT_COUNT1(type) (((unsigned int) (type) >> 3) & 0x1f)
|
#define _IOT_COUNT1(type) (((unsigned int) (type) >> 3) & 0x1f)
|
||||||
#define _IOT_COUNT2(type) (((unsigned int) (type) >> 0) & 3)
|
#define _IOT_COUNT2(type) (((unsigned int) (type) >> 0) & 7)
|
||||||
|
|
||||||
/* Construct an ioctl from all the broken-out fields. */
|
/* Construct an ioctl from all the broken-out fields. */
|
||||||
#define _IOCT(inout, group, num, t0, c0, t1, c1, t2, c2) \
|
#define _IOCT(inout, group, num, t0, c0, t1, c1, t2, c2) \
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# Copyright (C) 1992, 1993, 1995 Free Software Foundation, Inc.
|
# Copyright (C) 1992, 1993, 1995, 1996 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
|
||||||
@ -22,13 +22,6 @@ sysdep_routines := $(sysdep_routines) sysconfig pgrpsys __waitid
|
|||||||
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
|
||||||
ifeq ($(subdir),signal)
|
|
||||||
|
|
||||||
sysdep_routines := $(sysdep_routines) sys-sig
|
|
||||||
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifeq ($(subdir),misc)
|
ifeq ($(subdir),misc)
|
||||||
|
|
||||||
sysdep_routines := $(sysdep_routines) sysinfo
|
sysdep_routines := $(sysdep_routines) sysinfo
|
||||||
|
Loading…
Reference in New Issue
Block a user