2005-03-06 08:16:52 +03:00
/*
* udev_libc_wrapper - wrapping of functions missing in a specific libc
* or not working in a statically compiled binary
*
* Copyright ( C ) 2005 Kay Sievers < kay . sievers @ vrfy . org >
*
* This program is free software ; you can redistribute it and / or modify it
* under the terms of the GNU General Public License as published by the
* Free Software Foundation version 2 of the License .
*
* This program is distributed in the hope that it will be useful , but
* WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the GNU
* General Public License for more details .
*
* You should have received a copy of the GNU General Public License along
* with this program ; if not , write to the Free Software Foundation , Inc . ,
* 675 Mass Ave , Cambridge , MA 0213 9 , USA .
*
*/
# ifndef _UDEV_LIBC_WRAPPER_H_
# define _UDEV_LIBC_WRAPPER_H_
2005-08-15 13:57:04 +04:00
# include <string.h>
# include <unistd.h>
2005-10-27 23:04:38 +04:00
# include <stdint.h>
/* needed until Inotify! syscalls reach glibc */
# include <sys/syscall.h>
# ifndef __NR_inotify_init
# if defined(__i386__)
# define __NR_inotify_init 291
# define __NR_inotify_add_watch 292
# define __NR_inotify_rm_watch 293
# elif defined(__x86_64__)
# define __NR_inotify_init 253
# define __NR_inotify_add_watch 254
# define __NR_inotify_rm_watch 255
# elif defined(__powerpc__) || defined(__powerpc64__)
# define __NR_inotify_init 275
# define __NR_inotify_add_watch 276
# define __NR_inotify_rm_watch 277
# elif defined (__ia64__)
# define __NR_inotify_init 1277
# define __NR_inotify_add_watch 1278
# define __NR_inotify_rm_watch 1279
# elif defined (__s390__)
# define __NR_inotify_init 284
# define __NR_inotify_add_watch 285
# define __NR_inotify_rm_watch 286
# elif defined (__alpha__)
# define __NR_inotify_init 444
# define __NR_inotify_add_watch 445
# define __NR_inotify_rm_watch 446
# elif defined (__sparc__) || defined (__sparc64__)
# define __NR_inotify_init 151
# define __NR_inotify_add_watch 152
# define __NR_inotify_rm_watch 156
# elif defined (__arm__)
2006-07-27 12:53:11 +04:00
# define __NR_inotify_init __NR_SYSCALL_BASE+316
# define __NR_inotify_add_watch __NR_SYSCALL_BASE+317
# define __NR_inotify_rm_watch __NR_SYSCALL_BASE+318
2005-10-27 23:04:38 +04:00
# elif defined (__sh__)
# define __NR_inotify_init 290
# define __NR_inotify_add_watch 291
# define __NR_inotify_rm_watch 292
2006-04-06 21:52:41 +04:00
# elif defined (__hppa__)
# define __NR_inotify_init 269
# define __NR_inotify_add_watch 270
# define __NR_inotify_rm_watch 271
# elif defined (__mips__)
# include <sgidefs.h>
# if _MIPS_SIM == _MIPS_SIM_ABI32
# define __NR_Linux 4000
# define __NR_inotify_init (__NR_Linux + 284)
# define __NR_inotify_add_watch (__NR_Linux + 285)
# define __NR_inotify_rm_watch (__NR_Linux + 286)
# elif _MIPS_SIM == _MIPS_SIM_ABI64
# define __NR_Linux 5000
# define __NR_inotify_init (__NR_Linux + 243)
# define __NR_inotify_add_watch (__NR_Linux + 244)
# define __NR_inotify_rm_watch (__NR_Linux + 245)
# elif _MIPS_SIM == _MIPS_SIM_NABI32
# define __NR_Linux 6000
# define __NR_inotify_init (__NR_Linux + 247)
# define __NR_inotify_add_watch (__NR_Linux + 248)
# define __NR_inotify_rm_watch (__NR_Linux + 249)
# endif
2005-10-27 23:04:38 +04:00
# else
2005-10-28 04:29:38 +04:00
# warning "inotify unsupported on this architecture!"
2005-10-27 23:04:38 +04:00
# endif
# endif /* __NR_inotify_init */
2005-10-28 04:29:38 +04:00
/* dummy if we don't have the syscalls defined */
# ifndef __NR_inotify_init
static inline int inotify_init ( void )
{
return - 1 ;
}
static inline int inotify_add_watch ( int fd , const char * name , uint32_t mask )
{
return - 1 ;
}
# else
2005-10-27 23:04:38 +04:00
/* needed until /usr/include/sys/inotify.h is working */
2006-08-05 02:35:05 +04:00
# ifndef __GLIBC__
2005-10-27 23:04:38 +04:00
# include <sys/inotify.h>
# else
static inline int inotify_init ( void )
{
return syscall ( __NR_inotify_init ) ;
}
static inline int inotify_add_watch ( int fd , const char * name , uint32_t mask )
{
return syscall ( __NR_inotify_add_watch , fd , name , mask ) ;
}
2006-08-05 02:35:05 +04:00
# endif /* __GLIBC__ */
2005-10-28 04:29:38 +04:00
# endif /* __NR_inotify_init */
# ifndef IN_CREATE
2005-10-27 23:04:38 +04:00
# define IN_CREATE 0x00000100 /* Subfile was created */
# define IN_MOVED_FROM 0x00000040 /* File was moved from X */
# define IN_MOVED_TO 0x00000080 /* File was moved to Y */
# define IN_DELETE 0x00000200 /* Subfile was deleted */
# define IN_CLOSE_WRITE 0x00000008 /* Writtable file was closed */
# define IN_MOVE (IN_MOVED_FROM | IN_MOVED_TO) /* moves */
2005-10-28 04:29:38 +04:00
# endif /* IN_CREATE */
2005-08-15 13:57:04 +04:00
/* needed for our signal handlers to work */
2005-03-10 02:58:01 +03:00
# undef asmlinkage
2005-03-07 06:29:43 +03:00
# ifdef __i386__
2005-03-10 02:58:01 +03:00
# define asmlinkage __attribute__((regparm(0)))
# else
# define asmlinkage
2005-10-27 23:04:38 +04:00
# endif /* __i386__ */
2005-03-10 02:58:01 +03:00
2006-08-05 02:00:15 +04:00
/* headers are broken on some architectures */
2005-03-10 02:58:01 +03:00
# ifndef __FD_SET
# define __FD_SET(d, set) ((set)->fds_bits[__FDELT(d)] |= __FDMASK(d))
# endif
# ifndef __FD_CLR
# define __FD_CLR(d, set) ((set)->fds_bits[__FDELT(d)] &= ~__FDMASK(d))
# endif
# ifndef __FD_ISSET
# define __FD_ISSET(d, set) (((set)->fds_bits[__FDELT(d)] & __FDMASK(d)) != 0)
2005-03-07 06:29:43 +03:00
# endif
2005-03-10 02:58:01 +03:00
# ifndef __FD_ZERO
# define __FD_ZERO(set) ((void) memset ((void*) (set), 0, sizeof (fd_set)))
2005-03-07 06:29:43 +03:00
# endif
2005-08-04 14:24:41 +04:00
# ifndef NETLINK_KOBJECT_UEVENT
2006-08-05 02:00:15 +04:00
# define NETLINK_KOBJECT_UEVENT 15
2005-08-04 14:24:41 +04:00
# endif
2005-10-11 23:06:50 +04:00
# ifndef SO_RCVBUFFORCE
2006-02-21 19:01:54 +03:00
# if defined(__alpha__) || defined(__hppa__) || defined(__sparc__) || defined(__sparc_v9__)
# define SO_RCVBUFFORCE 0x100b
# else
2005-10-11 23:06:50 +04:00
# define SO_RCVBUFFORCE 33
# endif
2006-02-21 19:01:54 +03:00
# endif
2005-10-11 23:06:50 +04:00
2005-03-06 08:16:52 +03:00
extern uid_t lookup_user ( const char * user ) ;
extern gid_t lookup_group ( const char * group ) ;
2005-03-07 06:29:43 +03:00
extern size_t strlcpy ( char * dst , const char * src , size_t size ) ;
extern size_t strlcat ( char * dst , const char * src , size_t size ) ;
2005-03-06 08:16:52 +03:00
# endif /* _UDEV_LIBC_WRAPPER_H_ */