aclrtCreateContext
Description
Creates a context explicitly in the current process or thread.
For the
For the
If aclrtSetDevice is not called in the application, when aclrtCreateContext is called for the first time, the system binds a default stream to the device based on the device ID passed by the API (one device is bound to only one default stream). Therefore, when aclrtCreateContext is called for the first time, the number of occupied streams is calculated as follows: Number of occupied streams = Number of default streams bound to the device + Number of streams contained in the context.
Restrictions
The following use cases are supported:
- If aclrtCreateContext is not called to explicitly create a context, the system uses the default context, which is created implicitly with the aclrtSetDevice call.
- Implicit context creation: applies to simple apps with low complicity of interaction logic. However, in multithreaded programming, the execution result depends on the thread scheduling sequence.
- Explicit context creation: applies to large apps with complex interaction logic, offering better app readability and maintainability.
- If a device is specified in a process, multiple threads in the process can share the context explicitly created on the device by calling aclrtCreateContext.
- If multiple contexts are created in a process, the current thread can use only one context at a time. It is recommended that aclrtSetCurrentContext be used to specify the context of the current thread to improve program maintainability. (The number of contexts depends on the number of streams. For details, see aclrtCreateStream.)
Prototype
aclError aclrtCreateContext(aclrtContext *context, int32_t deviceId)
Parameters
Parameter |
Input/Output |
Description |
|---|---|---|
context |
Output |
Context pointer. |
deviceId |
Input |
Device on which to create a context. Must be in the range of [0, Device count – 1]. Call aclrtGetDeviceCount to obtain the device count. |
Returns
The value 0 indicates success, and other values indicate failure. For details, see aclError.