|
|
|
#![allow(unused_imports)]
|
|
|
|
|
|
|
|
use gpu::i915::GemHandle;
|
|
|
|
use intel_gpu::*;
|
|
|
|
use uapi::i915::{self, DrmGemHandle};
|
|
|
|
use std::fs;
|
|
|
|
use std::{fs::File, os::fd::{AsRawFd, RawFd}};
|
|
|
|
use std::thread;
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_i915_uapi_get_version() {
|
|
|
|
let node = i915::find_node().expect("Failed to find i915 fd");
|
|
|
|
let drm_version = uapi::get_drm_version(node.fd.as_raw_fd()).expect("Failed to get drm version");
|
|
|
|
assert_eq!(drm_version.name.to_str().unwrap(), "i915");
|
|
|
|
assert_eq!(drm_version.desc.to_str().unwrap(), "Intel Graphics");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_i915_uapi_get_engines() {
|
|
|
|
let node = i915::find_node().expect("Failed to find i915 fd");
|
|
|
|
let _engines = i915::get_engines(node.fd.as_raw_fd()).expect("Failed to get engines");
|
|
|
|
let fail_fd = File::open("/dev/null").expect("Failed to open /dev/null");
|
|
|
|
assert!(i915::get_engines(fail_fd.as_raw_fd()).is_none());
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_i915_uapi_get_param_fail() {
|
|
|
|
let fd = File::open("/dev/null").expect("Failed to open /dev/null");
|
|
|
|
let param = i915::get_param(fd.as_raw_fd(), native::I915_PARAM_CHIPSET_ID as i32);
|
|
|
|
assert!(param.is_none());
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_i915_uapi_native_engine_info() {
|
|
|
|
let node = i915::find_node().expect("Failed to find i915 fd");
|
|
|
|
let engines = i915::get_engines(node.fd.as_raw_fd()).expect("Failed to get engines");
|
|
|
|
for engine in engines {
|
|
|
|
let native_engine = engine.to_native();
|
|
|
|
let from_native = i915::EngineInfo::from_native(native_engine);
|
|
|
|
assert_eq!(&engine, &from_native);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_i915_uapi_find_fd() {
|
|
|
|
let fd = i915::find_fd().expect("Failed to find i915 fd");
|
|
|
|
let drm_version = uapi::get_drm_version(fd.as_raw_fd()).expect("Failed to get drm version");
|
|
|
|
assert_eq!(drm_version.name.to_str().unwrap(), "i915");
|
|
|
|
assert_eq!(drm_version.desc.to_str().unwrap(), "Intel Graphics");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_i915_uapi_get_context_param() {
|
|
|
|
let node = i915::find_node().expect("Failed to find i915 fd");
|
|
|
|
// Mesa uses context id of 0 for init so it's surely okay, right?
|
|
|
|
let param = i915::get_context_param(node.fd.as_raw_fd(),
|
|
|
|
0,
|
|
|
|
native::I915_CONTEXT_PARAM_GTT_SIZE as u32)
|
|
|
|
.expect("Failed to get context param");
|
|
|
|
assert!(param > 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_i915_uapi_gem_lifecycle() {
|
|
|
|
let node = i915::find_node().expect("Failed to find i915 fd");
|
|
|
|
let gem = i915::make_gem(node.fd.as_raw_fd(), 4096).expect("Failed to make gem");
|
|
|
|
assert!(gem.handle > 0);
|
|
|
|
assert!(i915::gem_is_valid(node.fd.as_raw_fd(), &gem).unwrap());
|
|
|
|
let tmp = i915::DrmGemHandle { handle: gem.handle };
|
|
|
|
i915::close_gem(node.fd.as_raw_fd(), tmp).expect("Failed to close gem");
|
|
|
|
assert!(!i915::gem_is_valid(node.fd.as_raw_fd(), &gem).unwrap());
|
|
|
|
let invalid_fd = File::open("/dev/null").expect("Failed to open /dev/null");
|
|
|
|
assert!(i915::make_gem(invalid_fd.as_raw_fd(), 4096).is_none());
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_i915_uapi_gem_tiling() {
|
|
|
|
let node = i915::find_node().expect("Failed to find i915 fd");
|
|
|
|
let gem = i915::make_gem(node.fd.as_raw_fd(), 4096).expect("Failed to make gem");
|
|
|
|
// TODO figure out which devices this holds for
|
|
|
|
assert!(i915::gem_has_tiling(node.fd.as_raw_fd(), &gem).is_ok_and(|e| e == true));
|
|
|
|
i915::close_gem(node.fd.as_raw_fd(), gem).expect("Failed to close gem");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_i915_uapi_gem_caching() {
|
|
|
|
let node = i915::find_node().expect("Failed to find i915 fd");
|
|
|
|
let gem = i915::make_gem(node.fd.as_raw_fd(), 4096).expect("Failed to make gem");
|
|
|
|
let caching = i915::gem_get_caching(node.fd.as_raw_fd(), &gem).expect("Failed to get caching");
|
|
|
|
assert!(caching > 0);
|
|
|
|
i915::close_gem(node.fd.as_raw_fd(), gem).expect("Failed to close gem");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_i915_uapi_gem_thread() {
|
|
|
|
let node = i915::find_node().expect("Failed to find i915 fd");
|
|
|
|
let gem = i915::make_gem(node.fd.as_raw_fd(), 4096).expect("Failed to make gem");
|
|
|
|
thread::scope(|s| {
|
|
|
|
let handle = s.spawn(|| {
|
|
|
|
assert!(i915::gem_is_valid(node.fd.as_raw_fd(), &gem).unwrap());
|
|
|
|
});
|
|
|
|
assert!(i915::gem_is_valid(node.fd.as_raw_fd(), &gem).unwrap());
|
|
|
|
handle.join().expect("Failed to join thread");
|
|
|
|
});
|
|
|
|
}
|