Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
kernel_linux
提交
10fc139f
K
kernel_linux
项目概览
OpenHarmony
/
kernel_linux
上一次同步 4 年多
通知
15
Star
8
Fork
2
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
kernel_linux
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
10fc139f
编写于
7月 04, 2017
作者:
B
Bjorn Helgaas
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'pci/host-versatile' into next
* pci/host-versatile: PCI: versatile: Add local struct device pointers
上级
1fb3d7d5
7d630aaa
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
9 addition
and
9 deletion
+9
-9
drivers/pci/host/pci-versatile.c
drivers/pci/host/pci-versatile.c
+9
-9
未找到文件。
drivers/pci/host/pci-versatile.c
浏览文件 @
10fc139f
...
...
@@ -120,6 +120,7 @@ static int versatile_pci_parse_request_of_pci_ranges(struct device *dev,
static
int
versatile_pci_probe
(
struct
platform_device
*
pdev
)
{
struct
device
*
dev
=
&
pdev
->
dev
;
struct
resource
*
res
;
int
ret
,
i
,
myslot
=
-
1
;
u32
val
;
...
...
@@ -128,27 +129,26 @@ static int versatile_pci_probe(struct platform_device *pdev)
struct
pci_host_bridge
*
bridge
;
LIST_HEAD
(
pci_res
);
bridge
=
devm_pci_alloc_host_bridge
(
&
pdev
->
dev
,
0
);
bridge
=
devm_pci_alloc_host_bridge
(
dev
,
0
);
if
(
!
bridge
)
return
-
ENOMEM
;
res
=
platform_get_resource
(
pdev
,
IORESOURCE_MEM
,
0
);
versatile_pci_base
=
devm_ioremap_resource
(
&
pdev
->
dev
,
res
);
versatile_pci_base
=
devm_ioremap_resource
(
dev
,
res
);
if
(
IS_ERR
(
versatile_pci_base
))
return
PTR_ERR
(
versatile_pci_base
);
res
=
platform_get_resource
(
pdev
,
IORESOURCE_MEM
,
1
);
versatile_cfg_base
[
0
]
=
devm_ioremap_resource
(
&
pdev
->
dev
,
res
);
versatile_cfg_base
[
0
]
=
devm_ioremap_resource
(
dev
,
res
);
if
(
IS_ERR
(
versatile_cfg_base
[
0
]))
return
PTR_ERR
(
versatile_cfg_base
[
0
]);
res
=
platform_get_resource
(
pdev
,
IORESOURCE_MEM
,
2
);
versatile_cfg_base
[
1
]
=
devm_pci_remap_cfg_resource
(
&
pdev
->
dev
,
res
);
versatile_cfg_base
[
1
]
=
devm_pci_remap_cfg_resource
(
dev
,
res
);
if
(
IS_ERR
(
versatile_cfg_base
[
1
]))
return
PTR_ERR
(
versatile_cfg_base
[
1
]);
ret
=
versatile_pci_parse_request_of_pci_ranges
(
&
pdev
->
dev
,
&
pci_res
);
ret
=
versatile_pci_parse_request_of_pci_ranges
(
dev
,
&
pci_res
);
if
(
ret
)
return
ret
;
...
...
@@ -164,7 +164,7 @@ static int versatile_pci_probe(struct platform_device *pdev)
}
}
if
(
myslot
==
-
1
)
{
dev_err
(
&
pdev
->
dev
,
"Cannot find PCI core!
\n
"
);
dev_err
(
dev
,
"Cannot find PCI core!
\n
"
);
return
-
EIO
;
}
/*
...
...
@@ -172,7 +172,7 @@ static int versatile_pci_probe(struct platform_device *pdev)
*/
pci_slot_ignore
|=
(
1
<<
myslot
);
dev_info
(
&
pdev
->
dev
,
"PCI core found (slot %d)
\n
"
,
myslot
);
dev_info
(
dev
,
"PCI core found (slot %d)
\n
"
,
myslot
);
writel
(
myslot
,
PCI_SELFID
);
local_pci_cfg_base
=
versatile_cfg_base
[
1
]
+
(
myslot
<<
11
);
...
...
@@ -205,7 +205,7 @@ static int versatile_pci_probe(struct platform_device *pdev)
pci_add_flags
(
PCI_REASSIGN_ALL_BUS
|
PCI_REASSIGN_ALL_RSRC
);
list_splice_init
(
&
pci_res
,
&
bridge
->
windows
);
bridge
->
dev
.
parent
=
&
pdev
->
dev
;
bridge
->
dev
.
parent
=
dev
;
bridge
->
sysdata
=
NULL
;
bridge
->
busnr
=
0
;
bridge
->
ops
=
&
pci_versatile_ops
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录