From d4f0dc43fc175738c41771c451d5bf7cdae37ad1105876e856935c51af676775 Mon Sep 17 00:00:00 2001 From: Larry Finger Date: Mon, 26 Dec 2022 17:18:51 +0000 Subject: [PATCH] Accepting request 1045400 from home:lwfinger:branches:Virtualization To eliminate some VM failures while using the kernel version of vboxvideo.ko for Leap 15.4, the build of this module is turned on again. Fixes boo#1206651 - Leap 15.4 guests running VirtualBox 7.0.4 crash when run on hosts with certain Intel graphics cards File "fixes_for_leap15.5.patch" added to fix chanes needed for backports to the Leap 15.5 kernel OBS-URL: https://build.opensuse.org/request/show/1045400 OBS-URL: https://build.opensuse.org/package/show/Virtualization/virtualbox?expand=0&rev=670 --- fix_kmp_build.patch | 2390 +++++++++++++++++++++ fixes_for_leap15.5.patch | 83 + vbox-disable-updates.diff | 4 +- vbox-fpie.diff | 4 +- vbox_remove_smp_mflags.patch | 13 - virtualbox-kmp-files | 2 +- virtualbox-snpritnf-buffer-overflow.patch | 12 - virtualbox.changes | 10 + virtualbox.spec | 174 +- 9 files changed, 2650 insertions(+), 42 deletions(-) create mode 100644 fixes_for_leap15.5.patch delete mode 100644 vbox_remove_smp_mflags.patch delete mode 100644 virtualbox-snpritnf-buffer-overflow.patch diff --git a/fix_kmp_build.patch b/fix_kmp_build.patch index 730a58b..cb18eba 100644 --- a/fix_kmp_build.patch +++ b/fix_kmp_build.patch @@ -90,3 +90,2393 @@ Index: VirtualBox-7.0.4/src/libs/Makefile.kmk # zlib is used by the IPRT compression code, libpng and others. +Index: VirtualBox-7.0.4/src/VBox/Additions/x11/vboxvideo/VBoxVideoIPRT.h +=================================================================== +--- VirtualBox-7.0.4.orig/src/VBox/Additions/x11/vboxvideo/VBoxVideoIPRT.h ++++ VirtualBox-7.0.4/src/VBox/Additions/x11/vboxvideo/VBoxVideoIPRT.h +@@ -49,7 +49,6 @@ typedef enum + # define RT_C_DECLS_END } + #endif + +-#if defined(IN_XF86_MODULE) && !defined(NO_ANSIC) + # ifdef __cplusplus + /* xf86Module.h redefines this. */ + # define NULL 0 +@@ -57,7 +56,6 @@ typedef enum + RT_C_DECLS_BEGIN + # include "xf86_ansic.h" + RT_C_DECLS_END +-#endif /* defined(IN_XF86_MODULE) && !defined(NO_ANSIC) */ + #define __STDC_LIMIT_MACROS /* define *INT*_MAX on C++ too. */ + #include "compiler.h" /* Can pull in . Must come after xf86_ansic.h on XFree86. */ + #include +Index: VirtualBox-7.0.4/src/VBox/Additions/x11/vboxvideo/xf86_ansic.h +=================================================================== +--- /dev/null ++++ VirtualBox-7.0.4/src/VBox/Additions/x11/vboxvideo/xf86_ansic.h +@@ -0,0 +1,351 @@ ++/* ++ * Copyright 1997-2000 by The XFree86 Project, Inc ++ * ++ * Permission to use, copy, modify, distribute, and sell this software and its ++ * documentation for any purpose is hereby granted without fee, provided that ++ * the above copyright notice appear in all copies and that both that ++ * copyright notice and this permission notice appear in supporting ++ * documentation, and that the names of the above listed copyright holders ++ * not be used in advertising or publicity pertaining to distribution of ++ * the software without specific, written prior permission. The above listed ++ * copyright holders make no representations about the suitability of this ++ * software for any purpose. It is provided "as is" without express or ++ * implied warranty. ++ * ++ * THE ABOVE LISTED COPYRIGHT HOLDERS DISCLAIM ALL WARRANTIES WITH REGARD ++ * TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY ++ * AND FITNESS, IN NO EVENT SHALL THE ABOVE LISTED COPYRIGHT HOLDERS BE ++ * LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY ++ * DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER ++ * IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING ++ * OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. ++ * ++ */ ++ ++/* $XFree86: xc/programs/Xserver/hw/xfree86/os-support/xf86_ansic.h,v 3.49 2003/02/22 06:00:39 dawes Exp $ */ ++ ++#ifndef _XF86_ANSIC_H ++#define _XF86_ANSIC_H ++ ++/* Handle */ ++ ++#ifndef IN_MODULE ++# include ++#else /* !IN_MODULE */ ++# ifndef __OS2ELF__ ++# include ++# else /* __OS2ELF__ */ ++ /* EMX/gcc_elf under OS/2 does not have native header files */ ++# if !defined (_VA_LIST) ++# define _VA_LIST ++ typedef char *va_list; ++# endif ++# define _VA_ROUND(t) ((sizeof (t) + 3) & -4) ++# if !defined (va_start) ++# define va_start(ap,v) ap = (va_list)&v + ((sizeof (v) + 3) & -4) ++# define va_end(ap) (ap = 0, (void)0) ++# define va_arg(ap,t) (ap += _VA_ROUND (t), *(t *)(ap - _VA_ROUND (t))) ++# endif ++# endif /* __OS2ELF__ */ ++#endif /* IN_MODULE */ ++ ++/* ++ * The first set of definitions are required both for modules and ++ * libc_wrapper.c. ++ */ ++ ++#if defined(XFree86LOADER) || defined(NEED_XF86_TYPES) ++ ++#if !defined(SYSV) && !defined(SVR4) && !defined(Lynx) || defined(SCO) ++#define HAVE_VSSCANF ++#define HAVE_VFSCANF ++#endif ++ ++#ifndef NULL ++#if (defined(SVR4) || defined(SYSV)) && !defined(__GNUC__) ++#define NULL 0 ++#else ++#define NULL ((void *)0) ++#endif ++#endif ++#ifndef EOF ++#define EOF (-1) ++#endif ++ ++#ifndef PATH_MAX ++#define PATH_MAX 1024 ++#endif ++ ++/* stuff */ ++#define x_BITSPERBYTE 8 ++#define x_BITS(type) (x_BITSPERBYTE * (int)sizeof(type)) ++#define x_SHORTBITS x_BITS(short) ++#define x_INTBITS x_BITS(int) ++#define x_LONGBITS x_BITS(long) ++#ifndef SHRT_MIN ++#define SHRT_MIN ((short)(1 << (x_SHORTBITS - 1))) ++#endif ++ ++#ifndef FONTMODULE ++#include "misc.h" ++#endif ++#include "xf86_libc.h" ++#ifndef SHRT_MAX ++#define SHRT_MAX ((short)~SHRT_MIN) ++#endif ++#ifndef USHRT_MAX ++#define USHRT_MAX ((unsigned short)~0) ++#endif ++#ifndef MINSHORT ++#define MINSHORT SHRT_MIN ++#endif ++#ifndef MAXSHORT ++#define MAXSHORT SHRT_MAX ++#endif ++#ifndef INT_MIN ++#define INT_MIN (1 << (x_INTBITS - 1)) ++#endif ++#ifndef INT_MAX ++#define INT_MAX (~INT_MIN) ++#endif ++#ifndef UINT_MAX ++#define UINT_MAX (~0) ++#endif ++#ifndef MININT ++#define MININT INT_MIN ++#endif ++#ifndef MAXINT ++#define MAXINT INT_MAX ++#endif ++#ifndef LONG_MIN ++#define LONG_MIN ((long)(1 << (x_LONGBITS - 1))) ++#endif ++#ifndef LONG_MAX ++#define LONG_MAX ((long)~LONG_MIN) ++#endif ++#ifndef ULONG_MAX ++#define ULONG_MAX ((unsigned long)~0UL) ++#endif ++#ifndef MINLONG ++#define MINLONG LONG_MIN ++#endif ++#ifndef MAXLONG ++#define MAXLONG LONG_MAX ++#endif ++ ++#endif /* XFree86LOADER || NEED_XF86_TYPES */ ++ ++#if defined(XFree86LOADER) || defined(NEED_XF86_PROTOTYPES) ++/* ++ * ANSI C compilers only. ++ */ ++ ++/* ANSI C emulation library */ ++ ++extern void xf86abort(void); ++extern int xf86abs(int); ++extern double xf86acos(double); ++extern double xf86asin(double); ++extern double xf86atan(double); ++extern double xf86atan2(double,double); ++extern double xf86atof(const char*); ++extern int xf86atoi(const char*); ++extern long xf86atol(const char*); ++extern void *xf86bsearch(const void *, const void *, xf86size_t, xf86size_t, ++ int (*)(const void *, const void *)); ++extern double xf86ceil(double); ++extern void* xf86calloc(xf86size_t,xf86size_t); ++extern void xf86clearerr(XF86FILE*); ++extern double xf86cos(double); ++extern void xf86exit(int); ++extern double xf86exp(double); ++extern double xf86fabs(double); ++extern int xf86fclose(XF86FILE*); ++extern int xf86feof(XF86FILE*); ++extern int xf86ferror(XF86FILE*); ++extern int xf86fflush(XF86FILE*); ++extern int xf86fgetc(XF86FILE*); ++extern int xf86getc(XF86FILE*); ++extern int xf86fgetpos(XF86FILE*,XF86fpos_t*); ++extern char* xf86fgets(char*,INT32,XF86FILE*); ++extern int xf86finite(double); ++extern double xf86floor(double); ++extern double xf86fmod(double,double); ++extern XF86FILE* xf86fopen(const char*,const char*); ++extern double xf86frexp(double, int*); ++extern int xf86printf(const char*,...); ++extern int xf86fprintf(XF86FILE*,const char*,...); ++extern int xf86fputc(int,XF86FILE*); ++extern int xf86fputs(const char*,XF86FILE*); ++extern xf86size_t xf86fread(void*,xf86size_t,xf86size_t,XF86FILE*); ++extern void xf86free(void*); ++extern XF86FILE* xf86freopen(const char*,const char*,XF86FILE*); ++#if defined(HAVE_VFSCANF) || !defined(NEED_XF86_PROTOTYPES) ++extern int xf86fscanf(XF86FILE*,const char*,...); ++#else ++extern int xf86fscanf(/*XF86FILE*,const char*,char *,char *,char *,char *, ++ char *,char *,char *,char *,char *,char * */); ++#endif ++extern int xf86fseek(XF86FILE*,long,int); ++extern int xf86fsetpos(XF86FILE*,const XF86fpos_t*); ++extern long xf86ftell(XF86FILE*); ++extern xf86size_t xf86fwrite(const void*,xf86size_t,xf86size_t,XF86FILE*); ++extern char* xf86getenv(const char*); ++extern int xf86isalnum(int); ++extern int xf86isalpha(int); ++extern int xf86iscntrl(int); ++extern int xf86isdigit(int); ++extern int xf86isgraph(int); ++extern int xf86islower(int); ++extern int xf86isprint(int); ++extern int xf86ispunct(int); ++extern int xf86isspace(int); ++extern int xf86isupper(int); ++extern int xf86isxdigit(int); ++extern long xf86labs(long); ++extern double xf86ldexp(double,int); ++extern double xf86log(double); ++extern double xf86log10(double); ++extern void* xf86malloc(xf86size_t); ++extern void* xf86memchr(const void*,int,xf86size_t); ++extern int xf86memcmp(const void*,const void*,xf86size_t); ++extern void* xf86memcpy(void*,const void*,xf86size_t); ++extern void* xf86memmove(void*,const void*,xf86size_t); ++extern void* xf86memset(void*,int,xf86size_t); ++extern double xf86modf(double,double*); ++extern void xf86perror(const char*); ++extern double xf86pow(double,double); ++extern void xf86qsort(void*, xf86size_t, xf86size_t, ++ int(*)(const void*, const void*)); ++extern void* xf86realloc(void*,xf86size_t); ++extern int xf86remove(const char*); ++extern int xf86rename(const char*,const char*); ++extern void xf86rewind(XF86FILE*); ++extern int xf86setbuf(XF86FILE*,char*); ++extern int xf86setvbuf(XF86FILE*,char*,int,xf86size_t); ++extern double xf86sin(double); ++extern int xf86sprintf(char*,const char*,...); ++extern int xf86snprintf(char*,xf86size_t,const char*,...); ++extern double xf86sqrt(double); ++#if defined(HAVE_VSSCANF) || !defined(NEED_XF86_PROTOTYPES) ++extern int xf86sscanf(char*,const char*,...); ++#else ++extern int xf86sscanf(/*char*,const char*,char *,char *,char *,char *, ++ char *,char *,char *,char *,char *,char * */); ++#endif ++extern char* xf86strcat(char*,const char*); ++extern char* xf86strchr(const char*, int c); ++extern int xf86strcmp(const char*,const char*); ++extern int xf86strcasecmp(const char*,const char*); ++extern char* xf86strcpy(char*,const char*); ++extern xf86size_t xf86strcspn(const char*,const char*); ++extern char* xf86strerror(int); ++extern xf86size_t xf86strlen(const char*); ++extern char* xf86strncat(char *, const char *, xf86size_t); ++extern int xf86strncmp(const char*,const char*,xf86size_t); ++extern int xf86strncasecmp(const char*,const char*,xf86size_t); ++extern char* xf86strncpy(char*,const char*,xf86size_t); ++extern char* xf86strpbrk(const char*,const char*); ++extern char* xf86strrchr(const char*,int); ++extern xf86size_t xf86strspn(const char*,const char*); ++extern char* xf86strstr(const char*,const char*); ++extern double xf86strtod(const char*,char**); ++extern char* xf86strtok(char*,const char*); ++extern long xf86strtol(const char*,char**,int); ++extern unsigned long xf86strtoul(const char*,char**,int); ++extern double xf86tan(double); ++extern XF86FILE* xf86tmpfile(void); ++extern char* xf86tmpnam(char*); ++extern int xf86tolower(int); ++extern int xf86toupper(int); ++extern int xf86ungetc(int,XF86FILE*); ++extern int xf86vfprintf(XF86FILE*,const char*,va_list); ++extern int xf86vsprintf(char*,const char*,va_list); ++extern int xf86vsnprintf(char*,xf86size_t,const char*,va_list); ++ ++extern int xf86open(const char*, int,...); ++extern int xf86close(int); ++extern long xf86lseek(int, long, int); ++extern int xf86ioctl(int, unsigned long, pointer); ++extern xf86ssize_t xf86read(int, void *, xf86size_t); ++extern xf86ssize_t xf86write(int, const void *, xf86size_t); ++extern void* xf86mmap(void*, xf86size_t, int, int, int, xf86size_t /* off_t */); ++extern int xf86munmap(void*, xf86size_t); ++extern int xf86stat(const char *, struct xf86stat_s *); ++extern int xf86fstat(int, struct xf86stat_s *); ++extern int xf86access(const char *, int); ++extern int xf86errno; ++extern int xf86GetErrno(void); ++ ++extern double xf86HUGE_VAL; ++ ++extern double xf86hypot(double,double); ++ ++/* non-ANSI C functions */ ++extern XF86DIR* xf86opendir(const char*); ++extern int xf86closedir(XF86DIR*); ++extern XF86DIRENT* xf86readdir(XF86DIR*); ++extern void xf86rewinddir(XF86DIR*); ++extern void xf86bcopy(const void*,void*,xf86size_t); ++extern int xf86ffs(int); ++extern char* xf86strdup(const char*); ++extern void xf86bzero(void*,unsigned int); ++extern int xf86execl(const char *, const char *, ...); ++extern long xf86fpossize(void); ++extern int xf86chmod(const char *, xf86mode_t); ++extern int xf86chown(const char *, xf86uid_t, xf86gid_t); ++extern xf86uid_t xf86geteuid(void); ++extern xf86gid_t xf86getegid(void); ++extern int xf86getpid(void); ++extern int xf86mknod(const char *, xf86mode_t, xf86dev_t); ++extern int xf86mkdir(const char *, xf86mode_t); ++unsigned int xf86sleep(unsigned int seconds); ++/* sysv IPC */ ++extern int xf86shmget(xf86key_t key, int size, int xf86shmflg); ++extern char * xf86shmat(int id, char *addr, int xf86shmflg); ++extern int xf86shmdt(char *addr); ++extern int xf86shmctl(int id, int xf86cmd, pointer buf); ++ ++extern int xf86setjmp(xf86jmp_buf env); ++extern int xf86setjmp1(xf86jmp_buf env, int); ++extern int xf86setjmp1_arg2(void); ++extern int xf86setjmperror(xf86jmp_buf env); ++extern int xf86getjmptype(void); ++extern void xf86longjmp(xf86jmp_buf env, int val); ++#define xf86setjmp_macro(env) \ ++ (xf86getjmptype() == 0 ? xf86setjmp((env)) : \ ++ (xf86getjmptype() == 1 ? xf86setjmp1((env), xf86setjmp1_arg2()) : \ ++ xf86setjmperror((env)))) ++ ++#else /* XFree86LOADER || NEED_XF86_PROTOTYPES */ ++#include ++#include ++#include ++#include ++#include ++#include ++#ifdef HAVE_SYSV_IPC ++#include ++#include ++#endif ++#include ++#define stat_t struct stat ++#endif /* XFree86LOADER || NEED_XF86_PROTOTYPES */ ++ ++/* ++ * These things are always required by drivers (but not by libc_wrapper.c), ++ * even for a static server because some OSs don't provide them. ++ */ ++ ++extern int xf86getpagesize(void); ++extern void xf86usleep(unsigned long); ++extern void xf86getsecs(long *, long *); ++#ifndef DONT_DEFINE_WRAPPERS ++#undef getpagesize ++#define getpagesize() xf86getpagesize() ++#undef usleep ++#define usleep(ul) xf86usleep(ul) ++#undef getsecs ++#define getsecs(a, b) xf86getsecs(a, b) ++#endif ++#endif /* _XF86_ANSIC_H */ +Index: VirtualBox-7.0.4/src/VBox/Additions/x11/vboxvideo/compiler.h +=================================================================== +--- /dev/null ++++ VirtualBox-7.0.4/src/VBox/Additions/x11/vboxvideo/compiler.h +@@ -0,0 +1,1743 @@ ++/* $XFree86: xc/programs/Xserver/hw/xfree86/common/compiler.h,v 3.99 2003/01/29 15:23:20 tsi Exp $ */ ++/* ++ * Copyright 1990,91 by Thomas Roell, Dinkelscherben, Germany. ++ * ++ * Permission to use, copy, modify, distribute, and sell this software and its ++ * documentation for any purpose is hereby granted without fee, provided that ++ * the above copyright notice appear in all copies and that both that ++ * copyright notice and this permission notice appear in supporting ++ * documentation, and that the name of Thomas Roell not be used in ++ * advertising or publicity pertaining to distribution of the software without ++ * specific, written prior permission. Thomas Roell makes no representations ++ * about the suitability of this software for any purpose. It is provided ++ * "as is" without express or implied warranty. ++ * ++ * THOMAS ROELL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, ++ * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO ++ * EVENT SHALL THOMAS ROELL BE LIABLE FOR ANY SPECIAL, INDIRECT OR ++ * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, ++ * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER ++ * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR ++ * PERFORMANCE OF THIS SOFTWARE. ++ * ++ */ ++/* $XConsortium: compiler.h /main/16 1996/10/25 15:38:34 kaleb $ */ ++ ++#ifndef _COMPILER_H ++ ++# if !defined(_XF86_ANSIC_H) && defined(XFree86Module) ++# error missing #include "xf86_ansic.h" before #include "compiler.h" ++# endif ++ ++# define _COMPILER_H ++ ++/* Allow drivers to use the GCC-supported __inline__ and/or __inline. */ ++# ifndef __inline__ ++# if defined(__GNUC__) ++ /* gcc has __inline__ */ ++# elif defined(__HIGHC__) ++# define __inline__ _Inline ++# else ++# define __inline__ /**/ ++# endif ++# endif /* __inline__ */ ++# ifndef __inline ++# if defined(__GNUC__) ++ /* gcc has __inline */ ++# elif defined(__HIGHC__) ++# define __inline _Inline ++# else ++# define __inline /**/ ++# endif ++# endif /* __inline */ ++ ++# if defined(IODEBUG) && defined(__GNUC__) ++# define outb RealOutb ++# define outw RealOutw ++# define outl RealOutl ++# define inb RealInb ++# define inw RealInw ++# define inl RealInl ++# endif ++ ++# if defined(QNX4) /* Do this for now to keep Watcom happy */ ++# define outb outp ++# define outw outpw ++# define outl outpd ++# define inb inp ++# define inw inpw ++# define inl inpd ++ ++/* Define the ffs function for inlining */ ++extern int ffs(unsigned long); ++# pragma aux ffs_ = \ ++ "bsf edx, eax" \ ++ "jnz bits_set" \ ++ "xor eax, eax" \ ++ "jmp exit1" \ ++ "bits_set:" \ ++ "mov eax, edx" \ ++ "inc eax" \ ++ "exit1:" \ ++ __parm [eax] \ ++ __modify [eax edx] \ ++ __value [eax] \ ++ ; ++# endif ++ ++# if defined(NO_INLINE) || defined(DO_PROTOTYPES) ++ ++# if !defined(__sparc__) && !defined(__arm32__) \ ++ && !(defined(__alpha__) && defined(linux)) ++ ++extern void outb(unsigned short, unsigned char); ++extern void outw(unsigned short, unsigned short); ++extern void outl(unsigned short, unsigned int); ++extern unsigned int inb(unsigned short); ++extern unsigned int inw(unsigned short); ++extern unsigned int inl(unsigned short); ++ ++# else /* __sparc__, __arm32__, __alpha__*/ ++ ++extern void outb(unsigned long, unsigned char); ++extern void outw(unsigned long, unsigned short); ++extern void outl(unsigned long, unsigned int); ++extern unsigned int inb(unsigned long); ++extern unsigned int inw(unsigned long); ++extern unsigned int inl(unsigned long); ++ ++# endif /* __sparc__, __arm32__, __alpha__ */ ++ ++extern unsigned long ldq_u(unsigned long *); ++extern unsigned long ldl_u(unsigned int *); ++extern unsigned long ldw_u(unsigned short *); ++extern void stq_u(unsigned long, unsigned long *); ++extern void stl_u(unsigned long, unsigned int *); ++extern void stw_u(unsigned long, unsigned short *); ++extern void mem_barrier(void); ++extern void write_mem_barrier(void); ++extern void stl_brx(unsigned long, volatile unsigned char *, int); ++extern void stw_brx(unsigned short, volatile unsigned char *, int); ++extern unsigned long ldl_brx(volatile unsigned char *, int); ++extern unsigned short ldw_brx(volatile unsigned char *, int); ++ ++# endif ++ ++# ifndef NO_INLINE ++# ifdef __GNUC__ ++# if (defined(linux) || defined(__FreeBSD__) || defined(__NetBSD__) || defined(__OpenBSD__)) && defined(__alpha__) ++ ++# ifdef linux ++/* for Linux on Alpha, we use the LIBC _inx/_outx routines */ ++/* note that the appropriate setup via "ioperm" needs to be done */ ++/* *before* any inx/outx is done. */ ++ ++extern void (*_alpha_outb)(char val, unsigned long port); ++static __inline__ void ++outb(unsigned long port, unsigned char val) ++{ ++ _alpha_outb(val, port); ++} ++ ++extern void (*_alpha_outw)(short val, unsigned long port); ++static __inline__ void ++outw(unsigned long port, unsigned short val) ++{ ++ _alpha_outw(val, port); ++} ++ ++extern void (*_alpha_outl)(int val, unsigned long port); ++static __inline__ void ++outl(unsigned long port, unsigned int val) ++{ ++ _alpha_outl(val, port); ++} ++ ++extern unsigned int (*_alpha_inb)(unsigned long port); ++static __inline__ unsigned int ++inb(unsigned long port) ++{ ++ return _alpha_inb(port); ++} ++ ++extern unsigned int (*_alpha_inw)(unsigned long port); ++static __inline__ unsigned int ++inw(unsigned long port) ++{ ++ return _alpha_inw(port); ++} ++ ++extern unsigned int (*_alpha_inl)(unsigned long port); ++static __inline__ unsigned int ++inl(unsigned long port) ++{ ++ return _alpha_inl(port); ++} ++ ++# endif /* linux */ ++ ++# if (defined(__FreeBSD__) || defined(__OpenBSD__)) \ ++ && !defined(DO_PROTOTYPES) ++ ++/* for FreeBSD and OpenBSD on Alpha, we use the libio (resp. libalpha) */ ++/* inx/outx routines */ ++/* note that the appropriate setup via "ioperm" needs to be done */ ++/* *before* any inx/outx is done. */ ++ ++extern void outb(unsigned int port, unsigned char val); ++extern void outw(unsigned int port, unsigned short val); ++extern void outl(unsigned int port, unsigned int val); ++extern unsigned char inb(unsigned int port); ++extern unsigned short inw(unsigned int port); ++extern unsigned int inl(unsigned int port); ++ ++# endif /* (__FreeBSD__ || __OpenBSD__ ) && !DO_PROTOTYPES */ ++ ++ ++#if defined(__NetBSD__) ++#include ++#endif /* __NetBSD__ */ ++ ++/* ++ * inline functions to do unaligned accesses ++ * from linux/include/asm-alpha/unaligned.h ++ */ ++ ++/* ++ * EGCS 1.1 knows about arbitrary unaligned loads. Define some ++ * packed structures to talk about such things with. ++ */ ++ ++struct __una_u64 { unsigned long x __attribute__((packed)); }; ++struct __una_u32 { unsigned int x __attribute__((packed)); }; ++struct __una_u16 { unsigned short x __attribute__((packed)); }; ++ ++/* ++ * Elemental unaligned loads ++ */ ++/* let's try making these things static */ ++ ++static __inline__ unsigned long ldq_u(unsigned long * r11) ++{ ++# if defined(__GNUC__) && ((__GNUC__ > 2) || (__GNUC_MINOR__ >= 91)) ++ const struct __una_u64 *ptr = (const struct __una_u64 *) r11; ++ return ptr->x; ++# else ++ unsigned long r1,r2; ++ __asm__("ldq_u %0,%3\n\t" ++ "ldq_u %1,%4\n\t" ++ "extql %0,%2,%0\n\t" ++ "extqh %1,%2,%1" ++ :"=&r" (r1), "=&r" (r2) ++ :"r" (r11), ++ "m" (*r11), ++ "m" (*(const unsigned long *)(7+(char *) r11))); ++ return r1 | r2; ++# endif ++} ++ ++static __inline__ unsigned long ldl_u(unsigned int * r11) ++{ ++# if defined(__GNUC__) && ((__GNUC__ > 2) || (__GNUC_MINOR__ >= 91)) ++ const struct __una_u32 *ptr = (const struct __una_u32 *) r11; ++ return ptr->x; ++# else ++ unsigned long r1,r2; ++ __asm__("ldq_u %0,%3\n\t" ++ "ldq_u %1,%4\n\t" ++ "extll %0,%2,%0\n\t" ++ "extlh %1,%2,%1" ++ :"=&r" (r1), "=&r" (r2) ++ :"r" (r11), ++ "m" (*r11), ++ "m" (*(const unsigned long *)(3+(char *) r11))); ++ return r1 | r2; ++# endif ++} ++ ++static __inline__ unsigned long ldw_u(unsigned short * r11) ++{ ++# if defined(__GNUC__) && ((__GNUC__ > 2) || (__GNUC_MINOR__ >= 91)) ++ const struct __una_u16 *ptr = (const struct __una_u16 *) r11; ++ return ptr->x; ++# else ++ unsigned long r1,r2; ++ __asm__("ldq_u %0,%3\n\t" ++ "ldq_u %1,%4\n\t" ++ "extwl %0,%2,%0\n\t" ++ "extwh %1,%2,%1" ++ :"=&r" (r1), "=&r" (r2) ++ :"r" (r11), ++ "m" (*r11), ++ "m" (*(const unsigned long *)(1+(char *) r11))); ++ return r1 | r2; ++# endif ++} ++ ++/* ++ * Elemental unaligned stores ++ */ ++ ++static __inline__ void stq_u(unsigned long r5, unsigned long * r11) ++{ ++# if defined(__GNUC__) && ((__GNUC__ > 2) || (__GNUC_MINOR__ >= 91)) ++ struct __una_u64 *ptr = (struct __una_u64 *) r11; ++ ptr->x = r5; ++# else ++ unsigned long r1,r2,r3,r4; ++ ++ __asm__("ldq_u %3,%1\n\t" ++ "ldq_u %2,%0\n\t" ++ "insqh %6,%7,%5\n\t" ++ "insql %6,%7,%4\n\t" ++ "mskqh %3,%7,%3\n\t" ++ "mskql %2,%7,%2\n\t" ++ "bis %3,%5,%3\n\t" ++ "bis %2,%4,%2\n\t" ++ "stq_u %3,%1\n\t" ++ "stq_u %2,%0" ++ :"=m" (*r11), ++ "=m" (*(unsigned long *)(7+(char *) r11)), ++ "=&r" (r1), "=&r" (r2), "=&r" (r3), "=&r" (r4) ++ :"r" (r5), "r" (r11)); ++# endif ++} ++ ++static __inline__ void stl_u(unsigned long r5, unsigned int * r11) ++{ ++# if defined(__GNUC__) && ((__GNUC__ > 2) || (__GNUC_MINOR__ >= 91)) ++ struct __una_u32 *ptr = (struct __una_u32 *) r11; ++ ptr->x = r5; ++# else ++ unsigned long r1,r2,r3,r4; ++ ++ __asm__("ldq_u %3,%1\n\t" ++ "ldq_u %2,%0\n\t" ++ "inslh %6,%7,%5\n\t" ++ "insll %6,%7,%4\n\t" ++ "msklh %3,%7,%3\n\t" ++ "mskll %2,%7,%2\n\t" ++ "bis %3,%5,%3\n\t" ++ "bis %2,%4,%2\n\t" ++ "stq_u %3,%1\n\t" ++ "stq_u %2,%0" ++ :"=m" (*r11), ++ "=m" (*(unsigned long *)(3+(char *) r11)), ++ "=&r" (r1), "=&r" (r2), "=&r" (r3), "=&r" (r4) ++ :"r" (r5), "r" (r11)); ++# endif ++} ++ ++static __inline__ void stw_u(unsigned long r5, unsigned short * r11) ++{ ++# if defined(__GNUC__) && ((__GNUC__ > 2) || (__GNUC_MINOR__ >= 91)) ++ struct __una_u16 *ptr = (struct __una_u16 *) r11; ++ ptr->x = r5; ++# else ++ unsigned long r1,r2,r3,r4; ++ ++ __asm__("ldq_u %3,%1\n\t" ++ "ldq_u %2,%0\n\t" ++ "inswh %6,%7,%5\n\t" ++ "inswl %6,%7,%4\n\t" ++ "mskwh %3,%7,%3\n\t" ++ "mskwl %2,%7,%2\n\t" ++ "bis %3,%5,%3\n\t" ++ "bis %2,%4,%2\n\t" ++ "stq_u %3,%1\n\t" ++ "stq_u %2,%0" ++ :"=m" (*r11), ++ "=m" (*(unsigned long *)(1+(char *) r11)), ++ "=&r" (r1), "=&r" (r2), "=&r" (r3), "=&r" (r4) ++ :"r" (r5), "r" (r11)); ++# endif ++} ++ ++/* to flush the I-cache before jumping to code which just got loaded */ ++# define PAL_imb 134 ++# define istream_mem_barrier() \ ++ __asm__ __volatile__("call_pal %0 #imb" : : "i" (PAL_imb) : "memory") ++# define mem_barrier() __asm__ __volatile__("mb" : : : "memory") ++# ifdef __ELF__ ++# define write_mem_barrier() __asm__ __volatile__("wmb" : : : "memory") ++# else /* ECOFF gas 2.6 doesn't know "wmb" :-( */ ++# define write_mem_barrier() mem_barrier() ++# endif ++ ++ ++# elif defined(linux) && defined(__ia64__) ++ ++# include ++ ++# include ++ ++struct __una_u64 { uint64_t x __attribute__((packed)); }; ++struct __una_u32 { uint32_t x __attribute__((packed)); }; ++struct __una_u16 { uint16_t x __attribute__((packed)); }; ++ ++static __inline__ unsigned long ++__uldq (const unsigned long * r11) ++{ ++ const struct __una_u64 *ptr = (const struct __una_u64 *) r11; ++ return ptr->x; ++} ++ ++static __inline__ unsigned long ++__uldl (const unsigned int * r11) ++{ ++ const struct __una_u32 *ptr = (const struct __una_u32 *) r11; ++ return ptr->x; ++} ++ ++static __inline__ unsigned long ++__uldw (const unsigned short * r11) ++{ ++ const struct __una_u16 *ptr = (const struct __una_u16 *) r11; ++ return ptr->x; ++} ++ ++static __inline__ void ++__ustq (unsigned long r5, unsigned long * r11) ++{ ++ struct __una_u64 *ptr = (struct __una_u64 *) r11; ++ ptr->x = r5; ++} ++ ++static __inline__ void ++__ustl (unsigned long r5, unsigned int * r11) ++{ ++ struct __una_u32 *ptr = (struct __una_u32 *) r11; ++ ptr->x = r5; ++} ++ ++static __inline__ void ++__ustw (unsigned long r5, unsigned short * r11) ++{ ++ struct __una_u16 *ptr = (struct __una_u16 *) r11; ++ ptr->x = r5; ++} ++ ++# define ldq_u(p) __uldq(p) ++# define ldl_u(p) __uldl(p) ++# define ldw_u(p) __uldw(p) ++# define stq_u(v,p) __ustq(v,p) ++# define stl_u(v,p) __ustl(v,p) ++# define stw_u(v,p) __ustw(v,p) ++ ++# define mem_barrier() __asm__ __volatile__ ("mf" ::: "memory") ++# define write_mem_barrier() __asm__ __volatile__ ("mf" ::: "memory") ++ ++/* ++ * This is overkill, but for different reasons depending on where it is used. ++ * This is thus general enough to be used everywhere cache flushes are needed. ++ * It doesn't handle memory access serialisation by other processors, though. ++ */ ++# define ia64_flush_cache(Addr) \ ++ __asm__ __volatile__ ( \ ++ "fc %0;;;" \ ++ "sync.i;;;" \ ++ "mf;;;" \ ++ "srlz.i;;;" \ ++ :: "r"(Addr) : "memory") ++ ++# undef outb ++# undef outw ++# undef outl ++ ++# define outb(a,b) _outb(b,a) ++# define outw(a,b) _outw(b,a) ++# define outl(a,b) _outl(b,a) ++ ++# elif defined(linux) && defined(__x86_64__) ++ ++# include ++ ++# define ldq_u(p) (*((unsigned long *)(p))) ++# define ldl_u(p) (*((unsigned int *)(p))) ++# define ldw_u(p) (*((unsigned short *)(p))) ++# define stq_u(v,p) (*(unsigned long *)(p)) = (v) ++# define stl_u(v,p) (*(unsigned int *)(p)) = (v) ++# define stw_u(v,p) (*(unsigned short *)(p)) = (v) ++ ++# define mem_barrier() \ ++ __asm__ __volatile__ ("lock; addl $0,0(%%rsp)": : :"memory") ++# define write_mem_barrier() \ ++ __asm__ __volatile__ ("": : :"memory") ++ ++ ++static __inline__ void ++outb(unsigned short port, unsigned char val) ++{ ++ __asm__ __volatile__("outb %0,%1" : :"a" (val), "d" (port)); ++} ++ ++ ++static __inline__ void ++outw(unsigned short port, unsigned short val) ++{ ++ __asm__ __volatile__("outw %0,%1" : :"a" (val), "d" (port)); ++} ++ ++static __inline__ void ++outl(unsigned short port, unsigned int val) ++{ ++ __asm__ __volatile__("outl %0,%1" : :"a" (val), "d" (port)); ++} ++ ++static __inline__ unsigned int ++inb(unsigned short port) ++{ ++ unsigned char ret; ++ __asm__ __volatile__("inb %1,%0" : ++ "=a" (ret) : ++ "d" (port)); ++ return ret; ++} ++ ++static __inline__ unsigned int ++inw(unsigned short port) ++{ ++ unsigned short ret; ++ __asm__ __volatile__("inw %1,%0" : ++ "=a" (ret) : ++ "d" (port)); ++ return ret; ++} ++ ++static __inline__ unsigned int ++inl(unsigned short port) ++{ ++ unsigned int ret; ++ __asm__ __volatile__("inl %1,%0" : ++ "=a" (ret) : ++ "d" (port)); ++ return ret; ++} ++ ++# elif (defined(linux) || defined(Lynx) || defined(sun) || defined(__OpenBSD__)) && defined(__sparc__) ++ ++# if !defined(Lynx) ++# ifndef ASI_PL ++# define ASI_PL 0x88 ++# endif ++ ++# define barrier() __asm__ __volatile__(".word 0x8143e00a": : :"memory") ++ ++static __inline__ void ++outb(unsigned long port, unsigned char val) ++{ ++ __asm__ __volatile__("stba %0, [%1] %2" ++ : /* No outputs */ ++ : "r" (val), "r" (port), "i" (ASI_PL)); ++ barrier(); ++} ++ ++static __inline__ void ++outw(unsigned long port, unsigned short val) ++{ ++ __asm__ __volatile__("stha %0, [%1] %2" ++ : /* No outputs */ ++ : "r" (val), "r" (port), "i" (ASI_PL)); ++ barrier(); ++} ++ ++static __inline__ void ++outl(unsigned long port, unsigned int val) ++{ ++ __asm__ __volatile__("sta %0, [%1] %2" ++ : /* No outputs */ ++ : "r" (val), "r" (port), "i" (ASI_PL)); ++ barrier(); ++} ++ ++static __inline__ unsigned int ++inb(unsigned long port) ++{ ++ unsigned int ret; ++ __asm__ __volatile__("lduba [%1] %2, %0" ++ : "=r" (ret) ++ : "r" (port), "i" (ASI_PL)); ++ return ret; ++} ++ ++static __inline__ unsigned int ++inw(unsigned long port) ++{ ++ unsigned int ret; ++ __asm__ __volatile__("lduha [%1] %2, %0" ++ : "=r" (ret) ++ : "r" (port), "i" (ASI_PL)); ++ return ret; ++} ++ ++static __inline__ unsigned int ++inl(unsigned long port) ++{ ++ unsigned int ret; ++ __asm__ __volatile__("lda [%1] %2, %0" ++ : "=r" (ret) ++ : "r" (port), "i" (ASI_PL)); ++ return ret; ++} ++ ++static __inline__ unsigned char ++xf86ReadMmio8(__volatile__ void *base, const unsigned long offset) ++{ ++ unsigned long addr = ((unsigned long)base) + offset; ++ unsigned char ret; ++ ++ __asm__ __volatile__("lduba [%1] %2, %0" ++ : "=r" (ret) ++ : "r" (addr), "i" (ASI_PL)); ++ return ret; ++} ++ ++static __inline__ unsigned short ++xf86ReadMmio16Be(__volatile__ void *base, const unsigned long offset) ++{ ++ unsigned long addr = ((unsigned long)base) + offset; ++ unsigned short ret; ++ ++ __asm__ __volatile__("lduh [%1], %0" ++ : "=r" (ret) ++ : "r" (addr)); ++ return ret; ++} ++ ++static __inline__ unsigned short ++xf86ReadMmio16Le(__volatile__ void *base, const unsigned long offset) ++{ ++ unsigned long addr = ((unsigned long)base) + offset; ++ unsigned short ret; ++ ++ __asm__ __volatile__("lduha [%1] %2, %0" ++ : "=r" (ret) ++ : "r" (addr), "i" (ASI_PL)); ++ return ret; ++} ++ ++static __inline__ unsigned int ++xf86ReadMmio32Be(__volatile__ void *base, const unsigned long offset) ++{ ++ unsigned long addr = ((unsigned long)base) + offset; ++ unsigned int ret; ++ ++ __asm__ __volatile__("ld [%1], %0" ++ : "=r" (ret) ++ : "r" (addr)); ++ return ret; ++} ++ ++static __inline__ unsigned int ++xf86ReadMmio32Le(__volatile__ void *base, const unsigned long offset) ++{ ++ unsigned long addr = ((unsigned long)base) + offset; ++ unsigned int ret; ++ ++ __asm__ __volatile__("lda [%1] %2, %0" ++ : "=r" (ret) ++ : "r" (addr), "i" (ASI_PL)); ++ return ret; ++} ++ ++static __inline__ void ++xf86WriteMmio8(__volatile__ void *base, const unsigned long offset, ++ const unsigned int val) ++{ ++ unsigned long addr = ((unsigned long)base) + offset; ++ ++ __asm__ __volatile__("stba %0, [%1] %2" ++ : /* No outputs */ ++ : "r" (val), "r" (addr), "i" (ASI_PL)); ++ barrier(); ++} ++ ++static __inline__ void ++xf86WriteMmio16Be(__volatile__ void *base, const unsigned long offset, ++ const unsigned int val) ++{ ++ unsigned long addr = ((unsigned long)base) + offset; ++ ++ __asm__ __volatile__("sth %0, [%1]" ++ : /* No outputs */ ++ : "r" (val), "r" (addr)); ++ barrier(); ++} ++ ++static __inline__ void ++xf86WriteMmio16Le(__volatile__ void *base, const unsigned long offset, ++ const unsigned int val) ++{ ++ unsigned long addr = ((unsigned long)base) + offset; ++ ++ __asm__ __volatile__("stha %0, [%1] %2" ++ : /* No outputs */ ++ : "r" (val), "r" (addr), "i" (ASI_PL)); ++ barrier(); ++} ++ ++static __inline__ void ++xf86WriteMmio32Be(__volatile__ void *base, const unsigned long offset, ++ const unsigned int val) ++{ ++ unsigned long addr = ((unsigned long)base) + offset; ++ ++ __asm__ __volatile__("st %0, [%1]" ++ : /* No outputs */ ++ : "r" (val), "r" (addr)); ++ barrier(); ++} ++ ++static __inline__ void ++xf86WriteMmio32Le(__volatile__ void *base, const unsigned long offset, ++ const unsigned int val) ++{ ++ unsigned long addr = ((unsigned long)base) + offset; ++ ++ __asm__ __volatile__("sta %0, [%1] %2" ++ : /* No outputs */ ++ : "r" (val), "r" (addr), "i" (ASI_PL)); ++ barrier(); ++} ++ ++static __inline__ void ++xf86WriteMmio8NB(__volatile__ void *base, const unsigned long offset, ++ const unsigned int val) ++{ ++ unsigned long addr = ((unsigned long)base) + offset; ++ ++ __asm__ __volatile__("stba %0, [%1] %2" ++ : /* No outputs */ ++ : "r" (val), "r" (addr), "i" (ASI_PL)); ++} ++ ++static __inline__ void ++xf86WriteMmio16BeNB(__volatile__ void *base, const unsigned long offset, ++ const unsigned int val) ++{ ++ unsigned long addr = ((unsigned long)base) + offset; ++ ++ __asm__ __volatile__("sth %0, [%1]" ++ : /* No outputs */ ++ : "r" (val), "r" (addr)); ++} ++ ++static __inline__ void ++xf86WriteMmio16LeNB(__volatile__ void *base, const unsigned long offset, ++ const unsigned int val) ++{ ++ unsigned long addr = ((unsigned long)base) + offset; ++ ++ __asm__ __volatile__("stha %0, [%1] %2" ++ : /* No outputs */ ++ : "r" (val), "r" (addr), "i" (ASI_PL)); ++} ++ ++static __inline__ void ++xf86WriteMmio32BeNB(__volatile__ void *base, const unsigned long offset, ++ const unsigned int val) ++{ ++ unsigned long addr = ((unsigned long)base) + offset; ++ ++ __asm__ __volatile__("st %0, [%1]" ++ : /* No outputs */ ++ : "r" (val), "r" (addr)); ++} ++ ++static __inline__ void ++xf86WriteMmio32LeNB(__volatile__ void *base, const unsigned long offset, ++ const unsigned int val) ++{ ++ unsigned long addr = ((unsigned long)base) + offset; ++ ++ __asm__ __volatile__("sta %0, [%1] %2" ++ : /* No outputs */ ++ : "r" (val), "r" (addr), "i" (ASI_PL)); ++} ++ ++# endif /* !Lynx */ ++ ++/* ++ * EGCS 1.1 knows about arbitrary unaligned loads. Define some ++ * packed structures to talk about such things with. ++ */ ++ ++# if defined(__arch64__) || defined(__sparcv9) ++struct __una_u64 { unsigned long x __attribute__((packed)); }; ++# endif ++struct __una_u32 { unsigned int x __attribute__((packed)); }; ++struct __una_u16 { unsigned short x __attribute__((packed)); }; ++ ++static __inline__ unsigned long ldq_u(unsigned long *p) ++{ ++# if defined(__GNUC__) && ((__GNUC__ > 2) || (__GNUC_MINOR__ >= 91)) ++# if defined(__arch64__) || defined(__sparcv9) ++ const struct __una_u64 *ptr = (const struct __una_u64 *) p; ++# else ++ const struct __una_u32 *ptr = (const struct __una_u32 *) p; ++# endif ++ return ptr->x; ++# else ++ unsigned long ret; ++ memmove(&ret, p, sizeof(*p)); ++ return ret; ++# endif ++} ++ ++static __inline__ unsigned long ldl_u(unsigned int *p) ++{ ++# if defined(__GNUC__) && ((__GNUC__ > 2) || (__GNUC_MINOR__ >= 91)) ++ const struct __una_u32 *ptr = (const struct __una_u32 *) p; ++ return ptr->x; ++# else ++ unsigned int ret; ++ memmove(&ret, p, sizeof(*p)); ++ return ret; ++# endif ++} ++ ++static __inline__ unsigned long ldw_u(unsigned short *p) ++{ ++# if defined(__GNUC__) && ((__GNUC__ > 2) || (__GNUC_MINOR__ >= 91)) ++ const struct __una_u16 *ptr = (const struct __una_u16 *) p; ++ return ptr->x; ++# else ++ unsigned short ret; ++ memmove(&ret, p, sizeof(*p)); ++ return ret; ++# endif ++} ++ ++static __inline__ void stq_u(unsigned long val, unsigned long *p) ++{ ++# if defined(__GNUC__) && ((__GNUC__ > 2) || (__GNUC_MINOR__ >= 91)) ++# if defined(__arch64__) || defined(__sparcv9) ++ struct __una_u64 *ptr = (struct __una_u64 *) p; ++# else ++ struct __una_u32 *ptr = (struct __una_u32 *) p; ++# endif ++ ptr->x = val; ++# else ++ unsigned long tmp = val; ++ memmove(p, &tmp, sizeof(*p)); ++# endif ++} ++ ++static __inline__ void stl_u(unsigned long val, unsigned int *p) ++{ ++# if defined(__GNUC__) && ((__GNUC__ > 2) || (__GNUC_MINOR__ >= 91)) ++ struct __una_u32 *ptr = (struct __una_u32 *) p; ++ ptr->x = val; ++# else ++ unsigned int tmp = val; ++ memmove(p, &tmp, sizeof(*p)); ++# endif ++} ++ ++static __inline__ void stw_u(unsigned long val, unsigned short *p) ++{ ++# if defined(__GNUC__) && ((__GNUC__ > 2) || (__GNUC_MINOR__ >= 91)) ++ struct __una_u16 *ptr = (struct __una_u16 *) p; ++ ptr->x = val; ++# else ++ unsigned short tmp = val; ++ memmove(p, &tmp, sizeof(*p)); ++# endif ++} ++ ++# define mem_barrier() /* XXX: nop for now */ ++# define write_mem_barrier() /* XXX: nop for now */ ++ ++# elif defined(__mips__) || defined(__arm32__) ++#ifdef __arm32__ ++#define PORT_SIZE long ++#else ++#define PORT_SIZE short ++#endif ++ ++unsigned int IOPortBase; /* Memory mapped I/O port area */ ++ ++static __inline__ void ++outb(unsigned PORT_SIZE port, unsigned char val) ++{ ++ *(volatile unsigned char*)(((unsigned PORT_SIZE)(port))+IOPortBase) = val; ++} ++ ++static __inline__ void ++outw(unsigned PORT_SIZE port, unsigned short val) ++{ ++ *(volatile unsigned short*)(((unsigned PORT_SIZE)(port))+IOPortBase) = val; ++} ++ ++static __inline__ void ++outl(unsigned PORT_SIZE port, unsigned int val) ++{ ++ *(volatile unsigned int*)(((unsigned PORT_SIZE)(port))+IOPortBase) = val; ++} ++ ++static __inline__ unsigned int ++inb(unsigned PORT_SIZE port) ++{ ++ return *(volatile unsigned char*)(((unsigned PORT_SIZE)(port))+IOPortBase); ++} ++ ++static __inline__ unsigned int ++inw(unsigned PORT_SIZE port) ++{ ++ return *(volatile unsigned short*)(((unsigned PORT_SIZE)(port))+IOPortBase); ++} ++ ++static __inline__ unsigned int ++inl(unsigned PORT_SIZE port) ++{ ++ return *(volatile unsigned int*)(((unsigned PORT_SIZE)(port))+IOPortBase); ++} ++ ++ ++# if defined(__mips__) ++static __inline__ unsigned long ldq_u(unsigned long * r11) ++{ ++ unsigned long r1; ++ __asm__("lwr %0,%2\n\t" ++ "lwl %0,%3\n\t" ++ :"=&r" (r1) ++ :"r" (r11), ++ "m" (*r11), ++ "m" (*(unsigned long *)(3+(char *) r11))); ++ return r1; ++} ++ ++static __inline__ unsigned long ldl_u(unsigned int * r11) ++{ ++ unsigned long r1; ++ __asm__("lwr %0,%2\n\t" ++ "lwl %0,%3\n\t" ++ :"=&r" (r1) ++ :"r" (r11), ++ "m" (*r11), ++ "m" (*(unsigned long *)(3+(char *) r11))); ++ return r1; ++} ++ ++static __inline__ unsigned long ldw_u(unsigned short * r11) ++{ ++ unsigned long r1; ++ __asm__("lwr %0,%2\n\t" ++ "lwl %0,%3\n\t" ++ :"=&r" (r1) ++ :"r" (r11), ++ "m" (*r11), ++ "m" (*(unsigned long *)(1+(char *) r11))); ++ return r1; ++} ++ ++# ifdef linux /* don't mess with other OSs */ ++ ++/* ++ * EGCS 1.1 knows about arbitrary unaligned loads (and we don't support older ++ * versions anyway. Define some packed structures to talk about such things ++ * with. ++ */ ++ ++struct __una_u32 { unsigned int x __attribute__((packed)); }; ++struct __una_u16 { unsigned short x __attribute__((packed)); }; ++ ++static __inline__ void stw_u(unsigned long val, unsigned short *p) ++{ ++ struct __una_u16 *ptr = (struct __una_u16 *) p; ++ ptr->x = val; ++} ++ ++static __inline__ void stl_u(unsigned long val, unsigned int *p) ++{ ++ struct __una_u32 *ptr = (struct __una_u32 *) p; ++ ptr->x = val; ++} ++ ++# if X_BYTE_ORDER == X_BIG_ENDIAN ++static __inline__ unsigned int ++xf86ReadMmio32Be(__volatile__ void *base, const unsigned long offset) ++{ ++ unsigned long addr = ((unsigned long)base) + offset; ++ unsigned int ret; ++ ++ __asm__ __volatile__("lw %0, 0(%1)" ++ : "=r" (ret) ++ : "r" (addr)); ++ return ret; ++} ++ ++static __inline__ void ++xf86WriteMmio32Be(__volatile__ void *base, const unsigned long offset, ++ const unsigned int val) ++{ ++ unsigned long addr = ((unsigned long)base) + offset; ++ ++ __asm__ __volatile__("sw %0, 0(%1)" ++ : /* No outputs */ ++ : "r" (val), "r" (addr)); ++} ++# endif ++ ++# define mem_barrier() \ ++ __asm__ __volatile__( \ ++ "# prevent instructions being moved around\n\t" \ ++ ".set\tnoreorder\n\t" \ ++ "# 8 nops to fool the R4400 pipeline\n\t" \ ++ "nop;nop;nop;nop;nop;nop;nop;nop\n\t" \ ++ ".set\treorder" \ ++ : /* no output */ \ ++ : /* no input */ \ ++ : "memory") ++# define write_mem_barrier() mem_barrier() ++ ++# else /* !linux */ ++ ++# define stq_u(v,p) stl_u(v,p) ++# define stl_u(v,p) (*(unsigned char *)(p)) = (v); \ ++ (*(unsigned char *)(p)+1) = ((v) >> 8); \ ++ (*(unsigned char *)(p)+2) = ((v) >> 16); \ ++ (*(unsigned char *)(p)+3) = ((v) >> 24) ++ ++# define stw_u(v,p) (*(unsigned char *)(p)) = (v); \ ++ (*(unsigned char *)(p)+1) = ((v) >> 8) ++ ++# define mem_barrier() /* NOP */ ++# endif /* !linux */ ++# endif /* __mips__ */ ++ ++# if defined(__arm32__) ++# define ldq_u(p) (*((unsigned long *)(p))) ++# define ldl_u(p) (*((unsigned int *)(p))) ++# define ldw_u(p) (*((unsigned short *)(p))) ++# define stq_u(v,p) (*(unsigned long *)(p)) = (v) ++# define stl_u(v,p) (*(unsigned int *)(p)) = (v) ++# define stw_u(v,p) (*(unsigned short *)(p)) = (v) ++# define mem_barrier() /* NOP */ ++# define write_mem_barrier() /* NOP */ ++# endif /* __arm32__ */ ++ ++# elif (defined(Lynx) || defined(linux) || defined(__OpenBSD__) || defined(__NetBSD__)) && defined(__powerpc__) ++ ++# ifndef MAP_FAILED ++# define MAP_FAILED ((void *)-1) ++# endif ++ ++extern volatile unsigned char *ioBase; ++ ++# define eieio() __asm__ __volatile__ ("eieio" ::: "memory") ++ ++static __inline__ unsigned char ++xf86ReadMmio8(__volatile__ void *base, const unsigned long offset) ++{ ++ register unsigned char val; ++ __asm__ __volatile__( ++ "lbzx %0,%1,%2\n\t" ++ "eieio" ++ : "=r" (val) ++ : "b" (base), "r" (offset), ++ "m" (*((volatile unsigned char *)base+offset))); ++ return val; ++} ++ ++static __inline__ unsigned short ++xf86ReadMmio16Be(__volatile__ void *base, const unsigned long offset) ++{ ++ register unsigned short val; ++ __asm__ __volatile__( ++ "lhzx %0,%1,%2\n\t" ++ "eieio" ++ : "=r" (val) ++ : "b" (base), "r" (offset), ++ "m" (*((volatile unsigned char *)base+offset))); ++ return val; ++} ++ ++static __inline__ unsigned short ++xf86ReadMmio16Le(__volatile__ void *base, const unsigned long offset) ++{ ++ register unsigned short val; ++ __asm__ __volatile__( ++ "lhbrx %0,%1,%2\n\t" ++ "eieio" ++ : "=r" (val) ++ : "b" (base), "r" (offset), ++ "m" (*((volatile unsigned char *)base+offset))); ++ return val; ++} ++ ++static __inline__ unsigned int ++xf86ReadMmio32Be(__volatile__ void *base, const unsigned long offset) ++{ ++ register unsigned int val; ++ __asm__ __volatile__( ++ "lwzx %0,%1,%2\n\t" ++ "eieio" ++ : "=r" (val) ++ : "b" (base), "r" (offset), ++ "m" (*((volatile unsigned char *)base+offset))); ++ return val; ++} ++ ++static __inline__ unsigned int ++xf86ReadMmio32Le(__volatile__ void *base, const unsigned long offset) ++{ ++ register unsigned int val; ++ __asm__ __volatile__( ++ "lwbrx %0,%1,%2\n\t" ++ "eieio" ++ : "=r" (val) ++ : "b" (base), "r" (offset), ++ "m" (*((volatile unsigned char *)base+offset))); ++ return val; ++} ++ ++static __inline__ void ++xf86WriteMmioNB8(__volatile__ void *base, const unsigned long offset, ++ const unsigned char val) ++{ ++ __asm__ __volatile__( ++ "stbx %1,%2,%3\n\t" ++ : "=m" (*((volatile unsigned char *)base+offset)) ++ : "r" (val), "b" (base), "r" (offset)); ++} ++ ++static __inline__ void ++xf86WriteMmioNB16Le(__volatile__ void *base, const unsigned long offset, ++ const unsigned short val) ++{ ++ __asm__ __volatile__( ++ "sthbrx %1,%2,%3\n\t" ++ : "=m" (*((volatile unsigned char *)base+offset)) ++ : "r" (val), "b" (base), "r" (offset)); ++} ++ ++static __inline__ void ++xf86WriteMmioNB16Be(__volatile__ void *base, const unsigned long offset, ++ const unsigned short val) ++{ ++ __asm__ __volatile__( ++ "sthx %1,%2,%3\n\t" ++ : "=m" (*((volatile unsigned char *)base+offset)) ++ : "r" (val), "b" (base), "r" (offset)); ++} ++ ++static __inline__ void ++xf86WriteMmioNB32Le(__volatile__ void *base, const unsigned long offset, ++ const unsigned int val) ++{ ++ __asm__ __volatile__( ++ "stwbrx %1,%2,%3\n\t" ++ : "=m" (*((volatile unsigned char *)base+offset)) ++ : "r" (val), "b" (base), "r" (offset)); ++} ++ ++static __inline__ void ++xf86WriteMmioNB32Be(__volatile__ void *base, const unsigned long offset, ++ const unsigned int val) ++{ ++ __asm__ __volatile__( ++ "stwx %1,%2,%3\n\t" ++ : "=m" (*((volatile unsigned char *)base+offset)) ++ : "r" (val), "b" (base), "r" (offset)); ++} ++ ++static __inline__ void ++xf86WriteMmio8(__volatile__ void *base, const unsigned long offset, ++ const unsigned char val) ++{ ++ xf86WriteMmioNB8(base, offset, val); ++ eieio(); ++} ++ ++static __inline__ void ++xf86WriteMmio16Le(__volatile__ void *base, const unsigned long offset, ++ const unsigned short val) ++{ ++ xf86WriteMmioNB16Le(base, offset, val); ++ eieio(); ++} ++ ++static __inline__ void ++xf86WriteMmio16Be(__volatile__ void *base, const unsigned long offset, ++ const unsigned short val) ++{ ++ xf86WriteMmioNB16Be(base, offset, val); ++ eieio(); ++} ++ ++static __inline__ void ++xf86WriteMmio32Le(__volatile__ void *base, const unsigned long offset, ++ const unsigned int val) ++{ ++ xf86WriteMmioNB32Le(base, offset, val); ++ eieio(); ++} ++ ++static __inline__ void ++xf86WriteMmio32Be(__volatile__ void *base, const unsigned long offset, ++ const unsigned int val) ++{ ++ xf86WriteMmioNB32Be(base, offset, val); ++ eieio(); ++} ++ ++ ++static __inline__ void ++outb(unsigned short port, unsigned char value) ++{ ++ if(ioBase == MAP_FAILED) return; ++ xf86WriteMmio8((void *)ioBase, port, value); ++} ++ ++static __inline__ void ++outw(unsigned short port, unsigned short value) ++{ ++ if(ioBase == MAP_FAILED) return; ++ xf86WriteMmio16Le((void *)ioBase, port, value); ++} ++ ++static __inline__ void ++outl(unsigned short port, unsigned int value) ++{ ++ if(ioBase == MAP_FAILED) return; ++ xf86WriteMmio32Le((void *)ioBase, port, value); ++} ++ ++static __inline__ unsigned int ++inb(unsigned short port) ++{ ++ if(ioBase == MAP_FAILED) return 0; ++ return xf86ReadMmio8((void *)ioBase, port); ++} ++ ++static __inline__ unsigned int ++inw(unsigned short port) ++{ ++ if(ioBase == MAP_FAILED) return 0; ++ return xf86ReadMmio16Le((void *)ioBase, port); ++} ++ ++static __inline__ unsigned int ++inl(unsigned short port) ++{ ++ if(ioBase == MAP_FAILED) return 0; ++ return xf86ReadMmio32Le((void *)ioBase, port); ++} ++ ++# define ldq_u(p) ldl_u(p) ++# define ldl_u(p) ((*(unsigned char *)(p)) | \ ++ (*((unsigned char *)(p)+1)<<8) | \ ++ (*((unsigned char *)(p)+2)<<16) | \ ++ (*((unsigned char *)(p)+3)<<24)) ++# define ldw_u(p) ((*(unsigned char *)(p)) | \ ++ (*((unsigned char *)(p)+1)<<8)) ++ ++# define stq_u(v,p) stl_u(v,p) ++# define stl_u(v,p) (*(unsigned char *)(p)) = (v); \ ++ (*((unsigned char *)(p)+1)) = ((v) >> 8); \ ++ (*((unsigned char *)(p)+2)) = ((v) >> 16); \ ++ (*((unsigned char *)(p)+3)) = ((v) >> 24) ++# define stw_u(v,p) (*(unsigned char *)(p)) = (v); \ ++ (*((unsigned char *)(p)+1)) = ((v) >> 8) ++ ++# define mem_barrier() eieio() ++# define write_mem_barrier() eieio() ++ ++# else /* ix86 */ ++ ++# define ldq_u(p) (*((unsigned long *)(p))) ++# define ldl_u(p) (*((unsigned int *)(p))) ++# define ldw_u(p) (*((unsigned short *)(p))) ++# define stq_u(v,p) (*(unsigned long *)(p)) = (v) ++# define stl_u(v,p) (*(unsigned int *)(p)) = (v) ++# define stw_u(v,p) (*(unsigned short *)(p)) = (v) ++# define mem_barrier() /* NOP */ ++# define write_mem_barrier() /* NOP */ ++ ++# if !defined(FAKEIT) && !defined(__mc68000__) && !defined(__arm__) && !defined(__sh__) && !defined(__hppa__) ++# ifdef GCCUSESGAS ++ ++/* ++ * If gcc uses gas rather than the native assembler, the syntax of these ++ * inlines has to be different. DHD ++ */ ++ ++static __inline__ void ++outb(unsigned short port, unsigned char val) ++{ ++ __asm__ __volatile__("outb %0,%1" : :"a" (val), "d" (port)); ++} ++ ++ ++static __inline__ void ++outw(unsigned short port, unsigned short val) ++{ ++ __asm__ __volatile__("outw %0,%1" : :"a" (val), "d" (port)); ++} ++ ++static __inline__ void ++outl(unsigned short port, unsigned int val) ++{ ++ __asm__ __volatile__("outl %0,%1" : :"a" (val), "d" (port)); ++} ++ ++static __inline__ unsigned int ++inb(unsigned short port) ++{ ++ unsigned char ret; ++ __asm__ __volatile__("inb %1,%0" : ++ "=a" (ret) : ++ "d" (port)); ++ return ret; ++} ++ ++static __inline__ unsigned int ++inw(unsigned short port) ++{ ++ unsigned short ret; ++ __asm__ __volatile__("inw %1,%0" : ++ "=a" (ret) : ++ "d" (port)); ++ return ret; ++} ++ ++static __inline__ unsigned int ++inl(unsigned short port) ++{ ++ unsigned int ret; ++ __asm__ __volatile__("inl %1,%0" : ++ "=a" (ret) : ++ "d" (port)); ++ return ret; ++} ++ ++# else /* GCCUSESGAS */ ++ ++static __inline__ void ++outb(unsigned short port, unsigned char val) ++{ ++ __asm__ __volatile__("out%B0 (%1)" : :"a" (val), "d" (port)); ++} ++ ++static __inline__ void ++outw(unsigned short port, unsigned short val) ++{ ++ __asm__ __volatile__("out%W0 (%1)" : :"a" (val), "d" (port)); ++} ++ ++static __inline__ void ++outl(unsigned short port, unsigned int val) ++{ ++ __asm__ __volatile__("out%L0 (%1)" : :"a" (val), "d" (port)); ++} ++ ++static __inline__ unsigned int ++inb(unsigned short port) ++{ ++ unsigned char ret; ++ __asm__ __volatile__("in%B0 (%1)" : ++ "=a" (ret) : ++ "d" (port)); ++ return ret; ++} ++ ++static __inline__ unsigned int ++inw(unsigned short port) ++{ ++ unsigned short ret; ++ __asm__ __volatile__("in%W0 (%1)" : ++ "=a" (ret) : ++ "d" (port)); ++ return ret; ++} ++ ++static __inline__ unsigned int ++inl(unsigned short port) ++{ ++ unsigned int ret; ++ __asm__ __volatile__("in%L0 (%1)" : ++ "=a" (ret) : ++ "d" (port)); ++ return ret; ++} ++ ++# endif /* GCCUSESGAS */ ++ ++# else /* !defined(FAKEIT) && !defined(__mc68000__) && !defined(__arm__) && !defined(__sh__) && !defined(__hppa__)*/ ++ ++static __inline__ void ++outb(unsigned short port, unsigned char val) ++{ ++} ++ ++static __inline__ void ++outw(unsigned short port, unsigned short val) ++{ ++} ++ ++static __inline__ void ++outl(unsigned short port, unsigned int val) ++{ ++} ++ ++static __inline__ unsigned int ++inb(unsigned short port) ++{ ++ return 0; ++} ++ ++static __inline__ unsigned int ++inw(unsigned short port) ++{ ++ return 0; ++} ++ ++static __inline__ unsigned int ++inl(unsigned short port) ++{ ++ return 0; ++} ++ ++# endif /* FAKEIT */ ++ ++# endif /* ix86 */ ++ ++# elif defined(__powerpc__) /* && !__GNUC__ */ ++/* ++ * NON-GCC PowerPC - Presumed to be PowerMAX OS for now ++ */ ++# ifndef PowerMAX_OS ++# error - Non-gcc PowerPC and !PowerMAXOS ??? ++# endif ++ ++# define PPCIO_DEBUG 0 ++# define PPCIO_INLINE 1 ++# define USE_ABS_MACRO 1 ++/* ++ * Use compiler intrinsics to access certain PPC machine instructions ++ */ ++# define eieio() __inst_eieio() ++# define stw_brx(val,base,ndx) __inst_sthbrx(val,base,ndx) ++# define stl_brx(val,base,ndx) __inst_stwbrx(val,base,ndx) ++# define ldw_brx(base,ndx) __inst_lhbrx(base,ndx) ++# define ldl_brx(base,ndx) __inst_lwbrx(base,ndx) ++ ++# define ldq_u(p) (*((unsigned long long *)(p))) ++# define ldl_u(p) (*((unsigned long *)(p))) ++# define ldw_u(p) (*((unsigned short *)(p))) ++# define stq_u(v,p) (*(unsigned long long *)(p)) = (v) ++# define stl_u(v,p) (*(unsigned long *)(p)) = (v) ++# define stw_u(v,p) (*(unsigned short *)(p)) = (v) ++# define mem_barrier() eieio() ++# define write_mem_barrier() eieio() ++ ++extern volatile unsigned char *ioBase; ++ ++# if !defined(abs) && defined(USE_ABS_MACRO) ++# define abs(x) ((x) >= 0 ? (x) : -(x)) ++# endif ++ ++# undef inb ++# undef inw ++# undef inl ++# undef outb ++# undef outw ++# undef outl ++ ++# if PPCIO_DEBUG ++ ++extern void debug_outb(unsigned int a, unsigned char b, int line, char *file); ++extern void debug_outw(unsigned int a, unsigned short w, int line, char *file); ++extern void debug_outl(unsigned int a, unsigned int l, int line, char *file); ++extern unsigned char debug_inb(unsigned int a, int line, char *file); ++extern unsigned short debug_inw(unsigned int a, int line, char *file); ++extern unsigned int debug_inl(unsigned int a, int line, char *file); ++ ++# define outb(a,b) debug_outb(a,b, __LINE__, __FILE__) ++# define outw(a,w) debug_outw(a,w, __LINE__, __FILE__) ++# define outl(a,l) debug_outl(a,l, __LINE__, __FILE__) ++# define inb(a) debug_inb(a, __LINE__, __FILE__) ++# define inw(a) debug_inw(a, __LINE__, __FILE__) ++# define inl(a) debug_inl(a, __LINE__, __FILE__) ++ ++# else /* !PPCIO_DEBUG */ ++ ++extern unsigned char inb(unsigned int a); ++extern unsigned short inw(unsigned int a); ++extern unsigned int inl(unsigned int a); ++ ++# if PPCIO_INLINE ++ ++# define outb(a,b) \ ++ (*((volatile unsigned char *)(ioBase + (a))) = (b), eieio()) ++# define outw(a,w) (stw_brx((w),ioBase,(a)), eieio()) ++# define outl(a,l) (stl_brx((l),ioBase,(a)), eieio()) ++ ++# else /* !PPCIO_INLINE */ ++ ++extern void outb(unsigned int a, unsigned char b); ++extern void outw(unsigned int a, unsigned short w); ++extern void outl(unsigned int a, unsigned int l); ++ ++# endif /* PPCIO_INLINE */ ++ ++# endif /* !PPCIO_DEBUG */ ++ ++# else /* !GNUC && !PPC */ ++# if !defined(QNX4) ++# if defined(__STDC__) && (__STDC__ == 1) ++# ifndef asm ++# define asm __asm ++# endif ++# endif ++# ifdef SVR4 ++#if 0 ++# include ++#endif ++# ifndef __HIGHC__ ++# ifndef __USLC__ ++# define __USLC__ ++# endif ++# endif ++# endif ++# ifndef SCO325 ++# if defined(USL) ++# if defined(IN_MODULE) ++# /* avoid including for on UnixWare */ ++# define ushort unsigned short ++# define ushort_t unsigned short ++# define ulong unsigned long ++# define ulong_t unsigned long ++# define uint_t unsigned int ++# define uchar_t unsigned char ++# else ++# include ++# endif /* IN_MODULE */ ++# endif /* USL */ ++# include ++# else ++# include "scoasm.h" ++# endif ++# if !defined(__HIGHC__) && !defined(SCO325) ++# pragma asm partial_optimization outl ++# pragma asm partial_optimization outw ++# pragma asm partial_optimization outb ++# pragma asm partial_optimization inl ++# pragma asm partial_optimization inw ++# pragma asm partial_optimization inb ++# endif ++# endif ++# define ldq_u(p) (*((unsigned long *)(p))) ++# define ldl_u(p) (*((unsigned int *)(p))) ++# define ldw_u(p) (*((unsigned short *)(p))) ++# define stq_u(v,p) (*(unsigned long *)(p)) = (v) ++# define stl_u(v,p) (*(unsigned int *)(p)) = (v) ++# define stw_u(v,p) (*(unsigned short *)(p)) = (v) ++# define mem_barrier() /* NOP */ ++# define write_mem_barrier() /* NOP */ ++# endif /* __GNUC__ */ ++ ++# if defined(QNX4) ++# include ++extern unsigned inb(unsigned port); ++extern unsigned inw(unsigned port); ++extern unsigned inl(unsigned port); ++extern void outb(unsigned port, unsigned val); ++extern void outw(unsigned port, unsigned val); ++extern void outl(unsigned port, unsigned val); ++# endif /* QNX4 */ ++ ++# if defined(IODEBUG) && defined(__GNUC__) ++# undef inb ++# undef inw ++# undef inl ++# undef outb ++# undef outw ++# undef outl ++# define inb(a) __extension__ ({unsigned char __c=RealInb(a); ErrorF("inb(0x%03x) = 0x%02x\t@ line %4d, file %s\n", a, __c, __LINE__, __FILE__);__c;}) ++# define inw(a) __extension__ ({unsigned short __c=RealInw(a); ErrorF("inw(0x%03x) = 0x%04x\t@ line %4d, file %s\n", a, __c, __LINE__, __FILE__);__c;}) ++# define inl(a) __extension__ ({unsigned int __c=RealInl(a); ErrorF("inl(0x%03x) = 0x%08x\t@ line %4d, file %s\n", a, __c, __LINE__, __FILE__);__c;}) ++ ++# define outb(a,b) (ErrorF("outb(0x%03x, 0x%02x)\t@ line %4d, file %s\n", a, b, __LINE__, __FILE__),RealOutb(a,b)) ++# define outw(a,b) (ErrorF("outw(0x%03x, 0x%04x)\t@ line %4d, file %s\n", a, b, __LINE__, __FILE__),RealOutw(a,b)) ++# define outl(a,b) (ErrorF("outl(0x%03x, 0x%08x)\t@ line %4d, file %s\n", a, b, __LINE__, __FILE__),RealOutl(a,b)) ++# endif ++ ++# endif /* NO_INLINE */ ++ ++# ifdef __alpha__ ++/* entry points for Mmio memory access routines */ ++extern int (*xf86ReadMmio8)(void *, unsigned long); ++extern int (*xf86ReadMmio16)(void *, unsigned long); ++extern int (*xf86ReadMmio32)(void *, unsigned long); ++extern void (*xf86WriteMmio8)(int, void *, unsigned long); ++extern void (*xf86WriteMmio16)(int, void *, unsigned long); ++extern void (*xf86WriteMmio32)(int, void *, unsigned long); ++extern void (*xf86WriteMmioNB8)(int, void *, unsigned long); ++extern void (*xf86WriteMmioNB16)(int, void *, unsigned long); ++extern void (*xf86WriteMmioNB32)(int, void *, unsigned long); ++extern void xf86JensenMemToBus(char *, long, long, int); ++extern void xf86JensenBusToMem(char *, char *, unsigned long, int); ++extern void xf86SlowBCopyFromBus(unsigned char *, unsigned char *, int); ++extern void xf86SlowBCopyToBus(unsigned char *, unsigned char *, int); ++ ++/* Some macros to hide the system dependencies for MMIO accesses */ ++/* Changed to kill noise generated by gcc's -Wcast-align */ ++# define MMIO_IN8(base, offset) (*xf86ReadMmio8)(base, offset) ++# define MMIO_IN16(base, offset) (*xf86ReadMmio16)(base, offset) ++# define MMIO_IN32(base, offset) (*xf86ReadMmio32)(base, offset) ++ ++# if defined (JENSEN_SUPPORT) ++# define MMIO_OUT32(base, offset, val) \ ++ (*xf86WriteMmio32)((CARD32)(val), base, offset) ++# define MMIO_ONB32(base, offset, val) \ ++ (*xf86WriteMmioNB32)((CARD32)(val), base, offset) ++# else ++# define MMIO_OUT32(base, offset, val) \ ++ do { \ ++ write_mem_barrier(); \ ++ *(volatile CARD32 *)(void *)(((CARD8*)(base)) + (offset)) = (val); \ ++ } while (0) ++# define MMIO_ONB32(base, offset, val) \ ++ *(volatile CARD32 *)(void *)(((CARD8*)(base)) + (offset)) = (val) ++# endif ++ ++# define MMIO_OUT8(base, offset, val) \ ++ (*xf86WriteMmio8)((CARD8)(val), base, offset) ++# define MMIO_OUT16(base, offset, val) \ ++ (*xf86WriteMmio16)((CARD16)(val), base, offset) ++# define MMIO_ONB8(base, offset, val) \ ++ (*xf86WriteMmioNB8)((CARD8)(val), base, offset) ++# define MMIO_ONB16(base, offset, val) \ ++ (*xf86WriteMmioNB16)((CARD16)(val), base, offset) ++# define MMIO_MOVE32(base, offset, val) \ ++ MMIO_OUT32(base, offset, val) ++ ++# elif defined(__powerpc__) ++ /* ++ * we provide byteswapping and no byteswapping functions here ++ * with byteswapping as default, ++ * drivers that don't need byteswapping should define PPC_MMIO_IS_BE ++ */ ++# define MMIO_IN8(base, offset) xf86ReadMmio8(base, offset) ++# define MMIO_OUT8(base, offset, val) \ ++ xf86WriteMmio8(base, offset, (CARD8)(val)) ++# define MMIO_ONB8(base, offset, val) \ ++ xf86WriteMmioNB8(base, offset, (CARD8)(val)) ++ ++# if defined(PPC_MMIO_IS_BE) /* No byteswapping */ ++# define MMIO_IN16(base, offset) xf86ReadMmio16Be(base, offset) ++# define MMIO_IN32(base, offset) xf86ReadMmio32Be(base, offset) ++# define MMIO_OUT16(base, offset, val) \ ++ xf86WriteMmio16Be(base, offset, (CARD16)(val)) ++# define MMIO_OUT32(base, offset, val) \ ++ xf86WriteMmio32Be(base, offset, (CARD32)(val)) ++# define MMIO_ONB16(base, offset, val) \ ++ xf86WriteMmioNB16Be(base, offset, (CARD16)(val)) ++# define MMIO_ONB32(base, offset, val) \ ++ xf86WriteMmioNB32Be(base, offset, (CARD32)(val)) ++# else /* byteswapping is the default */ ++# define MMIO_IN16(base, offset) xf86ReadMmio16Le(base, offset) ++# define MMIO_IN32(base, offset) xf86ReadMmio32Le(base, offset) ++# define MMIO_OUT16(base, offset, val) \ ++ xf86WriteMmio16Le(base, offset, (CARD16)(val)) ++# define MMIO_OUT32(base, offset, val) \ ++ xf86WriteMmio32Le(base, offset, (CARD32)(val)) ++# define MMIO_ONB16(base, offset, val) \ ++ xf86WriteMmioNB16Le(base, offset, (CARD16)(val)) ++# define MMIO_ONB32(base, offset, val) \ ++ xf86WriteMmioNB32Le(base, offset, (CARD32)(val)) ++# endif ++ ++# define MMIO_MOVE32(base, offset, val) \ ++ xf86WriteMmio32Be(base, offset, (CARD32)(val)) ++ ++static __inline__ void ppc_flush_icache(char *addr) ++{ ++ __asm__ volatile ( ++ "dcbf 0,%0;" ++ "sync;" ++ "icbi 0,%0;" ++ "sync;" ++ "isync;" ++ : : "r"(addr) : "memory"); ++} ++ ++# elif defined(__sparc__) ++ /* ++ * Like powerpc, we provide byteswapping and no byteswapping functions ++ * here with byteswapping as default, drivers that don't need byteswapping ++ * should define SPARC_MMIO_IS_BE (perhaps create a generic macro so that we ++ * do not need to use PPC_MMIO_IS_BE and the sparc one in all the same places ++ * of drivers?). ++ */ ++# define MMIO_IN8(base, offset) xf86ReadMmio8(base, offset) ++# define MMIO_OUT8(base, offset, val) \ ++ xf86WriteMmio8(base, offset, (CARD8)(val)) ++# define MMIO_ONB8(base, offset, val) \ ++ xf86WriteMmio8NB(base, offset, (CARD8)(val)) ++ ++# if defined(SPARC_MMIO_IS_BE) /* No byteswapping */ ++# define MMIO_IN16(base, offset) xf86ReadMmio16Be(base, offset) ++# define MMIO_IN32(base, offset) xf86ReadMmio32Be(base, offset) ++# define MMIO_OUT16(base, offset, val) \ ++ xf86WriteMmio16Be(base, offset, (CARD16)(val)) ++# define MMIO_OUT32(base, offset, val) \ ++ xf86WriteMmio32Be(base, offset, (CARD32)(val)) ++# define MMIO_ONB16(base, offset, val) \ ++ xf86WriteMmio16BeNB(base, offset, (CARD16)(val)) ++# define MMIO_ONB32(base, offset, val) \ ++ xf86WriteMmio32BeNB(base, offset, (CARD32)(val)) ++# else /* byteswapping is the default */ ++# define MMIO_IN16(base, offset) xf86ReadMmio16Le(base, offset) ++# define MMIO_IN32(base, offset) xf86ReadMmio32Le(base, offset) ++# define MMIO_OUT16(base, offset, val) \ ++ xf86WriteMmio16Le(base, offset, (CARD16)(val)) ++# define MMIO_OUT32(base, offset, val) \ ++ xf86WriteMmio32Le(base, offset, (CARD32)(val)) ++# define MMIO_ONB16(base, offset, val) \ ++ xf86WriteMmio16LeNB(base, offset, (CARD16)(val)) ++# define MMIO_ONB32(base, offset, val) \ ++ xf86WriteMmio32LeNB(base, offset, (CARD32)(val)) ++# endif ++ ++# define MMIO_MOVE32(base, offset, val) \ ++ xf86WriteMmio32Be(base, offset, (CARD32)(val)) ++ ++# else /* !__alpha__ && !__powerpc__ && !__sparc__ */ ++ ++# define MMIO_IN8(base, offset) \ ++ *(volatile CARD8 *)(((CARD8*)(base)) + (offset)) ++# define MMIO_IN16(base, offset) \ ++ *(volatile CARD16 *)(void *)(((CARD8*)(base)) + (offset)) ++# define MMIO_IN32(base, offset) \ ++ *(volatile CARD32 *)(void *)(((CARD8*)(base)) + (offset)) ++# define MMIO_OUT8(base, offset, val) \ ++ *(volatile CARD8 *)(((CARD8*)(base)) + (offset)) = (val) ++# define MMIO_OUT16(base, offset, val) \ ++ *(volatile CARD16 *)(void *)(((CARD8*)(base)) + (offset)) = (val) ++# define MMIO_OUT32(base, offset, val) \ ++ *(volatile CARD32 *)(void *)(((CARD8*)(base)) + (offset)) = (val) ++# define MMIO_ONB8(base, offset, val) MMIO_OUT8(base, offset, val) ++# define MMIO_ONB16(base, offset, val) MMIO_OUT16(base, offset, val) ++# define MMIO_ONB32(base, offset, val) MMIO_OUT32(base, offset, val) ++ ++# define MMIO_MOVE32(base, offset, val) MMIO_OUT32(base, offset, val) ++ ++# endif /* __alpha__ */ ++ ++/* ++ * With Intel, the version in os-support/misc/SlowBcopy.s is used. ++ * This avoids port I/O during the copy (which causes problems with ++ * some hardware). ++ */ ++# ifdef __alpha__ ++# define slowbcopy_tobus(src,dst,count) xf86SlowBCopyToBus(src,dst,count) ++# define slowbcopy_frombus(src,dst,count) xf86SlowBCopyFromBus(src,dst,count) ++# else /* __alpha__ */ ++# define slowbcopy_tobus(src,dst,count) xf86SlowBcopy(src,dst,count) ++# define slowbcopy_frombus(src,dst,count) xf86SlowBcopy(src,dst,count) ++# endif /* __alpha__ */ ++ ++#endif /* _COMPILER_H */ +Index: VirtualBox-7.0.4/src/VBox/Additions/x11/vboxvideo/xorg-server.h +=================================================================== +--- /dev/null ++++ VirtualBox-7.0.4/src/VBox/Additions/x11/vboxvideo/xorg-server.h +@@ -0,0 +1,247 @@ ++/* include/xorg-server.h. Generated from xorg-server.h.in by configure. */ ++/* xorg-server.h.in -*- c -*- ++ * ++ * This file is the template file for the xorg-server.h file which gets ++ * installed as part of the SDK. The #defines in this file overlap ++ * with those from config.h, but only for those options that we want ++ * to export to external modules. Boilerplate autotool #defines such ++ * as HAVE_STUFF and PACKAGE_NAME is kept in config.h ++ * ++ * It is still possible to update config.h.in using autoheader, since ++ * autoheader only creates a .h.in file for the first ++ * AM_CONFIG_HEADER() line, and thus does not overwrite this file. ++ * ++ * However, it should be kept in sync with this file. ++ */ ++ ++#ifndef _XORG_SERVER_H_ ++#define _XORG_SERVER_H_ ++ ++/* Support BigRequests extension */ ++#define BIGREQS 1 ++ ++/* Default font path */ ++#define COMPILEDDEFAULTFONTPATH "/usr/local/lib/X11/fonts/misc/,/usr/local/lib/X11/fonts/TTF/,/usr/local/lib/X11/fonts/OTF,/usr/local/lib/X11/fonts/Type1/,/usr/local/lib/X11/fonts/100dpi/,/usr/local/lib/X11/fonts/75dpi/" ++ ++/* Support Composite Extension */ ++#define COMPOSITE 1 ++ ++/* Use OsVendorInit */ ++#define DDXOSINIT 1 ++ ++/* Build DPMS extension */ ++#define DPMSExtension 1 ++ ++/* Build GLX extension */ ++#define GLXEXT 1 ++ ++/* Include handhelds.org h3600 touchscreen driver */ ++/* #undef H3600_TS */ ++ ++/* Support XDM-AUTH*-1 */ ++#define HASXDMAUTH 1 ++ ++/* Support SHM */ ++#define HAS_SHM 1 ++ ++/* Support IPv6 for TCP connections */ ++#define IPv6 1 ++ ++/* Support MIT Misc extension */ ++#define MITMISC 1 ++ ++/* Support MIT-SHM Extension */ ++#define MITSHM 1 ++ ++/* Disable some debugging code */ ++#define NDEBUG 1 ++ ++/* Need XFree86 helper functions */ ++#define NEED_XF86_PROTOTYPES 1 ++ ++/* Need XFree86 typedefs */ ++#define NEED_XF86_TYPES 1 ++ ++/* Internal define for Xinerama */ ++#define PANORAMIX 1 ++ ++/* Support RANDR extension */ ++#define RANDR 1 ++ ++/* Support RENDER extension */ ++#define RENDER 1 ++ ++/* Support X resource extension */ ++#define RES 1 ++ ++/* Support MIT-SCREEN-SAVER extension */ ++#define SCREENSAVER 1 ++ ++/* Use a lock to prevent multiple servers on a display */ ++#define SERVER_LOCK 1 ++ ++/* Support SHAPE extension */ ++#define SHAPE 1 ++ ++/* Include time-based scheduler */ ++#define SMART_SCHEDULE 1 ++ ++/* Define to 1 on systems derived from System V Release 4 */ ++/* #undef SVR4 */ ++ ++/* Support TCP socket connections */ ++#define TCPCONN 1 ++ ++/* Enable touchscreen support */ ++/* #undef TOUCHSCREEN */ ++ ++/* Support tslib touchscreen abstraction library */ ++/* #undef TSLIB */ ++ ++/* Support UNIX socket connections */ ++#define UNIXCONN 1 ++ ++/* unaligned word accesses behave as expected */ ++/* #undef WORKING_UNALIGNED_INT */ ++ ++/* Support XCMisc extension */ ++#define XCMISC 1 ++ ++/* Support Xdmcp */ ++#define XDMCP 1 ++ ++/* Build XFree86 BigFont extension */ ++/* #undef XF86BIGFONT */ ++ ++/* Support XFree86 miscellaneous extensions */ ++#define XF86MISC 1 ++ ++/* Support XFree86 Video Mode extension */ ++#define XF86VIDMODE 1 ++ ++/* Build XDGA support */ ++#define XFreeXDGA 1 ++ ++/* Support Xinerama extension */ ++#define XINERAMA 1 ++ ++/* Support X Input extension */ ++#define XINPUT 1 ++ ++/* Build XKB */ ++#define XKB 1 ++ ++/* Enable XKB per default */ ++#define XKB_DFLT_DISABLED 0 ++ ++/* Build XKB server */ ++#define XKB_IN_SERVER 1 ++ ++/* Support loadable input and output drivers */ ++/* #undef XLOADABLE */ ++ ++/* Build DRI extension */ ++#define XF86DRI 1 ++ ++/* Build DRI2 extension */ ++/* #undef DRI2 */ ++ ++/* Build Xorg server */ ++#define XORGSERVER 1 ++ ++/* Vendor release */ ++/* #undef XORG_RELEASE */ ++ ++/* Current Xorg version */ ++#define XORG_VERSION_CURRENT (((1) * 10000000) + ((5) * 100000) + ((3) * 1000) + 0) ++ ++/* Build Xv Extension */ ++#define XvExtension 1 ++ ++/* Build XvMC Extension */ ++#define XvMCExtension 1 ++ ++/* Build XRes extension */ ++#define XResExtension 1 ++ ++/* Support XSync extension */ ++#define XSYNC 1 ++ ++/* Support XTest extension */ ++#define XTEST 1 ++ ++/* Support XTrap extension */ ++/* #undef XTRAP */ ++ ++/* Support Xv Extension */ ++#define XV 1 ++ ++/* Vendor name */ ++#define XVENDORNAME "The X.Org Foundation" ++ ++/* Endian order */ ++#define _X_BYTE_ORDER X_LITTLE_ENDIAN ++/* Deal with multiple architecture compiles on Mac OS X */ ++#ifndef __APPLE_CC__ ++#define X_BYTE_ORDER _X_BYTE_ORDER ++#else ++#ifdef __BIG_ENDIAN__ ++#define X_BYTE_ORDER X_BIG_ENDIAN ++#else ++#define X_BYTE_ORDER X_LITTLE_ENDIAN ++#endif ++#endif ++ ++/* BSD-compliant source */ ++/* #undef _BSD_SOURCE */ ++ ++/* POSIX-compliant source */ ++/* #undef _POSIX_SOURCE */ ++ ++/* X/Open-compliant source */ ++/* #undef _XOPEN_SOURCE */ ++ ++/* Vendor web address for support */ ++#define __VENDORDWEBSUPPORT__ "http://wiki.x.org" ++ ++/* Location of configuration file */ ++#define __XCONFIGFILE__ "xorg.conf" ++ ++/* XKB default rules */ ++#define __XKBDEFRULES__ "xorg" ++ ++/* Name of X server */ ++#define __XSERVERNAME__ "Xorg" ++ ++/* Define to 1 if unsigned long is 64 bits. */ ++/* #undef _XSERVER64 */ ++ ++/* Building vgahw module */ ++#define WITH_VGAHW 1 ++ ++/* System is BSD-like */ ++/* #undef CSRG_BASED */ ++ ++/* Solaris 8 or later? */ ++/* #undef __SOL8__ */ ++ ++/* System has PC console */ ++/* #undef PCCONS_SUPPORT */ ++ ++/* System has PCVT console */ ++/* #undef PCVT_SUPPORT */ ++ ++/* System has syscons console */ ++/* #undef SYSCONS_SUPPORT */ ++ ++/* System has wscons console */ ++/* #undef WSCONS_SUPPORT */ ++ ++/* Loadable XFree86 server awesomeness */ ++#define XFree86LOADER 1 ++ ++/* Use libpciaccess */ ++#define XSERVER_LIBPCIACCESS 1 ++ ++#endif /* _XORG_SERVER_H_ */ ++ +Index: VirtualBox-7.0.4/src/VBox/Additions/x11/vboxvideo/Makefile.kmk +=================================================================== +--- VirtualBox-7.0.4.orig/src/VBox/Additions/x11/vboxvideo/Makefile.kmk ++++ VirtualBox-7.0.4/src/VBox/Additions/x11/vboxvideo/Makefile.kmk +@@ -410,7 +410,7 @@ ifdef VBOX_USE_SYSTEM_XORG_HEADERS + SYSMODS := $(filter-out vboxvideo_drv%,$(SYSMODS)) + vboxvideo_drv_system_TEMPLATE = VBOXGUESTR3XORGMOD + vboxvideo_drv_system_CFLAGS := \ +- $(vboxvideo_drv_70_CFLAGS) -include xorg-server.h ++ $(vboxvideo_drv_70_CFLAGS) -Isrc/VBox/Additions/x11/x11include/XFree86-4.3/Xserver/ -Isrc/VBox/Additions/x11/x11include/XFree86-4.3/X11/ + vboxvideo_drv_system_DEFS := $(filter-out _XORG_SERVER_H_ _DIX_CONFIG_H_, $(vboxvideo_15_DEFS)) + vboxvideo_drv_system_INCS += \ + $(PATH_ROOT)/src/VBox/Runtime/include \ + diff --git a/fixes_for_leap15.5.patch b/fixes_for_leap15.5.patch new file mode 100644 index 0000000..ac96df7 --- /dev/null +++ b/fixes_for_leap15.5.patch @@ -0,0 +1,83 @@ +Index: VirtualBox-7.0.4/src/VBox/Additions/linux/drm/vbox_drv.h +=================================================================== +--- VirtualBox-7.0.4.orig/src/VBox/Additions/linux/drm/vbox_drv.h ++++ VirtualBox-7.0.4/src/VBox/Additions/linux/drm/vbox_drv.h +@@ -166,9 +166,9 @@ + # include + # include + # include +-# if RTLNX_VER_MAX(5,15,0) && !RTLNX_RHEL_RANGE(8,7, 8,99) && !RTLNX_RHEL_MAJ_PREREQ(9,1) +-# include +-# endif ++//# if RTLNX_VER_MAX(5,15,0) && !RTLNX_RHEL_RANGE(8,7, 8,99) && !RTLNX_RHEL_MAJ_PREREQ(9,1) ++//# include ++//# endif + # include + #else /* < 5.5.0 || RHEL < 8.3 || SLES < 15-SP3 */ + # include +Index: VirtualBox-7.0.4/src/VBox/Additions/linux/drm/vbox_drv.c +=================================================================== +--- VirtualBox-7.0.4.orig/src/VBox/Additions/linux/drm/vbox_drv.c ++++ VirtualBox-7.0.4/src/VBox/Additions/linux/drm/vbox_drv.c +@@ -52,13 +52,7 @@ + + /** Detect whether kernel mode setting is OFF. */ + #if defined(CONFIG_VGA_CONSOLE) +-# if RTLNX_VER_MIN(5,17,0) + # define VBOX_VIDEO_NOMODESET() drm_firmware_drivers_only() && vbox_modeset == -1 +-# elif RTLNX_VER_MIN(4,7,0) +-# define VBOX_VIDEO_NOMODESET() vgacon_text_force() && vbox_modeset == -1 +-# else /* < 4.7.0 */ +-# define VBOX_VIDEO_NOMODESET() 0 +-# endif /* < 4.7.0 */ + #else /* !CONFIG_VGA_CONSOLE */ + # define VBOX_VIDEO_NOMODESET() 0 + #endif /* !CONFIG_VGA_CONSOLE */ +@@ -372,7 +366,7 @@ static struct drm_driver driver = { + #endif + + .fops = &vbox_fops, +-#if RTLNX_VER_MAX(5,15,0) && !RTLNX_RHEL_RANGE(8,7, 8,99) && !RTLNX_RHEL_MAJ_PREREQ(9,1) ++#if RTLNX_VER_MIN(5,15,0) + .irq_handler = vbox_irq_handler, + #endif + .name = DRIVER_NAME, +Index: VirtualBox-7.0.4/src/VBox/Additions/linux/drm/vbox_irq.c +=================================================================== +--- VirtualBox-7.0.4.orig/src/VBox/Additions/linux/drm/vbox_irq.c ++++ VirtualBox-7.0.4/src/VBox/Additions/linux/drm/vbox_irq.c +@@ -205,21 +205,11 @@ int vbox_irq_init(struct vbox_private *v + { + INIT_WORK(&vbox->hotplug_work, vbox_hotplug_worker); + vbox_update_mode_hints(vbox); +-#if RTLNX_VER_MIN(5,15,0) || RTLNX_RHEL_RANGE(8,7, 8,99) || RTLNX_RHEL_MAJ_PREREQ(9,1) + return request_irq(VBOX_DRM_TO_PCI_DEV(vbox->dev)->irq, vbox_irq_handler, IRQF_SHARED, vbox->dev->driver->name, vbox->dev); +-#elif RTLNX_VER_MIN(3,16,0) || RTLNX_RHEL_MAJ_PREREQ(7,1) +- return drm_irq_install(vbox->dev, VBOX_DRM_TO_PCI_DEV(vbox->dev)->irq); +-#else +- return drm_irq_install(vbox->dev); +-#endif + } + + void vbox_irq_fini(struct vbox_private *vbox) + { +-#if RTLNX_VER_MIN(5,15,0) || RTLNX_RHEL_RANGE(8,7, 8,99) || RTLNX_RHEL_MAJ_PREREQ(9,1) + free_irq(VBOX_DRM_TO_PCI_DEV(vbox->dev)->irq, vbox->dev); +-#else +- drm_irq_uninstall(vbox->dev); +-#endif + flush_work(&vbox->hotplug_work); + } +Index: VirtualBox-7.0.4/src/VBox/Additions/linux/drm/vbox_ttm.c +=================================================================== +--- VirtualBox-7.0.4.orig/src/VBox/Additions/linux/drm/vbox_ttm.c ++++ VirtualBox-7.0.4/src/VBox/Additions/linux/drm/vbox_ttm.c +@@ -320,7 +320,7 @@ static struct ttm_tt *vbox_ttm_tt_create + if (ttm_tt_init(tt, bdev, size, page_flags, dummy_read_page)) { + #elif RTLNX_VER_MAX(5,11,0) && !RTLNX_RHEL_RANGE(8,5, 8,99) + if (ttm_tt_init(tt, bo, page_flags)) { +-#elif RTLNX_VER_MAX(5,19,0) ++#elif RTLNX_VER_MAX(5,14,0) + if (ttm_tt_init(tt, bo, page_flags, ttm_write_combined)) { + #else + if (ttm_tt_init(tt, bo, page_flags, ttm_write_combined, 0)) { diff --git a/vbox-disable-updates.diff b/vbox-disable-updates.diff index 114d926..3c3bd3e 100644 --- a/vbox-disable-updates.diff +++ b/vbox-disable-updates.diff @@ -11,7 +11,7 @@ Index: VirtualBox-7.0.4/src/VBox/Frontends/VirtualBox/src/settings/UISettingsDia #endif /* Language page: */ -@@ -224,17 +222,7 @@ void UISettingsDialogGlobal::prepare() +@@ -224,17 +222,6 @@ void UISettingsDialogGlobal::prepare() addPageHelpKeyword(iPageIndex, "preferences"); break; } @@ -22,7 +22,7 @@ Index: VirtualBox-7.0.4/src/VBox/Frontends/VirtualBox/src/settings/UISettingsDia - pSettingsPage = new UIGlobalSettingsUpdate; - addItem(":/refresh_32px.png", ":/refresh_24px.png", ":/refresh_16px.png", - iPageIndex, "#update", pSettingsPage); - addPageHelpKeyword(iPageIndex, "preferences"); +- addPageHelpKeyword(iPageIndex, "preferences"); - break; - } -#endif /* VBOX_GUI_WITH_NETWORK_MANAGER */ diff --git a/vbox-fpie.diff b/vbox-fpie.diff index a329f45..ff94801 100644 --- a/vbox-fpie.diff +++ b/vbox-fpie.diff @@ -2,7 +2,7 @@ Index: VirtualBox-7.0.4/Config.kmk =================================================================== --- VirtualBox-7.0.4.orig/Config.kmk +++ VirtualBox-7.0.4/Config.kmk -@@ -6622,6 +6622,9 @@ TEMPLATE_VBOXR3HARDENEDEXE_LDFLAGS.darwi +@@ -6674,6 +6674,9 @@ TEMPLATE_VBOXR3HARDENEDEXE_LDFLAGS.darwi ifeq ($(KBUILD_TARGET),linux) # not necessary except USE_LIB_PCAP is defined in SUPR3HardenedMain.cpp # TEMPLATE_VBOXR3HARDENEDEXE_LIBS += cap @@ -12,7 +12,7 @@ Index: VirtualBox-7.0.4/Config.kmk endif ifeq ($(KBUILD_TARGET),win) # No CRT! TEMPLATE_VBOXR3HARDENEDEXE_SDKS = VBOX_NTDLL $(TEMPLATE_VBOXR3EXE_SDKS) -@@ -6654,8 +6657,8 @@ ifeq ($(KBUILD_TARGET),win) # No CRT! +@@ -6706,8 +6709,8 @@ ifeq ($(KBUILD_TARGET),win) # No CRT! TEMPLATE_VBOXR3HARDENEDEXE_VBOX_IMPORT_CHECKER.win = noimports else ifn1of ($(KBUILD_TARGET), os2) ifneq ($(KBUILD_TYPE),asan) # Keep RPATH in asan builds so we can find libasan.so.X and libubsan.so.Y. diff --git a/vbox_remove_smp_mflags.patch b/vbox_remove_smp_mflags.patch deleted file mode 100644 index 0411a52..0000000 --- a/vbox_remove_smp_mflags.patch +++ /dev/null @@ -1,13 +0,0 @@ -Index: VirtualBox-7.0.4/src/libs/libxml2-2.9.14/libxml.spec.in -=================================================================== ---- VirtualBox-7.0.4.orig/src/libs/libxml2-2.9.14/libxml.spec.in -+++ VirtualBox-7.0.4/src/libs/libxml2-2.9.14/libxml.spec.in -@@ -103,7 +103,7 @@ sed -i 's|#!/usr/bin/python |#!%{__pytho - - %build - %configure --make %{_smp_mflags} -+make - - find doc -type f -exec chmod 0644 \{\} \; - diff --git a/virtualbox-kmp-files b/virtualbox-kmp-files index a58d8cc..2be9d75 100644 --- a/virtualbox-kmp-files +++ b/virtualbox-kmp-files @@ -6,4 +6,4 @@ %{kernel_module_directory}/%2-%1/extra/vboxnetflt.ko %{kernel_module_directory}/%2-%1/extra/vboxsf.ko %{kernel_module_directory}/%2-%1/extra/vboxguest.ko -#%{kernel_module_directory}/%2-%1/extra/vboxvideo.ko +%{kernel_module_directory}/%2-%1/extra/vboxvideo.ko diff --git a/virtualbox-snpritnf-buffer-overflow.patch b/virtualbox-snpritnf-buffer-overflow.patch deleted file mode 100644 index db8820f..0000000 --- a/virtualbox-snpritnf-buffer-overflow.patch +++ /dev/null @@ -1,12 +0,0 @@ -Index: VirtualBox-7.0.4/src/VBox/ExtPacks/VBoxDTrace/onnv/lib/libdtrace/common/dt_subr.c -=================================================================== ---- VirtualBox-7.0.4.orig/src/VBox/ExtPacks/VBoxDTrace/onnv/lib/libdtrace/common/dt_subr.c -+++ VirtualBox-7.0.4/src/VBox/ExtPacks/VBoxDTrace/onnv/lib/libdtrace/common/dt_subr.c -@@ -833,6 +833,7 @@ dt_gmatch(const char *s, const char *p) - #else - return (p == NULL || *p == '\0' || RTStrSimplePatternMatch(p, s)); /** @todo implement gmatch. */ - #endif -+ return 0; - } - - char * diff --git a/virtualbox.changes b/virtualbox.changes index 839246c..dffa51f 100644 --- a/virtualbox.changes +++ b/virtualbox.changes @@ -1,4 +1,14 @@ ------------------------------------------------------------------- +Fri Dec 23 23:24:21 UTC 2022 - Larry Finger + + To eliminate some VM failures while using the kernel version of vboxvideo.ko for Leap 15.4, + the build of this module is turned on again. Fixes boo#1206651 - Leap 15.4 guests running + VirtualBox 7.0.4 crash when run on hosts with certain Intel graphics cards + + File "virtualbox-snpritnf-buffer-overflow.patch" deleted. + File "vbox_remove_smp_mflags.patch" deleted. + File "fixes_for_leap15.5.patch" added to fix chanes needed for backports to the Leap 15.5 kernel +------------------------------------------------------------------- Wed Nov 30 17:22:42 UTC 2022 - Larry Finger Fixes boo#1205868 - VirtualBox 7.0.4 crashes when machine log is requested from GUI diff --git a/virtualbox.spec b/virtualbox.spec index aca2539..232c1ba 100644 --- a/virtualbox.spec +++ b/virtualbox.spec @@ -120,8 +120,6 @@ Patch12: smap.diff Patch13: gcc5-real-support.patch # Patch to build with gnu sed correctly Patch14: virtualbox-sed-params.patch -# Patch to use snprintf correcty and not overflow dst buffer -Patch15: virtualbox-snpritnf-buffer-overflow.patch # Patch to add code to explain USB Passthru Patch16: vbox-usb-warning.diff # Patch to ensure that VirtualBoxVM is SUID @@ -130,8 +128,6 @@ Patch17: vbox-suid-warning.diff Patch18: fix_conflict_between_host_and_guest.patch # Fix change in kernel API for ttm_bo_move_memcpy() Patch19: modify_for_4_8_bo_move.patch -# Remove all mention of _smp_mflags -Patch20: vbox_remove_smp_mflags.patch # Disable experimental and incomplete CLOUD_NET Patch21: turn_off_cloud_net.patch # Fix rpmlint error for script /lib/usr/virtualbox/vboxshell.py @@ -141,7 +137,6 @@ Patch23: vbox-python-py310.patch # fix build of Python and dev package on openSUSE 11.3 (was vbox-detection.diff) # use plain python3 interpreter of the distro (part of former switch_to_pyton3.4+.patch), Patch24: vbox-python-selection.patch -# Use build parameters to control video driver problems Patch25: remove_vbox_video_build.patch # Fixes for modified kernel in Leap 42.3 Patch26: VirtualBox-5.2.10-xclient.patch @@ -160,6 +155,8 @@ Patch32: handle_gsoap_208103.patch # Fix for struct file_operations backport in 15.3 Patch33: fixes_for_leap15.3.patch Patch34: fix_kmp_build.patch +# Fix for backports to 15.5 +Patch35: fixes_for_leap15.5.patch # # Common BuildRequires for both virtualbox and virtualbox-kmp BuildRequires: %{kernel_module_package_buildreqs} @@ -298,6 +295,25 @@ and others, and limited virtualization of macOS guests on Apple hardware. VirtualBox is freely available as Open Source Software under the terms of the GNU Public License (GPL). + + + + + + + + + + + + + + + + + + + ########################################## @@ -318,6 +334,25 @@ Obsoletes: %{name}-ose-qt < %{version} %description qt This package contains the code for the GUI used to control VMs. + + + + + + + + + + + + + + + + + + + ######################################### @@ -334,6 +369,25 @@ Obsoletes: %{name}-vboxwebsrv < %{version} The VirtualBox web server is used to control headless VMs using a browser. + + + + + + + + + + + + + + + + + + + ########################################### @@ -357,6 +411,25 @@ Requires(pre): net-tools-deprecated %description guest-tools VirtualBox guest addition tools. + + + + + + + + + + + + + + + + + + + ########################################### @@ -378,6 +451,25 @@ Obsoletes: python3-%{name}-ose < %{version} %description -n python3-%{name} Python XPCOM bindings to %{name}. Used e.g. by vboxgtk package. + + + + + + + + + + + + + + + + + + + ########################################### @@ -394,6 +486,25 @@ Obsoletes: %{name}-ose-devel < %{version} %description devel Development file for %{name} + + + + + + + + + + + + + + + + + + + ########################################### @@ -427,6 +538,25 @@ Source files for %{name} guest kernel modules These can be built for custom kernels using sudo %{_sbindir}/vboxguestconfig + + + + + + + + + + + + + + + + + + + ########################################### @@ -441,6 +571,25 @@ BuildArch: noarch %description guest-desktop-icons This package contains icons for guest desktop files that were created on the desktop. + + + + + + + + + + + + + + + + + + + ########################################### @@ -481,12 +630,10 @@ This package contains the kernel-modules that VirtualBox uses to create or run v %patch12 -p1 %patch13 -p1 %patch14 -p1 -%patch15 -p1 %patch16 -p1 %patch17 -p1 %patch18 -p1 %patch19 -p1 -%patch20 -p1 %patch21 -p1 %patch22 -p1 %patch23 -p1 @@ -508,6 +655,9 @@ This package contains the kernel-modules that VirtualBox uses to create or run v %patch33 -p1 %endif %patch34 -p1 +%if 0%{?sle_version} == 150500 && 0%{?is_opensuse} +%patch35 -p1 +%endif ### Documents for virtualbox main package ### %if %{main_package} @@ -1182,10 +1332,10 @@ COMMON_KMK_FLAGS=" # # build kernel modules for guest and host (check novel-kmp package as example) # host modules : vboxdrv,vboxnetflt,vboxnetadp -# guest modules : vboxguest,vboxsf +# guest modules : vboxguest,vboxsf,vboxvideo echo "build kernel modules" for vbox_module in out/linux.*/release/bin/src/vbox{drv,netflt,netadp} \ - out/linux.*/release/bin/additions/src/vbox{guest,sf}; do + out/linux.*/release/bin/additions/src/vbox{guest,sf,video}; do #get the module name from path module_name=$(basename "$vbox_module") @@ -1211,7 +1361,7 @@ for vbox_module in out/linux.*/release/bin/src/vbox{drv,netflt,netadp} \ $PWD/modules_build_dir/$flavor/$module_name SYMBOLS="$PWD/modules_build_dir/$flavor/vboxdrv/Module.symvers" fi - # copy vboxguest (for guest) module symbols which are used by vboxsf km: + # copy vboxguest (for guest) module symbols which are used by vboxsf and vboxvideo km's: if [ "$module_name" = "vboxsf" -o \ "$module_name" = "vboxvideo" ] ; then cp $PWD/modules_build_dir/$flavor/vboxguest/Module.symvers \ @@ -1228,9 +1378,9 @@ done export INSTALL_MOD_PATH=%{buildroot} export INSTALL_MOD_DIR=extra #to install modules we use here similar steps like in build phase, go through all the modules : -for module_name in vbox{drv,netflt,netadp,guest,sf} +for module_name in vbox{drv,netflt,netadp,guest,sf,video} do - #and through the all flavors + #and through all flavors for flavor in %{flavors_to_build}; do make -C %{_prefix}/src/linux-obj/%{_target_cpu}/$flavor modules_install M=$PWD/modules_build_dir/$flavor/$module_name done