TQ3568 Buildroot文件系统终端上支持中文显示调试方法

修改busybox配置单  

如果是buildroot 则 make busybox-menuconfig ARCH=arm64

diff --git a/rootfs/buildroot/package/busybox/busybox.config b/rootfs/buildroot/package/busybox/busybox.config            
index 02b1ee1..abc857e 100644            
--- a/rootfs/buildroot/package/busybox/busybox.config            
+++ b/rootfs/buildroot/package/busybox/busybox.config            
@@ -26,14 +26,14 @@ CONFIG_FEATURE_VERBOSE_USAGE=y            
CONFIG_BUSYBOX=y            
CONFIG_FEATURE_INSTALLER=y            
# CONFIG_INSTALL_NO_USR is not set            
-# CONFIG_LOCALE_SUPPORT is not set            
-# CONFIG_UNICODE_SUPPORT is not set            
+CONFIG_LOCALE_SUPPORT=y            
+CONFIG_UNICODE_SUPPORT=y            
# CONFIG_UNICODE_USING_LOCALE is not set            
-# CONFIG_FEATURE_CHECK_UNICODE_IN_ENV is not set            
-CONFIG_SUBST_WCHAR=0            
-CONFIG_LAST_SUPPORTED_WCHAR=0            
+CONFIG_FEATURE_CHECK_UNICODE_IN_ENV=y            
+CONFIG_SUBST_WCHAR=63            
+CONFIG_LAST_SUPPORTED_WCHAR=40907            
# CONFIG_UNICODE_COMBINING_WCHARS is not set            
-# CONFIG_UNICODE_WIDE_WCHARS is not set            
# 这个好像可以不用.            
+CONFIG_UNICODE_WIDE_WCHARS=y            
# CONFIG_UNICODE_BIDI_SUPPORT is not set            
# CONFIG_UNICODE_NEUTRAL_TABLE is not set            
# CONFIG_UNICODE_PRESERVE_BROKEN is not set            
@@ -805,13 +805,13 @@ CONFIG_ARPING=y            

图片

修改busybox源码    

busybox-1.34.1

From eb3ae4ea53dde8018524a0ed9dc08a65625197cc Mon Sep 17 00:00:00 2001            
From: "hero.huang"
Date: Wed, 23 Aug 2017 11:33:47 +0800      
Subject: [PATCH 3/4] busybox: support chinese display in terminal      
     
Signed-off-by: hero.huang
---        
libbb/printable_string.c | 4 +---        
libbb/unicode.c          | 4 ++--        
2 files changed, 3 insertions(+), 5 deletions(-)        
       
diff --git a/libbb/printable_string.c b/libbb/printable_string.c        
index a814fd0..f4c7b00 100644        
--- a/libbb/printable_string.c        
+++ b/libbb/printable_string.c        
@@ -28,8 +28,6 @@ const char* FAST_FUNC printable_string2(uni_stat_t *stats, const char *str)        
                }        
                if (c < ' ')        
                        break;        
-               if (c >= 0x7f)        
-                       break;        
                s++;        
        }        
       
@@ -42,7 +40,7 @@ const char* FAST_FUNC printable_string2(uni_stat_t *stats, const char *str)        
                        unsigned char c = *d;        
                        if (c == '\0')        
                                break;        
-                       if (c < ' ' || c >= 0x7f)        
+                       if (c < ' ')        
                                *d = '?';        
                        d++;        
                }        
diff --git a/libbb/unicode.c b/libbb/unicode.c        
index e98cbbf..677db1f 100644        
--- a/libbb/unicode.c        
+++ b/libbb/unicode.c        
@@ -1027,7 +1027,7 @@ static char* FAST_FUNC unicode_conv_to_printable2(uni_stat_t *stats, const char        
                                        while ((int)--width >= 0);        
                                        break;        
                                }        
-                               *d++ = (c >= ' ' && c < 0x7f) ? c : '?';        
+                               *d++ = (c >= ' ') ? c : '?';        
                                src++;        
                        }        
                        *d = '\0';        
@@ -1035,7 +1035,7 @@ static char* FAST_FUNC unicode_conv_to_printable2(uni_stat_t *stats, const char        
                        d = dst = xstrndup(src, width);        
                        while (*d) {        
                                unsigned char c = *d;        
-                               if (c < ' ' || c >= 0x7f)        
+                               if (c < ' ')        
                                        *d = '?';        
                                d++;        
                        }        
--        
2.20.1  

设置文件系统  

1.设置环境变量

 

export LC_ALL="zh_CN.UTF-8" export LANG="zh_CN.UTF-8"

2.确认文件系统中ls是不是指向 busybox

3.增加挂载时字符选择

diff --git a/buildroot-201611/target/user_rootfs_extra/etc/udev/scripts/mount.sh b/buildroot-201611/target/user_rootfs_extra/etc/udev/scripts/mount.sh            
index 29a4f48..817a4aa 100755            
--- a/buildroot-201611/target/user_rootfs_extra/etc/udev/scripts/mount.sh            
+++ b/buildroot-201611/target/user_rootfs_extra/etc/udev/scripts/mount.sh            
@@ -31,7 +31,7 @@ automount() {            
         # grant it with  w/r/x permissions.            
         case $ID_FS_TYPE in            
         vfat|fat)            
-                MOUNT="$MOUNT -o umask=007,gid=`awk -F':' '/^disk/{print $3}' /etc/group`"            
+                MOUNT="$MOUNT -o iocharset=utf8,umask=007,gid=`awk -F':' '/^disk/{print $3}' /etc/group`"            
                 ;;            
         # TODO            
         *)  

其它问题  

理论上应该可以了,如果不行试下:

1.minicom上有可能不支持utf-8显示,可以使用命令 minicom -D /dev/ttyUSB0 -R utf8

2.在内核配置要加上CONFIG_NLS=y,

CONFIG_NLS_UTF8=y,CONFIG_NLS_CODEPAGE_936=y(这个最好也加上)

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值