📄 common.h
字号:
/* * mips/common.h * Common MIPS configuration information. * * Copyright (c) 1996, 1997, 1998, 1999 * Transvirtual Technologies, Inc. All rights reserved. * * Copyright (c) 2003 * Kaffe.org contributors. See ChangeLog for details. * * See the file "license.terms" for information on usage and redistribution * of this file. * * by Alexandre Oliva <oliva@dcc.unicamp.br> * and Edouard G. Parmelan <egp@free.fr> */#ifndef __mips_common_h#define __mips_common_h/* The R5900 is the Mips Core in the PS2 (Playstation 2)* It has most of the Mips III instructions set, some of the Mips IV * instructions, it lacks the Mips II "ll" and "sc" instructions and * it has 128 bit GP registers and 32 bit FPU registers. There is no * FPU Emulation present in the default kernel. Since no 64 bit* FPU registers exist, doubles are passed in 2 GP registers.*/#ifdef _R5900#define PS2LINUX#undef HAVE_MIPSII_INSTRUCTIONS#endif #if defined(HAVE_MIPSII_INSTRUCTIONS)/* * Do an atomic compare and exchange. The address 'A' is checked against * value 'O' and if they match it's exchanged with value 'N'. * We return '1' if the exchange is sucessful, otherwise 0. */#define COMPARE_AND_EXCHANGE(A,O,N) \({ \ unsigned int tmp, ret; \ \ asm volatile( \ " .set noreorder\n" \ " .set mips2\n" \ "1: ll %0, %2\n" \ " bne %0, %3,2f\n" \ " move %0, $0\n" \ " move %0, %4\n" \ " sc %0, %1\n" \ " beqz %0, 1b\n" \ " nop\n" \ "2:\n" \ " .set mips0\n" \ " .set reorder\n" \ : "=&r" (ret), "=m" (*(A)) \ : "m" (*(A)), "r" (O), "r" (N) \ : "memory"); \ ret; \})#else/* * Do an atomic compare and exchange. The address 'A' is checked against * value 'O' and if they match it's exchanged with value 'N'. * We return '1' if the exchange is sucessful, otherwise 0. */#define COMPARE_AND_EXCHANGE(A,O,N) \({ \ int ret = 0; \ jthread_suspendall(); \ \ if (*(A) == (O)) { \ *(A) = (N); \ ret = 1; \ } \ jthread_unsuspendall(); \ ret; \})#endif #endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -