挖坑网/填坑网 DebugDump Forum

别人挖坑默默填上,自己挖坑含泪填上。天下没有填不了的坑,只有不会填坑的人。来吧,加入我们,挖坑行,填坑你更行! 站长QQ: 516333132 点击这里给我发消息

您尚未登录。

#1 2018-05-12 14:37:02

晕哥
Administrator
注册时间: 1970-01-01
累计发帖: 2,505

终于把V3s三个串口全部榨干, 控制台只能用 ssh 了, 泪崩

终于把V3s三个串口全部榨干, 控制台只能用 ssh 了, 泪崩

蓝牙,通讯, 加密芯片各用一个

离线

#2 2018-05-12 14:45:02

晕哥
Administrator
注册时间: 1970-01-01
累计发帖: 2,505

Re: 终于把V3s三个串口全部榨干, 控制台只能用 ssh 了, 泪崩

一开始默认控制台是 ttyS0,
我在u-boot里面手动把控制台设置成一个不存在的 ttySx,
但是程序死活起不动,
由于没有了控制台,
也不知道什么原因卡死,
又没有其他合适的调试办法。

离线

#3 2018-05-12 16:21:58

晕哥
Administrator
注册时间: 1970-01-01
累计发帖: 2,505

Re: 终于把V3s三个串口全部榨干, 控制台只能用 ssh 了, 泪崩

后来我去 V3s 的u-boot sun8i 改成这样:

#define CONFIG_BOOTARGS      "console=ttyS1,115200  ......"

把Linux的控制台改为 ttyS1, 接上电脑串口, 发现一旦程序 open("/dev/ttyS0"), 控制台就再也不受控制了。

再发现  echo xxxxxxxxxxx > /dev/ttyS0 直接输出到控制台,
这样就不太符合逻辑了, 因为当前的控制台已经是 ttyS1 了。

离线

#4 2018-05-12 16:25:01

晕哥
Administrator
注册时间: 1970-01-01
累计发帖: 2,505

Re: 终于把V3s三个串口全部榨干, 控制台只能用 ssh 了, 泪崩

继续折腾, 现在把网卡的座子焊起,把 dropbear sshd服务器运行起来,
ssh登录到V3s Linux,

发现应用程序的log是这样:

[error]open serial port /dev/ttyS0 failure ...

接着我直接输出到 /dev/ttyS0:

# echo 00000000000 > /dev/ttyS0
-sh: can't create /dev/ttyS0: No such device

接着我有一个大胆的想法,看看设备节点号:

# ls /dev/ttyS* /dev/console  -l
crw-rw----    1 root     root        5,   1 May 11 09:36 /dev/console
crw-rw----    1 root     root        5,   1 May 11 09:36 /dev/ttyS0
crw-rw----    1 root     root        4,  65 May 12 14:57 /dev/ttyS1
crw-rw----    1 root     root        4,  66 May 12 14:57 /dev/ttyS2
crw-rw----    1 root     root        4,  67 May 12 14:38 /dev/ttyS3
crw-rw----    1 root     root        4,  68 May 12 14:38 /dev/ttyS4
crw-rw----    1 root     root        4,  69 May 12 14:38 /dev/ttyS5
crw-rw----    1 root     root        4,  70 May 12 14:38 /dev/ttyS6
crw-rw----    1 root     root        4,  71 May 12 14:38 /dev/ttyS7

离线

#5 2018-05-12 16:27:58

晕哥
Administrator
注册时间: 1970-01-01
累计发帖: 2,505

Re: 终于把V3s三个串口全部榨干, 控制台只能用 ssh 了, 泪崩

列位是不是看出来了 /dev/ttyS0 与 其他 /dev/ttyS* 设备号有很大的区别?

离线

#6 2018-05-12 16:29:03

晕哥
Administrator
注册时间: 1970-01-01
累计发帖: 2,505

Re: 终于把V3s三个串口全部榨干, 控制台只能用 ssh 了, 泪崩

问题就出在这里了, 在根文件系统里面把 /dev/ttyS0 的节点改为 4, 64
现在三个串口已经愉快的一起玩耍了。

