Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
27abc13e
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
161
Star
36
Fork
7
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
10
列表
看板
标记
里程碑
合并请求
2
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
cloud-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
10
Issue
10
列表
看板
标记
里程碑
合并请求
2
合并请求
2
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
27abc13e
编写于
11月 22, 2012
作者:
B
Ben Skeggs
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/nv98/crypt: use nouveau_falcon base class
Signed-off-by:
N
Ben Skeggs
<
bskeggs@redhat.com
>
上级
e3aaa946
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
35 addition
and
95 deletion
+35
-95
drivers/gpu/drm/nouveau/core/engine/crypt/nv84.c
drivers/gpu/drm/nouveau/core/engine/crypt/nv84.c
+14
-13
drivers/gpu/drm/nouveau/core/engine/crypt/nv98.c
drivers/gpu/drm/nouveau/core/engine/crypt/nv98.c
+21
-43
drivers/gpu/drm/nouveau/core/include/engine/crypt.h
drivers/gpu/drm/nouveau/core/include/engine/crypt.h
+0
-39
未找到文件。
drivers/gpu/drm/nouveau/core/engine/crypt/nv84.c
浏览文件 @
27abc13e
...
@@ -34,11 +34,11 @@
...
@@ -34,11 +34,11 @@
#include <engine/crypt.h>
#include <engine/crypt.h>
struct
nv84_crypt_priv
{
struct
nv84_crypt_priv
{
struct
nouveau_
crypt
base
;
struct
nouveau_
engine
base
;
};
};
struct
nv84_crypt_chan
{
struct
nv84_crypt_chan
{
struct
nouveau_
crypt_chan
base
;
struct
nouveau_
engctx
base
;
};
};
/*******************************************************************************
/*******************************************************************************
...
@@ -96,8 +96,8 @@ nv84_crypt_context_ctor(struct nouveau_object *parent,
...
@@ -96,8 +96,8 @@ nv84_crypt_context_ctor(struct nouveau_object *parent,
struct
nv84_crypt_chan
*
priv
;
struct
nv84_crypt_chan
*
priv
;
int
ret
;
int
ret
;
ret
=
nouveau_
crypt_context
_create
(
parent
,
engine
,
oclass
,
NULL
,
256
,
ret
=
nouveau_
engctx
_create
(
parent
,
engine
,
oclass
,
NULL
,
256
,
0
,
NVOBJ_FLAG_ZERO_ALLOC
,
&
priv
);
0
,
NVOBJ_FLAG_ZERO_ALLOC
,
&
priv
);
*
pobject
=
nv_object
(
priv
);
*
pobject
=
nv_object
(
priv
);
if
(
ret
)
if
(
ret
)
return
ret
;
return
ret
;
...
@@ -110,11 +110,11 @@ nv84_crypt_cclass = {
...
@@ -110,11 +110,11 @@ nv84_crypt_cclass = {
.
handle
=
NV_ENGCTX
(
CRYPT
,
0x84
),
.
handle
=
NV_ENGCTX
(
CRYPT
,
0x84
),
.
ofuncs
=
&
(
struct
nouveau_ofuncs
)
{
.
ofuncs
=
&
(
struct
nouveau_ofuncs
)
{
.
ctor
=
nv84_crypt_context_ctor
,
.
ctor
=
nv84_crypt_context_ctor
,
.
dtor
=
_nouveau_
crypt_context
_dtor
,
.
dtor
=
_nouveau_
engctx
_dtor
,
.
init
=
_nouveau_
crypt_context
_init
,
.
init
=
_nouveau_
engctx
_init
,
.
fini
=
_nouveau_
crypt_context
_fini
,
.
fini
=
_nouveau_
engctx
_fini
,
.
rd32
=
_nouveau_
crypt_context
_rd32
,
.
rd32
=
_nouveau_
engctx
_rd32
,
.
wr32
=
_nouveau_
crypt_context
_wr32
,
.
wr32
=
_nouveau_
engctx
_wr32
,
},
},
};
};
...
@@ -176,7 +176,8 @@ nv84_crypt_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
...
@@ -176,7 +176,8 @@ nv84_crypt_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
struct
nv84_crypt_priv
*
priv
;
struct
nv84_crypt_priv
*
priv
;
int
ret
;
int
ret
;
ret
=
nouveau_crypt_create
(
parent
,
engine
,
oclass
,
&
priv
);
ret
=
nouveau_engine_create
(
parent
,
engine
,
oclass
,
true
,
"PCRYPT"
,
"crypt"
,
&
priv
);
*
pobject
=
nv_object
(
priv
);
*
pobject
=
nv_object
(
priv
);
if
(
ret
)
if
(
ret
)
return
ret
;
return
ret
;
...
@@ -195,7 +196,7 @@ nv84_crypt_init(struct nouveau_object *object)
...
@@ -195,7 +196,7 @@ nv84_crypt_init(struct nouveau_object *object)
struct
nv84_crypt_priv
*
priv
=
(
void
*
)
object
;
struct
nv84_crypt_priv
*
priv
=
(
void
*
)
object
;
int
ret
;
int
ret
;
ret
=
nouveau_
crypt
_init
(
&
priv
->
base
);
ret
=
nouveau_
engine
_init
(
&
priv
->
base
);
if
(
ret
)
if
(
ret
)
return
ret
;
return
ret
;
...
@@ -210,8 +211,8 @@ nv84_crypt_oclass = {
...
@@ -210,8 +211,8 @@ nv84_crypt_oclass = {
.
handle
=
NV_ENGINE
(
CRYPT
,
0x84
),
.
handle
=
NV_ENGINE
(
CRYPT
,
0x84
),
.
ofuncs
=
&
(
struct
nouveau_ofuncs
)
{
.
ofuncs
=
&
(
struct
nouveau_ofuncs
)
{
.
ctor
=
nv84_crypt_ctor
,
.
ctor
=
nv84_crypt_ctor
,
.
dtor
=
_nouveau_
crypt
_dtor
,
.
dtor
=
_nouveau_
engine
_dtor
,
.
init
=
nv84_crypt_init
,
.
init
=
nv84_crypt_init
,
.
fini
=
_nouveau_
crypt
_fini
,
.
fini
=
_nouveau_
engine
_fini
,
},
},
};
};
drivers/gpu/drm/nouveau/core/engine/crypt/nv98.c
浏览文件 @
27abc13e
...
@@ -26,6 +26,7 @@
...
@@ -26,6 +26,7 @@
#include <core/enum.h>
#include <core/enum.h>
#include <core/class.h>
#include <core/class.h>
#include <core/engctx.h>
#include <core/engctx.h>
#include <core/falcon.h>
#include <subdev/timer.h>
#include <subdev/timer.h>
#include <subdev/fb.h>
#include <subdev/fb.h>
...
@@ -36,11 +37,11 @@
...
@@ -36,11 +37,11 @@
#include "fuc/nv98.fuc.h"
#include "fuc/nv98.fuc.h"
struct
nv98_crypt_priv
{
struct
nv98_crypt_priv
{
struct
nouveau_
crypt
base
;
struct
nouveau_
falcon
base
;
};
};
struct
nv98_crypt_chan
{
struct
nv98_crypt_chan
{
struct
nouveau_
crypt
_chan
base
;
struct
nouveau_
falcon
_chan
base
;
};
};
/*******************************************************************************
/*******************************************************************************
...
@@ -66,8 +67,8 @@ nv98_crypt_context_ctor(struct nouveau_object *parent,
...
@@ -66,8 +67,8 @@ nv98_crypt_context_ctor(struct nouveau_object *parent,
struct
nv98_crypt_chan
*
priv
;
struct
nv98_crypt_chan
*
priv
;
int
ret
;
int
ret
;
ret
=
nouveau_
crypt
_context_create
(
parent
,
engine
,
oclass
,
NULL
,
256
,
ret
=
nouveau_
falcon
_context_create
(
parent
,
engine
,
oclass
,
NULL
,
256
,
256
,
NVOBJ_FLAG_ZERO_ALLOC
,
&
priv
);
256
,
NVOBJ_FLAG_ZERO_ALLOC
,
&
priv
);
*
pobject
=
nv_object
(
priv
);
*
pobject
=
nv_object
(
priv
);
if
(
ret
)
if
(
ret
)
return
ret
;
return
ret
;
...
@@ -80,11 +81,11 @@ nv98_crypt_cclass = {
...
@@ -80,11 +81,11 @@ nv98_crypt_cclass = {
.
handle
=
NV_ENGCTX
(
CRYPT
,
0x98
),
.
handle
=
NV_ENGCTX
(
CRYPT
,
0x98
),
.
ofuncs
=
&
(
struct
nouveau_ofuncs
)
{
.
ofuncs
=
&
(
struct
nouveau_ofuncs
)
{
.
ctor
=
nv98_crypt_context_ctor
,
.
ctor
=
nv98_crypt_context_ctor
,
.
dtor
=
_nouveau_
crypt
_context_dtor
,
.
dtor
=
_nouveau_
falcon
_context_dtor
,
.
init
=
_nouveau_
crypt
_context_init
,
.
init
=
_nouveau_
falcon
_context_init
,
.
fini
=
_nouveau_
crypt
_context_fini
,
.
fini
=
_nouveau_
falcon
_context_fini
,
.
rd32
=
_nouveau_
crypt
_context_rd32
,
.
rd32
=
_nouveau_
falcon
_context_rd32
,
.
wr32
=
_nouveau_
crypt
_context_wr32
,
.
wr32
=
_nouveau_
falcon
_context_wr32
,
},
},
};
};
...
@@ -153,7 +154,8 @@ nv98_crypt_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
...
@@ -153,7 +154,8 @@ nv98_crypt_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
struct
nv98_crypt_priv
*
priv
;
struct
nv98_crypt_priv
*
priv
;
int
ret
;
int
ret
;
ret
=
nouveau_crypt_create
(
parent
,
engine
,
oclass
,
&
priv
);
ret
=
nouveau_falcon_create
(
parent
,
engine
,
oclass
,
0x087000
,
true
,
"PCRYPT"
,
"crypt"
,
&
priv
);
*
pobject
=
nv_object
(
priv
);
*
pobject
=
nv_object
(
priv
);
if
(
ret
)
if
(
ret
)
return
ret
;
return
ret
;
...
@@ -163,36 +165,10 @@ nv98_crypt_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
...
@@ -163,36 +165,10 @@ nv98_crypt_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
nv_engine
(
priv
)
->
cclass
=
&
nv98_crypt_cclass
;
nv_engine
(
priv
)
->
cclass
=
&
nv98_crypt_cclass
;
nv_engine
(
priv
)
->
sclass
=
nv98_crypt_sclass
;
nv_engine
(
priv
)
->
sclass
=
nv98_crypt_sclass
;
nv_engine
(
priv
)
->
tlb_flush
=
nv98_crypt_tlb_flush
;
nv_engine
(
priv
)
->
tlb_flush
=
nv98_crypt_tlb_flush
;
return
0
;
nv_falcon
(
priv
)
->
code
.
data
=
nv98_pcrypt_code
;
}
nv_falcon
(
priv
)
->
code
.
size
=
sizeof
(
nv98_pcrypt_code
);
nv_falcon
(
priv
)
->
data
.
data
=
nv98_pcrypt_data
;
static
int
nv_falcon
(
priv
)
->
data
.
size
=
sizeof
(
nv98_pcrypt_data
);
nv98_crypt_init
(
struct
nouveau_object
*
object
)
{
struct
nv98_crypt_priv
*
priv
=
(
void
*
)
object
;
int
ret
,
i
;
ret
=
nouveau_crypt_init
(
&
priv
->
base
);
if
(
ret
)
return
ret
;
/* wait for exit interrupt to signal */
nv_wait
(
priv
,
0x087008
,
0x00000010
,
0x00000010
);
nv_wr32
(
priv
,
0x087004
,
0x00000010
);
/* upload microcode code and data segments */
nv_wr32
(
priv
,
0x087ff8
,
0x00100000
);
for
(
i
=
0
;
i
<
ARRAY_SIZE
(
nv98_pcrypt_code
);
i
++
)
nv_wr32
(
priv
,
0x087ff4
,
nv98_pcrypt_code
[
i
]);
nv_wr32
(
priv
,
0x087ff8
,
0x00000000
);
for
(
i
=
0
;
i
<
ARRAY_SIZE
(
nv98_pcrypt_data
);
i
++
)
nv_wr32
(
priv
,
0x087ff4
,
nv98_pcrypt_data
[
i
]);
/* start it running */
nv_wr32
(
priv
,
0x08710c
,
0x00000000
);
nv_wr32
(
priv
,
0x087104
,
0x00000000
);
/* ENTRY */
nv_wr32
(
priv
,
0x087100
,
0x00000002
);
/* TRIGGER */
return
0
;
return
0
;
}
}
...
@@ -201,8 +177,10 @@ nv98_crypt_oclass = {
...
@@ -201,8 +177,10 @@ nv98_crypt_oclass = {
.
handle
=
NV_ENGINE
(
CRYPT
,
0x98
),
.
handle
=
NV_ENGINE
(
CRYPT
,
0x98
),
.
ofuncs
=
&
(
struct
nouveau_ofuncs
)
{
.
ofuncs
=
&
(
struct
nouveau_ofuncs
)
{
.
ctor
=
nv98_crypt_ctor
,
.
ctor
=
nv98_crypt_ctor
,
.
dtor
=
_nouveau_crypt_dtor
,
.
dtor
=
_nouveau_falcon_dtor
,
.
init
=
nv98_crypt_init
,
.
init
=
_nouveau_falcon_init
,
.
fini
=
_nouveau_crypt_fini
,
.
fini
=
_nouveau_falcon_fini
,
.
rd32
=
_nouveau_falcon_rd32
,
.
wr32
=
_nouveau_falcon_wr32
,
},
},
};
};
drivers/gpu/drm/nouveau/core/include/engine/crypt.h
浏览文件 @
27abc13e
#ifndef __NOUVEAU_CRYPT_H__
#ifndef __NOUVEAU_CRYPT_H__
#define __NOUVEAU_CRYPT_H__
#define __NOUVEAU_CRYPT_H__
#include <core/engine.h>
#include <core/engctx.h>
struct
nouveau_crypt_chan
{
struct
nouveau_engctx
base
;
};
#define nouveau_crypt_context_create(p,e,c,g,s,a,f,d) \
nouveau_engctx_create((p), (e), (c), (g), (s), (a), (f), (d))
#define nouveau_crypt_context_destroy(d) \
nouveau_engctx_destroy(&(d)->base)
#define nouveau_crypt_context_init(d) \
nouveau_engctx_init(&(d)->base)
#define nouveau_crypt_context_fini(d,s) \
nouveau_engctx_fini(&(d)->base, (s))
#define _nouveau_crypt_context_dtor _nouveau_engctx_dtor
#define _nouveau_crypt_context_init _nouveau_engctx_init
#define _nouveau_crypt_context_fini _nouveau_engctx_fini
#define _nouveau_crypt_context_rd32 _nouveau_engctx_rd32
#define _nouveau_crypt_context_wr32 _nouveau_engctx_wr32
struct
nouveau_crypt
{
struct
nouveau_engine
base
;
};
#define nouveau_crypt_create(p,e,c,d) \
nouveau_engine_create((p), (e), (c), true, "PCRYPT", "crypt", (d))
#define nouveau_crypt_destroy(d) \
nouveau_engine_destroy(&(d)->base)
#define nouveau_crypt_init(d) \
nouveau_engine_init(&(d)->base)
#define nouveau_crypt_fini(d,s) \
nouveau_engine_fini(&(d)->base, (s))
#define _nouveau_crypt_dtor _nouveau_engine_dtor
#define _nouveau_crypt_init _nouveau_engine_init
#define _nouveau_crypt_fini _nouveau_engine_fini
extern
struct
nouveau_oclass
nv84_crypt_oclass
;
extern
struct
nouveau_oclass
nv84_crypt_oclass
;
extern
struct
nouveau_oclass
nv98_crypt_oclass
;
extern
struct
nouveau_oclass
nv98_crypt_oclass
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录