mirror of
				https://github.com/MariaDB/server.git
				synced 2025-11-03 14:33:32 +03:00 
			
		
		
		
	Patches for NetBSD/macppc
Fixed bug in LEFT JOIN Added bdb_log_buffer_size Docs/manual.texi: Added documentation for mysqlhotcopy client/mysql.cc: Fixed core dump when column names couldn't be read configure.in: Fixed possible error mit-pthreads/Changes-mysql: Patches for NetBSD/macppc mit-pthreads/config/config.guess: Patches for NetBSD/macppc mit-pthreads/config/configure.in: Patches for NetBSD/macppc mit-pthreads/config/configure: Patches for NetBSD/macppc mysql-test/r/join_outer.result: New join test mysql-test/t/join_outer.test: New join test scripts/mysqlhotcopy.sh: Patches from ASK sql/ha_berkeley.cc: Adeed log buffer cache sql/ha_berkeley.h: Adeed log buffer cache sql/log.cc: Fixed possible overrun bug sql/mysqld.cc: Fix for Mac OS X public beta Added bdb_log_buffer_size sql/sql_select.cc: Fixed bug in LEFT JOIN tests/mail_to_db.pl: Removed unsubscribe tails tests/pmail.pl: Sort mails according to date
This commit is contained in:
		
							
								
								
									
										109
									
								
								mit-pthreads/machdep/engine-powerpc-netbsd.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										109
									
								
								mit-pthreads/machdep/engine-powerpc-netbsd.h
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,109 @@
 | 
			
		||||
/* ==== machdep.h ============================================================
 | 
			
		||||
 * Copyright (c) 1994 Chris Provenzano (proven@athena.mit.edu) and
 | 
			
		||||
 * Ken Raeburn (raeburn@mit.edu).
 | 
			
		||||
 *
 | 
			
		||||
 * engine-alpha-osf1.h,v 1.4.4.1 1995/12/13 05:41:42 proven Exp
 | 
			
		||||
 *
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include <unistd.h>
 | 
			
		||||
#include <setjmp.h>
 | 
			
		||||
#include <sys/time.h>
 | 
			
		||||
#include <sys/cdefs.h>
 | 
			
		||||
#include <sys/signal.h>  /* for _NSIG */
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * The first machine dependent functions are the SEMAPHORES
 | 
			
		||||
 * needing the test and set instruction.
 | 
			
		||||
 */
 | 
			
		||||
#define SEMAPHORE_CLEAR 0
 | 
			
		||||
#define SEMAPHORE_SET   0xffff
 | 
			
		||||
 | 
			
		||||
#define SEMAPHORE_TEST_AND_SET(lock)            \
 | 
			
		||||
({                                              \
 | 
			
		||||
        volatile long t1, temp = SEMAPHORE_SET; \
 | 
			
		||||
        __asm__ volatile(                       \
 | 
			
		||||
	  "1: lwarx  %0,0,%1;			\
 | 
			
		||||
	      cmpwi  %0, 0;                     \
 | 
			
		||||
	      bne    2f;                        \
 | 
			
		||||
	      stwcx. %2,0,%1;                   \
 | 
			
		||||
	      bne-   1b;                        \
 | 
			
		||||
	   2: "                                 \
 | 
			
		||||
          :"=r" (t1)                            \
 | 
			
		||||
          :"m" (lock), "r" (temp));             \
 | 
			
		||||
        t1;                                     \
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
#define SEMAPHORE_RESET(lock)           *lock = SEMAPHORE_CLEAR
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * New types
 | 
			
		||||
 */
 | 
			
		||||
typedef int semaphore;
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * sigset_t macros
 | 
			
		||||
 */
 | 
			
		||||
#define        SIG_ANY(sig)            (sig)
 | 
			
		||||
#define        SIGMAX                  (_NSIG-1)
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * New Strutures
 | 
			
		||||
 */
 | 
			
		||||
struct machdep_pthread {
 | 
			
		||||
    void                       *(*start_routine)(void *);
 | 
			
		||||
    void                       *start_argument;
 | 
			
		||||
    void                       *machdep_stack;
 | 
			
		||||
    struct itimerval           machdep_timer;
 | 
			
		||||
    jmp_buf	               machdep_istate;
 | 
			
		||||
    unsigned long              machdep_fstate[66];
 | 
			
		||||
				/* 64-bit fp regs 0-31 + fpscr */
 | 
			
		||||
				/* We pretend the fpscr is 64 bits */
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * Static machdep_pthread initialization values.
 | 
			
		||||
 * For initial thread only.
 | 
			
		||||
 */
 | 
			
		||||
#define MACHDEP_PTHREAD_INIT    \
 | 
			
		||||
       { NULL, NULL, NULL, { { 0, 0 }, { 0, 100000 } }, { 0 }, { 0 } }
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * Minimum stack size
 | 
			
		||||
 */
 | 
			
		||||
#define PTHREAD_STACK_MIN      2048
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * Some fd flag defines that are necessary to distinguish between posix
 | 
			
		||||
 * behavior and bsd4.3 behavior.
 | 
			
		||||
 */
 | 
			
		||||
#define __FD_NONBLOCK          O_NONBLOCK
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * New functions
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
__BEGIN_DECLS
 | 
			
		||||
 | 
			
		||||
#if defined(PTHREAD_KERNEL)
 | 
			
		||||
 | 
			
		||||
#define __machdep_stack_get(x)      (x)->machdep_stack
 | 
			
		||||
#define __machdep_stack_set(x, y)   (x)->machdep_stack = y
 | 
			
		||||
#define __machdep_stack_repl(x, y)                          \
 | 
			
		||||
{                                                           \
 | 
			
		||||
    if ((stack = __machdep_stack_get(x))) {                 \
 | 
			
		||||
        __machdep_stack_free(stack);                        \
 | 
			
		||||
    }                                                       \
 | 
			
		||||
    __machdep_stack_set(x, y);                              \
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
int machdep_save_state(void);
 | 
			
		||||
 | 
			
		||||
void __machdep_save_fp_state(unsigned long *);
 | 
			
		||||
void __machdep_restore_fp_state(unsigned long *);
 | 
			
		||||
void *__machdep_stack_alloc(size_t);
 | 
			
		||||
void __machdep_stack_free(void *);
 | 
			
		||||
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
__END_DECLS
 | 
			
		||||
		Reference in New Issue
	
	Block a user