Skip to content

Commit

Permalink
Add a new single API for Level Zero Init and Driver Retrieval
Browse files Browse the repository at this point in the history
Closes oneapi-src#298

Signed-off-by: Neil R. Spruit <[email protected]>
  • Loading branch information
nrspruit committed May 6, 2024
1 parent dd631e2 commit 574b199
Show file tree
Hide file tree
Showing 3 changed files with 84 additions and 1 deletion.
4 changes: 4 additions & 0 deletions scripts/core/common.yml
Original file line number Diff line number Diff line change
Expand Up @@ -556,6 +556,10 @@ etors:
desc: $x_image_pitched_exp_desc_t
version: "1.9"
value: "0x0002001F"
- name: INIT_DRIVER_TYPE_DESC
desc: $x_init_driver_type_desc_t
version: "1.10"
value: "0x00020020"
- name: COMMAND_GRAPH_EXP_DESC
desc: $x_command_graph_exp_desc_t
version: "2.0"
Expand Down
76 changes: 76 additions & 0 deletions scripts/core/driver.yml
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,82 @@ params:
if count is less than the number of drivers available, then the loader shall only retrieve that number of drivers.
--- #--------------------------------------------------------------------------
type: enum
desc: "Supported driver initialization type flags"
class: $x
name: $x_init_driver_type_flags_t
version: "1.10"
details:
- "Bit Field which details the driver types to be initialized and returned to the user."
- "Value Definition:"
- "0, do not init or retrieve any drivers."
- "ZE_INIT_DRIVER_TYPE_FLAG_GPU, GPU Drivers are Init and driver handles retrieved."
- "ZE_INIT_DRIVER_TYPE_FLAG_NPU, NPU Drivers are Init and driver handles retrieved."
- "ZE_INIT_DRIVER_TYPE_FLAG_GPU | ZE_INIT_DRIVER_TYPE_FLAG_NPU, NPU & GPU Drivers are Init and driver handles retrieved."
- "UINT32_MAX All Drivers of any type are Init and driver handles retrieved."
etors:
- name: GPU
desc: "initialize and retrieve GPU drivers"
- name: NPU
desc: "initialize and retrieve NPU drivers"
--- #--------------------------------------------------------------------------
type: struct
desc: "Init Driver Type descriptor"
class: $x
name: $x_init_driver_type_desc_t
version: "1.10"
base: $x_base_desc_t
members:
- type: $x_init_driver_type_flags_t
name: flags
desc: |
[in] driver type init flags.
must be a valid combination of $x_init_driver_type_flag_t or UINT32_MAX;
driver types are init and retrieved based on these init flags in zeInitDrivers().
init: "0"
--- #--------------------------------------------------------------------------
type: function
desc: "Initialize the $OneApi driver(s) based on the driver types requested and retrieve the driver handles."
class: $x
name: InitDrivers
version: "1.10"
decl: static
ordinal: "0"
details:
- "The application must call this function or zeInit before calling any other function."
- "The application can call InitDrivers or zeInit to init the drivers on the system."
- "Calls to zeInit or InitDrivers will not alter the drivers retrieved thru either api."
- "Drivers init thru zeInit or InitDrivers will not be reInitialized once init in an application.
The Loader will determine if the already init driver needs to be delivered to the user thru the init type flags."
- "Already init Drivers will not be uninitialized if the call to InitDrivers does not include that driver's type.
Those init drivers which don't match the init flags will not have their driver handles returned to the user in that InitDrivers call."
- "If this function or zeInit is not called, then all other functions will return $X_RESULT_ERROR_UNINITIALIZED."
- "Only one instance of each driver will be initialized per process."
- "A driver represents a collection of physical devices."
- "Multiple calls to this function will return identical driver handles, in the same order."
- "The drivers returned to the caller will be based on the init types which state the drivers to be included."
- "The application may pass nullptr for pDrivers when only querying the number of drivers."
- "The application may call this function multiple times with different flags or environment variables enabled."
- "The application must call this function after forking new processes. Each forked process must call this function."
- "The application may call this function from simultaneous threads."
- "The implementation of this function must be thread-safe for scenarios where multiple libraries may initialize the driver(s) simultaneously."
params:
- type: "uint32_t*"
name: pCount
desc: |
[in,out] pointer to the number of driver instances.
if count is zero, then the loader shall update the value with the total number of drivers available.
if count is greater than the number of drivers available, then the loader shall update the value with the correct number of drivers available.
- type: "$x_driver_handle_t*"
name: phDrivers
desc: |
[in,out][optional][range(0, *pCount)] array of driver instance handles.
if count is less than the number of drivers available, then the loader shall only retrieve that number of drivers.
- type: "$x_init_driver_type_desc_t*"
name: desc
desc: |
[in] descriptor containing the driver type initialization details including $x_init_driver_type_flag_t combinations.
--- #--------------------------------------------------------------------------
type: enum
desc: "Supported API versions"
class: $xDriver
name: $x_api_version_t
Expand Down
5 changes: 4 additions & 1 deletion scripts/parse_specs.py
Original file line number Diff line number Diff line change
Expand Up @@ -743,7 +743,10 @@ def _append(lst, key, val):
if re.match(r"stype", m['name']):
_append(rets, "$X_RESULT_ERROR_UNSUPPORTED_VERSION", "`%s != %s->stype`"%(re.sub(r"(\$\w)_(.*)_t.*", r"\1_STRUCTURE_TYPE_\2", typename).upper(), item['name']))
else:
_append(rets, "$X_RESULT_ERROR_INVALID_ENUMERATION", "`%s < %s->%s`"%(meta['enum'][mtypename]['max'], item['name'], m['name']))
if "$x_init_driver_type_flags_t" == mtypename:
_append(rets, "$X_RESULT_ERROR_INVALID_ENUMERATION", "`%s == %s->%s`"%('0x0', item['name'], m['name']))
else:
_append(rets, "$X_RESULT_ERROR_INVALID_ENUMERATION", "`%s < %s->%s`"%(meta['enum'][mtypename]['max'], item['name'], m['name']))

elif type_traits.is_properties(item['type']):
# walk each entry in the properties
Expand Down

0 comments on commit 574b199

Please sign in to comment.