离线

#7 2018-05-12 16:47:56

晕哥
Administrator
注册时间: 1970-01-01
累计发帖: 2,505

Re: 终于把V3s三个串口全部榨干, 控制台只能用 ssh 了, 泪崩

关于如何编译 dropbear 这个使用 buildroot menuconfig 找到这个软件包开启即可,
然后眼力不好找不到,可以直接打开 .config 文件编辑即可。

使用方法可以参考这个:
https://blog.csdn.net/hai__yun/article/details/77966315

使用步骤:

[root@A ~]# mkdir /etc/dropbear                #创建存放密钥目录
[root@A ~]# dropbearkey -t rsa -f /etc/dropbear/dropbear_rsa_host_key -s 2048  #使用rsa算法生成2048位的密钥
[root@A ~]# dropbearkey -t dss -f /etc/dropbear/dropbear_dsa_host_key  #使用dss算法生成密钥
[root@A ~]# dropbear -p :2222 -F -E            #在前台启动dropbear端口位2222
[root@B ~]# ssh 192.168.8.128 -p 2222      #使用B去连A可以链接

离线

#8 2018-06-04 11:27:18

木子猫
会员
注册时间: 2018-03-27
累计发帖: 6

Re: 终于把V3s三个串口全部榨干, 控制台只能用 ssh 了, 泪崩

改串口要改哪些东西呢 改了dts dtsi,sun8i文件,不行呢

离线

#9 2018-06-04 11:38:54

晕哥
Administrator
注册时间: 1970-01-01
累计发帖: 2,505

Re: 终于把V3s三个串口全部榨干, 控制台只能用 ssh 了, 泪崩

改dts就可以了。

离线

#10 2018-06-05 14:56:55

木子猫
会员
注册时间: 2018-03-27
累计发帖: 6

Re: 终于把V3s三个串口全部榨干, 控制台只能用 ssh 了, 泪崩

改这句吗  stdout-path = "serial0:115200n8";

离线

#11 2018-06-05 15:08:22

晕哥
Administrator
注册时间: 1970-01-01
累计发帖: 2,505

Re: 终于把V3s三个串口全部榨干, 控制台只能用 ssh 了, 泪崩

sun8i-v3s.dtsi 文件:

uart0_pins_a: uart0@0 {
                pins = "PB8", "PB9";
                function = "uart0";
            };

            uart1_pins_a: uart1@0 {
                pins = "PE21", "PE22";
                function = "uart1";
                bias-pull-up;
            };

            uart2_pins_a: uart2@0 {
                pins = "PB0", "PB1";
                function = "uart2";
                bias-pull-up;
            };

sun8i-v3s-licheepi-zero.dts 文件:

&uart0 {
    pinctrl-0 = <&uart0_pins_a>;
    pinctrl-names = "default";
    status = "okay";
};

&uart1 {
    pinctrl-0 = <&uart1_pins_a>;
    pinctrl-names = "default";
    status = "okay";
};

&uart2 {
    pinctrl-0 = <&uart2_pins_a>;
    pinctrl-names = "default";
    status = "okay";
};

改上面两个文件.

离线

#12 2018-06-05 23:47:33

木子猫
会员
注册时间: 2018-03-27
累计发帖: 6

Re: 终于把V3s三个串口全部榨干, 控制台只能用 ssh 了, 泪崩

再请教一下 比如uart2作为终端输出 还需要改哪里

离线

#13 2018-06-06 08:05:49

晕哥
Administrator
注册时间: 1970-01-01
累计发帖: 2,505

Re: 终于把V3s三个串口全部榨干, 控制台只能用 ssh 了, 泪崩

木子猫 说:

再请教一下 比如uart2作为终端输出 还需要改哪里

有两个办法:
1. 在u-boot命令行修改 bootargs 参数
2. 修改 u-boot源码 include/configs/sun8i.h 改成这样

#define CONFIG_BOOTARGS      "console=ttyS1,115200  ......"

离线

页脚