/* * Copyright (c) 2000 Apple Computer, Inc. All rights reserved. * * @APPLE_LICENSE_HEADER_START@ * * The contents of this file constitute Original Code as defined in and * are subject to the Apple Public Source License Version 1.1 (the * "License"). You may not use this file except in compliance with the * License. Please obtain a copy of the License at * http://www.apple.com/publicsource and read it before using this file. * * This Original Code and all software distributed under the License are * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the * License for the specific language governing rights and limitations * under the License. * * @APPLE_LICENSE_HEADER_END@ */ #;************************************************************************** #;* Boolean OSCompareAndSwap(SInt32 oldValue, SInt32 newValue, SInt32 * ptr) * #;************************************************************************** .globl _OSCompareAndSwap _OSCompareAndSwap: #; this is _lame_, the project will not currently accept asm code that #; requires anything beyond a 386, but that chip: #; - does not support MP #; - does not support the cmpxchgl instruction #; - does not support the lock meta-instruction #; so what is a poor guy to do? comment it out... pushl %edi pushl %esi movl 0+8+4(%esp),%eax #; oldValue movl 4+8+4(%esp),%edi #; newValue movl 8+8+4(%esp),%esi #; ptr lock cmpxchgl %edi,0(%esi) #; CAS (eax is an implicit operand) sete %al #; did CAS succeed? (TZ=1) andl $0x000000ff,%eax #; clear out the high bytes (has to be an easier way...) popl %esi popl %edi ret