Skip to content

Commit

Permalink
Move versions.jl to Metal module.
Browse files Browse the repository at this point in the history
Add docstrings
  • Loading branch information
christiangnrd committed Jul 18, 2024
1 parent 071d6d8 commit 53be9fe
Show file tree
Hide file tree
Showing 5 changed files with 49 additions and 7 deletions.
8 changes: 8 additions & 0 deletions docs/src/api/essentials.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,13 @@
# Essentials

## Versions and Support
```@docs
macos_version
Metal.darwin_version
Metal.metal_support
Metal.metallib_support
Metal.air_support
```

## Global State

Expand Down
3 changes: 2 additions & 1 deletion lib/mtl/MTL.jl
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,8 @@ module MTL
using CEnum
using ObjectiveC, .Foundation, .Dispatch

using ..Metal

# Metal APIs generally expect to be running under an autorelease pool.
# In most cases, we handle this in the code calling into the MTL module,
# however, finalizers are out of the caller's control, so we need to
Expand All @@ -20,7 +22,6 @@ release(obj) = @autoreleasepool unsafe=true Foundation.release(obj)

## source code includes

include("version.jl")
include("size.jl")
include("device.jl")
include("resource.jl")
Expand Down
2 changes: 2 additions & 0 deletions src/Metal.jl
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,8 @@ using ExprTools: splitdef, combinedef
using Artifacts
using ObjectiveC, .CoreFoundation, .Foundation, .Dispatch, .OS

include("version.jl")

# core library
include("../lib/mtl/MTL.jl")
using .MTL
Expand Down
40 changes: 36 additions & 4 deletions lib/mtl/version.jl → src/version.jl
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# version and support queries

export darwin_version, macos_version, metallib_support, air_support, metal_support
export macos_version

@noinline function _syscall_version(name)
size = Ref{Csize_t}()
Expand All @@ -18,6 +18,13 @@ export darwin_version, macos_version, metallib_support, air_support, metal_suppo
end

const _darwin_version = Ref{VersionNumber}()
"""
Metal.darwin_version() -> VersionNumber
Returns the host Darwin kernel version.
See also [`macos_version`](@ref).
"""
function darwin_version()
if !isassigned(_darwin_version)
_darwin_version[] = _syscall_version("kern.osrelease")
Expand All @@ -26,6 +33,13 @@ function darwin_version()
end

const _macos_version = Ref{VersionNumber}()
"""
macos_version() -> VersionNumber
Returns the host macOS version.
See also [`Metal.darwin_version`](@ref).
"""
function macos_version()
if !isassigned(_macos_version)
_macos_version[] = _syscall_version("kern.osproductversion")
Expand All @@ -46,7 +60,13 @@ end
# - metal support: last 2 bytes of the VERS tag in the function list,
# or air.language_version in the embedded bitcode

# support for the metallib file format
"""
Metal.metallib_support() -> VersionNumber
Returns the highest supported version for the metallib file format.
See also [`Metal.air_support`](@ref) and [`Metal.metal_support`](@ref).
"""
function metallib_support()
macos = macos_version()
if macos >= v"15"
Expand All @@ -68,7 +88,13 @@ function metallib_support()
end
end

# support for the embedded AIR bitcode format
"""
Metal.air_support() -> VersionNumber
Returns the highest supported version for the embedded AIR bitcode format.
See also [`Metal.metallib_support`](@ref) and [`Metal.metal_support`](@ref).
"""
function air_support()
macos = macos_version()
if macos >= v"15"
Expand All @@ -92,7 +118,13 @@ function air_support()
end
end

# support for the Metal language
"""
Metal.metal_support() -> VersionNumber
Returns the highest supported version for the Metal Shading Language.
See also [`Metal.metallib_support`](@ref) and [`Metal.air_support`](@ref).
"""
function metal_support()
macos = macos_version()
if macos >= v"15"
Expand Down
3 changes: 1 addition & 2 deletions test/execution.jl
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
using Metal: macos_version, MTLCommandQueue

dummy() = return

Expand Down Expand Up @@ -143,7 +142,7 @@ end
vecA .= 0

dev = device()
queue = MTLCommandQueue(dev)
queue = MTL.MTLCommandQueue(dev)
@metal threads=(3) queue=queue tester(bufferA)
synchronize(queue)
@test all(vecA == Int.([5, 5, 5, 0, 0, 0, 0, 0]))
Expand Down

0 comments on commit 53be9fe

Please sign in to comment.