forked from mirrors/gecko-dev
		
	 0cf457e591
			
		
	
	
		0cf457e591
		
	
	
	
	
		
			
			Similar to the two previous patches in this stack, add a separate header file for these callback functions. The header file name matches the file name of the other two files (i.e. ends with "Callbacks" and not "Callback"), even though the function name is `SetWaitCallback`. Differential Revision: https://phabricator.services.mozilla.com/D123199
		
			
				
	
	
		
			54 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			54 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*-
 | |
|  * vim: set ts=8 sts=2 et sw=2 tw=80:
 | |
|  * This Source Code Form is subject to the terms of the Mozilla Public
 | |
|  * License, v. 2.0. If a copy of the MPL was not distributed with this
 | |
|  * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 | |
| 
 | |
| #ifndef js_WaitCallbacks_h
 | |
| #define js_WaitCallbacks_h
 | |
| 
 | |
| #include <stddef.h>
 | |
| #include <stdint.h>
 | |
| 
 | |
| #include "jstypes.h"
 | |
| 
 | |
| struct JS_PUBLIC_API JSRuntime;
 | |
| 
 | |
| namespace JS {
 | |
| 
 | |
| /**
 | |
|  * When the JSRuntime is about to block in an Atomics.wait() JS call or in a
 | |
|  * `wait` instruction in WebAssembly, it can notify the host by means of a call
 | |
|  * to BeforeWaitCallback.  After the wait, it can notify the host by means of a
 | |
|  * call to AfterWaitCallback.  Both callbacks must be null, or neither.
 | |
|  *
 | |
|  * (If you change the callbacks from null to not-null or vice versa while some
 | |
|  * thread on the runtime is in a wait, you will be sorry.)
 | |
|  *
 | |
|  * The argument to the BeforeWaitCallback is a pointer to uninitialized
 | |
|  * stack-allocated working memory of size WAIT_CALLBACK_CLIENT_MAXMEM bytes.
 | |
|  * The caller of SetWaitCallback() must pass the amount of memory it will need,
 | |
|  * and this amount will be checked against that limit and the process will crash
 | |
|  * reliably if the check fails.
 | |
|  *
 | |
|  * The value returned by the BeforeWaitCallback will be passed to the
 | |
|  * AfterWaitCallback.
 | |
|  *
 | |
|  * The AfterWaitCallback will be called even if the wakeup is spurious and the
 | |
|  * thread goes right back to waiting again.  Of course the thread will call the
 | |
|  * BeforeWaitCallback once more before it goes to sleep in this situation.
 | |
|  */
 | |
| 
 | |
| static constexpr size_t WAIT_CALLBACK_CLIENT_MAXMEM = 32;
 | |
| 
 | |
| using BeforeWaitCallback = void* (*)(uint8_t* memory);
 | |
| using AfterWaitCallback = void (*)(void* cookie);
 | |
| 
 | |
| extern JS_PUBLIC_API void SetWaitCallback(JSRuntime* rt,
 | |
|                                           BeforeWaitCallback beforeWait,
 | |
|                                           AfterWaitCallback afterWait,
 | |
|                                           size_t requiredMemory);
 | |
| 
 | |
| }  // namespace JS
 | |
| 
 | |
| #endif  // js_WaitCallbacks_h
 |