Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
e758a311
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
e758a311
编写于
6月 07, 2011
作者:
B
Ben Skeggs
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/nouveau: fixup gem_info ioctl to return client-specific bo virtual
Signed-off-by:
N
Ben Skeggs
<
bskeggs@redhat.com
>
上级
3d483d57
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
20 addition
and
12 deletion
+20
-12
drivers/gpu/drm/nouveau/nouveau_gem.c
drivers/gpu/drm/nouveau/nouveau_gem.c
+20
-12
未找到文件。
drivers/gpu/drm/nouveau/nouveau_gem.c
浏览文件 @
e758a311
...
...
@@ -123,21 +123,28 @@ nouveau_gem_new(struct drm_device *dev, int size, int align, uint32_t domain,
}
static
int
nouveau_gem_info
(
struct
drm_gem_object
*
gem
,
struct
drm_nouveau_gem_info
*
rep
)
nouveau_gem_info
(
struct
drm_file
*
file_priv
,
struct
drm_gem_object
*
gem
,
struct
drm_nouveau_gem_info
*
rep
)
{
struct
drm_nouveau_private
*
dev_priv
=
gem
->
dev
->
dev_private
;
struct
nouveau_fpriv
*
fpriv
=
nouveau_fpriv
(
file_priv
)
;
struct
nouveau_bo
*
nvbo
=
nouveau_gem_object
(
gem
);
struct
nouveau_vma
*
vma
;
if
(
nvbo
->
bo
.
mem
.
mem_type
==
TTM_PL_TT
)
rep
->
domain
=
NOUVEAU_GEM_DOMAIN_GART
;
else
rep
->
domain
=
NOUVEAU_GEM_DOMAIN_VRAM
;
rep
->
offset
=
nvbo
->
bo
.
offset
;
if
(
fpriv
->
vm
)
{
vma
=
nouveau_bo_vma_find
(
nvbo
,
fpriv
->
vm
);
if
(
!
vma
)
return
-
EINVAL
;
rep
->
offset
=
vma
->
offset
;
}
rep
->
size
=
nvbo
->
bo
.
mem
.
num_pages
<<
PAGE_SHIFT
;
if
(
dev_priv
->
card_type
<
NV_50
)
rep
->
offset
=
nvbo
->
bo
.
offset
;
else
rep
->
offset
=
nvbo
->
vma
.
offset
;
rep
->
map_handle
=
nvbo
->
bo
.
addr_space_offset
;
rep
->
tile_mode
=
nvbo
->
tile_mode
;
rep
->
tile_flags
=
nvbo
->
tile_flags
;
...
...
@@ -167,14 +174,15 @@ nouveau_gem_ioctl_new(struct drm_device *dev, void *data,
if
(
ret
)
return
ret
;
ret
=
nouveau_gem_info
(
nvbo
->
gem
,
&
req
->
info
);
if
(
ret
)
goto
out
;
ret
=
drm_gem_handle_create
(
file_priv
,
nvbo
->
gem
,
&
req
->
info
.
handle
);
if
(
ret
==
0
)
{
ret
=
nouveau_gem_info
(
file_priv
,
nvbo
->
gem
,
&
req
->
info
);
if
(
ret
)
drm_gem_handle_delete
(
file_priv
,
req
->
info
.
handle
);
}
/* drop reference from allocate - handle holds it now */
drm_gem_object_unreference_unlocked
(
nvbo
->
gem
);
out:
return
ret
;
}
...
...
@@ -800,7 +808,7 @@ nouveau_gem_ioctl_info(struct drm_device *dev, void *data,
if
(
!
gem
)
return
-
ENOENT
;
ret
=
nouveau_gem_info
(
gem
,
req
);
ret
=
nouveau_gem_info
(
file_priv
,
gem
,
req
);
drm_gem_object_unreference_unlocked
(
gem
);
return
ret
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录