Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
kernel_linux
提交
4729d773
K
kernel_linux
项目概览
OpenHarmony
/
kernel_linux
上一次同步 3 年多
通知
13
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看板
提交
4729d773
编写于
10月 08, 2014
作者:
J
Jesper Nilsson
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
CRISv32: Implement early console
Signed-off-by:
N
Jesper Nilsson
<
jesper.nilsson@axis.com
>
上级
421d0852
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
56 addition
and
26 deletion
+56
-26
arch/cris/arch-v32/kernel/debugport.c
arch/cris/arch-v32/kernel/debugport.c
+56
-26
未找到文件。
arch/cris/arch-v32/kernel/debugport.c
浏览文件 @
4729d773
...
...
@@ -3,7 +3,9 @@
*/
#include <linux/console.h>
#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/string.h>
#include <hwregs/reg_rdwr.h>
#include <hwregs/reg_map.h>
#include <hwregs/ser_defs.h>
...
...
@@ -65,6 +67,7 @@ struct dbg_port ports[] =
},
#endif
};
static
struct
dbg_port
*
port
=
#if defined(CONFIG_ETRAX_DEBUG_PORT0)
&
ports
[
0
];
...
...
@@ -97,14 +100,19 @@ static struct dbg_port *kgdb_port =
#endif
#endif
static
void
start_port
(
struct
dbg_port
*
p
)
static
void
start_port
(
struct
dbg_port
*
p
)
{
if
(
!
p
)
return
;
/* Set up serial port registers */
reg_ser_rw_tr_ctrl
tr_ctrl
=
{
0
};
reg_ser_rw_tr_dma_en
tr_dma_en
=
{
0
};
if
(
p
->
started
)
reg_ser_rw_rec_ctrl
rec_ctrl
=
{
0
};
reg_ser_rw_tr_baud_div
tr_baud_div
=
{
0
};
reg_ser_rw_rec_baud_div
rec_baud_div
=
{
0
};
if
(
!
p
||
p
->
started
)
return
;
p
->
started
=
1
;
if
(
p
->
nbr
==
1
)
...
...
@@ -118,36 +126,24 @@ start_port(struct dbg_port* p)
crisv32_pinmux_alloc_fixed
(
pinmux_ser4
);
#endif
/* Set up serial port registers */
reg_ser_rw_tr_ctrl
tr_ctrl
=
{
0
};
reg_ser_rw_tr_dma_en
tr_dma_en
=
{
0
};
reg_ser_rw_rec_ctrl
rec_ctrl
=
{
0
};
reg_ser_rw_tr_baud_div
tr_baud_div
=
{
0
};
reg_ser_rw_rec_baud_div
rec_baud_div
=
{
0
};
tr_ctrl
.
base_freq
=
rec_ctrl
.
base_freq
=
regk_ser_f29_493
;
tr_dma_en
.
en
=
rec_ctrl
.
dma_mode
=
regk_ser_no
;
tr_baud_div
.
div
=
rec_baud_div
.
div
=
29493000
/
p
->
baudrate
/
8
;
tr_ctrl
.
en
=
rec_ctrl
.
en
=
1
;
if
(
p
->
parity
==
'O'
)
{
if
(
p
->
parity
==
'O'
)
{
tr_ctrl
.
par_en
=
regk_ser_yes
;
tr_ctrl
.
par
=
regk_ser_odd
;
rec_ctrl
.
par_en
=
regk_ser_yes
;
rec_ctrl
.
par
=
regk_ser_odd
;
}
else
if
(
p
->
parity
==
'E'
)
{
}
else
if
(
p
->
parity
==
'E'
)
{
tr_ctrl
.
par_en
=
regk_ser_yes
;
tr_ctrl
.
par
=
regk_ser_even
;
rec_ctrl
.
par_en
=
regk_ser_yes
;
rec_ctrl
.
par
=
regk_ser_odd
;
}
if
(
p
->
bits
==
7
)
{
if
(
p
->
bits
==
7
)
{
tr_ctrl
.
data_bits
=
regk_ser_bits7
;
rec_ctrl
.
data_bits
=
regk_ser_bits7
;
}
...
...
@@ -161,8 +157,7 @@ start_port(struct dbg_port* p)
#ifdef CONFIG_ETRAX_KGDB
/* Use polling to get a single character from the kernel debug port */
int
getDebugChar
(
void
)
int
getDebugChar
(
void
)
{
reg_ser_rs_stat_din
stat
;
reg_ser_rw_ack_intr
ack_intr
=
{
0
};
...
...
@@ -179,8 +174,7 @@ getDebugChar(void)
}
/* Use polling to put a single character to the kernel debug port */
void
putDebugChar
(
int
val
)
void
putDebugChar
(
int
val
)
{
reg_ser_r_stat_din
stat
;
do
{
...
...
@@ -190,12 +184,48 @@ putDebugChar(int val)
}
#endif
/* CONFIG_ETRAX_KGDB */
static
void
__init
early_putch
(
int
c
)
{
reg_ser_r_stat_din
stat
;
/* Wait until transmitter is ready and send. */
do
stat
=
REG_RD
(
ser
,
port
->
instance
,
r_stat_din
);
while
(
!
stat
.
tr_rdy
);
REG_WR_INT
(
ser
,
port
->
instance
,
rw_dout
,
c
);
}
static
void
__init
early_console_write
(
struct
console
*
con
,
const
char
*
s
,
unsigned
n
)
{
extern
void
reset_watchdog
(
void
);
int
i
;
/* Send data. */
for
(
i
=
0
;
i
<
n
;
i
++
)
{
/* TODO: the '\n' -> '\n\r' translation should be done at the
receiver. Remove it when the serial driver removes it. */
if
(
s
[
i
]
==
'\n'
)
early_putch
(
'\r'
);
early_putch
(
s
[
i
]);
reset_watchdog
();
}
}
static
struct
console
early_console_dev
__initdata
=
{
.
name
=
"early"
,
.
write
=
early_console_write
,
.
flags
=
CON_PRINTBUFFER
|
CON_BOOT
,
.
index
=
-
1
};
/* Register console for printk's, etc. */
int
__init
init_etrax_debug
(
void
)
int
__init
init_etrax_debug
(
void
)
{
start_port
(
port
);
/* Register an early console if a debug port was chosen. */
register_console
(
&
early_console_dev
);
#ifdef CONFIG_ETRAX_KGDB
start_port
(
kgdb_port
);
#endif
/* CONFIG_ETRAX_KGDB */
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录