Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
3b6ed4ab
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看板
提交
3b6ed4ab
编写于
12月 25, 2008
作者:
M
Martin Schwidefsky
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[S390] convert setup printks to pr_xxx macros.
Signed-off-by:
N
Martin Schwidefsky
<
schwidefsky@de.ibm.com
>
上级
f55495ba
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
46 addition
and
26 deletion
+46
-26
arch/s390/kernel/setup.c
arch/s390/kernel/setup.c
+46
-26
未找到文件。
arch/s390/kernel/setup.c
浏览文件 @
3b6ed4ab
...
@@ -14,6 +14,9 @@
...
@@ -14,6 +14,9 @@
* This file handles the architecture-dependent parts of initialization
* This file handles the architecture-dependent parts of initialization
*/
*/
#define KMSG_COMPONENT "setup"
#define pr_fmt(fmt) KMSG_COMPONENT ": " fmt
#include <linux/errno.h>
#include <linux/errno.h>
#include <linux/module.h>
#include <linux/module.h>
#include <linux/sched.h>
#include <linux/sched.h>
...
@@ -291,8 +294,8 @@ unsigned int switch_amode = 0;
...
@@ -291,8 +294,8 @@ unsigned int switch_amode = 0;
#endif
#endif
EXPORT_SYMBOL_GPL
(
switch_amode
);
EXPORT_SYMBOL_GPL
(
switch_amode
);
static
void
set_amode_and_uaccess
(
unsigned
long
user_amode
,
static
int
set_amode_and_uaccess
(
unsigned
long
user_amode
,
unsigned
long
user32_amode
)
unsigned
long
user32_amode
)
{
{
psw_user_bits
=
PSW_BASE_BITS
|
PSW_MASK_DAT
|
user_amode
|
psw_user_bits
=
PSW_BASE_BITS
|
PSW_MASK_DAT
|
user_amode
|
PSW_MASK_IO
|
PSW_MASK_EXT
|
PSW_MASK_MCHECK
|
PSW_MASK_IO
|
PSW_MASK_EXT
|
PSW_MASK_MCHECK
|
...
@@ -309,11 +312,11 @@ static void set_amode_and_uaccess(unsigned long user_amode,
...
@@ -309,11 +312,11 @@ static void set_amode_and_uaccess(unsigned long user_amode,
PSW_MASK_MCHECK
|
PSW_DEFAULT_KEY
;
PSW_MASK_MCHECK
|
PSW_DEFAULT_KEY
;
if
(
MACHINE_HAS_MVCOS
)
{
if
(
MACHINE_HAS_MVCOS
)
{
printk
(
"mvcos available.
\n
"
);
memcpy
(
&
uaccess
,
&
uaccess_mvcos_switch
,
sizeof
(
uaccess
));
memcpy
(
&
uaccess
,
&
uaccess_mvcos_switch
,
sizeof
(
uaccess
));
return
1
;
}
else
{
}
else
{
printk
(
"mvcos not available.
\n
"
);
memcpy
(
&
uaccess
,
&
uaccess_pt
,
sizeof
(
uaccess
));
memcpy
(
&
uaccess
,
&
uaccess_pt
,
sizeof
(
uaccess
));
return
0
;
}
}
}
}
...
@@ -328,9 +331,10 @@ static int __init early_parse_switch_amode(char *p)
...
@@ -328,9 +331,10 @@ static int __init early_parse_switch_amode(char *p)
early_param
(
"switch_amode"
,
early_parse_switch_amode
);
early_param
(
"switch_amode"
,
early_parse_switch_amode
);
#else
/* CONFIG_S390_SWITCH_AMODE */
#else
/* CONFIG_S390_SWITCH_AMODE */
static
inline
void
set_amode_and_uaccess
(
unsigned
long
user_amode
,
static
inline
int
set_amode_and_uaccess
(
unsigned
long
user_amode
,
unsigned
long
user32_amode
)
unsigned
long
user32_amode
)
{
{
return
0
;
}
}
#endif
/* CONFIG_S390_SWITCH_AMODE */
#endif
/* CONFIG_S390_SWITCH_AMODE */
...
@@ -355,11 +359,20 @@ early_param("noexec", early_parse_noexec);
...
@@ -355,11 +359,20 @@ early_param("noexec", early_parse_noexec);
static
void
setup_addressing_mode
(
void
)
static
void
setup_addressing_mode
(
void
)
{
{
if
(
s390_noexec
)
{
if
(
s390_noexec
)
{
printk
(
"S390 execute protection active, "
);
if
(
set_amode_and_uaccess
(
PSW_ASC_SECONDARY
,
set_amode_and_uaccess
(
PSW_ASC_SECONDARY
,
PSW32_ASC_SECONDARY
);
PSW32_ASC_SECONDARY
))
pr_info
(
"Execute protection active, "
"mvcos available
\n
"
);
else
pr_info
(
"Execute protection active, "
"mvcos not available
\n
"
);
}
else
if
(
switch_amode
)
{
}
else
if
(
switch_amode
)
{
printk
(
"S390 address spaces switched, "
);
if
(
set_amode_and_uaccess
(
PSW_ASC_PRIMARY
,
PSW32_ASC_PRIMARY
))
set_amode_and_uaccess
(
PSW_ASC_PRIMARY
,
PSW32_ASC_PRIMARY
);
pr_info
(
"Address spaces switched, "
"mvcos available
\n
"
);
else
pr_info
(
"Address spaces switched, "
"mvcos not available
\n
"
);
}
}
#ifdef CONFIG_TRACE_IRQFLAGS
#ifdef CONFIG_TRACE_IRQFLAGS
sysc_restore_trace_psw
.
mask
=
psw_kernel_bits
&
~
PSW_MASK_MCHECK
;
sysc_restore_trace_psw
.
mask
=
psw_kernel_bits
&
~
PSW_MASK_MCHECK
;
...
@@ -572,15 +585,15 @@ setup_memory(void)
...
@@ -572,15 +585,15 @@ setup_memory(void)
start
=
PFN_PHYS
(
start_pfn
)
+
bmap_size
+
PAGE_SIZE
;
start
=
PFN_PHYS
(
start_pfn
)
+
bmap_size
+
PAGE_SIZE
;
if
(
start
+
INITRD_SIZE
>
memory_end
)
{
if
(
start
+
INITRD_SIZE
>
memory_end
)
{
pr
intk
(
"initrd extends beyond end of memory
"
pr
_err
(
"initrd extends beyond end of
"
"
(0x%08lx > 0x%08lx)
\n
"
"
memory (0x%08lx > 0x%08lx)
"
"disabling initrd
\n
"
,
"disabling initrd
\n
"
,
start
+
INITRD_SIZE
,
memory_end
);
start
+
INITRD_SIZE
,
memory_end
);
INITRD_START
=
INITRD_SIZE
=
0
;
INITRD_START
=
INITRD_SIZE
=
0
;
}
else
{
}
else
{
pr
intk
(
"Moving initrd (0x%08lx -> 0x%08lx,
"
pr
_info
(
"Moving initrd (0x%08lx ->
"
"
size: %ld)
\n
"
,
"0x%08lx,
size: %ld)
\n
"
,
INITRD_START
,
start
,
INITRD_SIZE
);
INITRD_START
,
start
,
INITRD_SIZE
);
memmove
((
void
*
)
start
,
(
void
*
)
INITRD_START
,
memmove
((
void
*
)
start
,
(
void
*
)
INITRD_START
,
INITRD_SIZE
);
INITRD_SIZE
);
INITRD_START
=
start
;
INITRD_START
=
start
;
...
@@ -642,8 +655,9 @@ setup_memory(void)
...
@@ -642,8 +655,9 @@ setup_memory(void)
initrd_start
=
INITRD_START
;
initrd_start
=
INITRD_START
;
initrd_end
=
initrd_start
+
INITRD_SIZE
;
initrd_end
=
initrd_start
+
INITRD_SIZE
;
}
else
{
}
else
{
printk
(
"initrd extends beyond end of memory "
pr_err
(
"initrd extends beyond end of "
"(0x%08lx > 0x%08lx)
\n
disabling initrd
\n
"
,
"memory (0x%08lx > 0x%08lx) "
"disabling initrd
\n
"
,
initrd_start
+
INITRD_SIZE
,
memory_end
);
initrd_start
+
INITRD_SIZE
,
memory_end
);
initrd_start
=
initrd_end
=
0
;
initrd_start
=
initrd_end
=
0
;
}
}
...
@@ -747,21 +761,27 @@ setup_arch(char **cmdline_p)
...
@@ -747,21 +761,27 @@ setup_arch(char **cmdline_p)
* print what head.S has found out about the machine
* print what head.S has found out about the machine
*/
*/
#ifndef CONFIG_64BIT
#ifndef CONFIG_64BIT
printk
((
MACHINE_IS_VM
)
?
if
(
MACHINE_IS_VM
)
"We are running under VM (31 bit mode)
\n
"
:
pr_info
(
"Linux is running as a z/VM "
"We are running native (31 bit mode)
\n
"
);
"guest operating system in 31-bit mode
\n
"
);
printk
((
MACHINE_HAS_IEEE
)
?
else
"This machine has an IEEE fpu
\n
"
:
pr_info
(
"Linux is running natively in 31-bit mode
\n
"
);
"This machine has no IEEE fpu
\n
"
);
if
(
MACHINE_HAS_IEEE
)
pr_info
(
"The hardware system has IEEE compatible "
"floating point units
\n
"
);
else
pr_info
(
"The hardware system has no IEEE compatible "
"floating point units
\n
"
);
#else
/* CONFIG_64BIT */
#else
/* CONFIG_64BIT */
if
(
MACHINE_IS_VM
)
if
(
MACHINE_IS_VM
)
printk
(
"We are running under VM (64 bit mode)
\n
"
);
pr_info
(
"Linux is running as a z/VM "
"guest operating system in 64-bit mode
\n
"
);
else
if
(
MACHINE_IS_KVM
)
{
else
if
(
MACHINE_IS_KVM
)
{
pr
intk
(
"We are running under KVM (64 bit mode)
\n
"
);
pr
_info
(
"Linux is running under KVM in 64-bit mode
\n
"
);
add_preferred_console
(
"hvc"
,
0
,
NULL
);
add_preferred_console
(
"hvc"
,
0
,
NULL
);
s390_virtio_console_init
();
s390_virtio_console_init
();
}
else
}
else
pr
intk
(
"We are running native (64 bit mode)
\n
"
);
pr
_info
(
"Linux is running natively in 64-bit mode
\n
"
);
#endif
/* CONFIG_64BIT */
#endif
/* CONFIG_64BIT */
/* Have one command line that is parsed and saved in /proc/cmdline */
/* Have one command line that is parsed and saved in /proc/cmdline */
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录