构建全志 T113 Tina SDK
1、环境配置:
准备一个 Ubuntu 系统,可以是 WSL,虚拟机等,建议版本是 20.04。
1.1、安装必要的软件
进入系统后,输入下方命令安装需要的工具 :
sudo apt update -y sudo apt full-upgrade -y sudo apt install -y ack antlr3 asciidoc autoconf automake autopoint binutils bison build-essential \
bzip2 ccache cmake cpio curl device-tree-compiler fastjar flex gawk gettext gcc-multilib g++-multilib \
git gperf haveged help2man intltool libc6-dev-i386 libelf-dev libfuse-dev libglib2.0-dev libgmp3-dev \
libltdl-dev libmpc-dev libmpfr-dev libncurses5-dev libncursesw5-dev libpython3-dev libreadline-dev \
libssl-dev libtool lrzsz mkisofs msmtp ninja-build p7zip p7zip-full patch pkgconf python2.7 python3 \
python3-pyelftools python3-setuptools qemu-utils rsync scons squashfs-tools subversion swig texinfo \
uglifyjs upx-ucl unzip vim make make-guile gcc g++ wget xmlto xxd zlib1g-dev
1.2、安装 repo:
repo 是 Google 开发的用于管理 Android 版本库的一个工具,repo 是使用 Python 对 git 进行了一定的封装,并不是用于取代 git,它简化了对多个 git 版本库的管理。用 repo 管理的版本库都需要使用 git 命令来进行操作。
因此,使用 repo 工具之前,请先确保已经安装 git。
为什么要用 repo? 项目模块化/组件化之后各模块也作为独立的 git 仓库从主项目里剥离了去,各模块各自管理自己的版本。
下载 repo 文件
sudo curl -o /usr/bin/repo https://storage.googleapis.com/git-repo-downloads/repo
设置执行权限
sudo chmod a+x /usr/bin/repo
检查是否成功安装
repo --version
1.3、更换为国内镜像源
echo export REPO_URL='https://mirrors.tuna.tsinghua.edu.cn/git/git-repo' >> ~/.bashrc
source ~/.bashrc
1.4、配置保存身份认证:
新版本 git 默认加强了安全性,身份认证不会保存,导致拉取 repo 需要多次输入密码,可以用下列命令配置。
git config --global credential.helper store
2、SDK 拉取
2.1、新建一个目录用来存放 SDK
mkdir tina-sdkcd tina-sdk
2.2、初始化仓库
使用 repo init 命令初始化仓库,tina-d1-h 的仓库地址是 https://sdk.aw-ol.com/git_repo/D1_Tina_Open/manifest.git 需要执行命令:
repo init -u https://sdk.aw-ol.com/git_repo/D1_Tina_Open/manifest.git -b master -m tina-d1-h.xml
如果提示 Username for 'https://sdk.aw-ol.com': 请输入 全志在线开发者论坛 的用户名和密码 。
需要自己先去全志在线开发者论坛创建一个账号,先之前的经验贴说要升到 v2 才有权限下载,升一级还是容易的,但是经过测试现在是创建账号后就能下载。
2.3、使用命令 repo sync 拉取 SDK,由于 SDK 普遍较大,拉取可能需要一定的时间
repo sync
2.4、使用命令 repo start 创建开发环境分支
repo start product-smartx-d1-h-tina-stable-v2.0 --all
3、SDK 配置
3.1、当前克隆项目运行 source build/envsetup.sh 会存在以下报错:
bash: build/envsetup.sh: line 1: syntax error near unexpected token `$'{\r''
bash: build/envsetup.sh: line 1: `function hmm() {
解决方法:使用 dos2unix 批量将文件转换为 unix 格式 。
sudo apt install dos2unix find -type f | xargs dos2unix
3.2、合入 100ASK 的 T113-S3 补丁
由于全志默认的 SDK 没有提供 T113 的支持,所以需要打百问网的 T113 补丁。
此处需要在根目录操作,否则会污染下载到的tina-sdk。
cd ~
git clone https://github.com/DongshanPI/100ASK_T113-Pro_TinaSDK.gitcd 100ASK_T113-Pro_TinaSDK git submodule update --init # 替换实际的tina-sdk路径cp ./* -rfvd ~/tina-sdk
3.3、初始化编译环境
cd tina-sdksource build/envsetup.sh lunch You're building on Linux
Lunch menu... pick a combo: 1. d1-h_nezha-tina 2. d1-h_nezha_min-tina 3. d1s_nezha-tina 4. t113_100ask-tina
Which would you like? [Default d1s_nezha]: 4
按照以上步骤进入编译环境后,输入以下命令可进入linux内核配置:
make kernel_menuconfig
输入下列命令,可以进入Tina配置界面:
make menuconfig
4、修改配置文件
系统分区配置:
;---------------------------------------------------------------------------------------------------
; 说明: 脚本中的字符串区分大小写,用户可以修改"="后面的数值,但是不要修改前面的字符串
;---------------------------------------------------------------------------------------------------;---------------------------------------------------------------------------------------------------
; 固件下载参数配置
;---------------------------------------------------------------------------------------------------
;***************************************************************************************************
; mbr的大小, 以Kbyte为单位
;***************************************************************************************************
[mbr]
size = 16384;***************************************************************************************************
; 分区配置
;
;
; partition 定义范例:
; [partition] ; //表示是一个分区
; name = USERFS2 ; //分区名称
; size = 16384 ; //分区大小 单位: 扇区.分区表示个数最多2^31 * 512 = 2T
; downloadfile = "123.fex" ; //下载文件的路径和名称,可以使用相对路径,相对是指相对于image.cfg文件所在分区。也可以使用绝对路径
; keydata = 1 ; //私有数据分区,重新量产数据将不丢失
; encrypt = 1 ; //采用加密方式烧录,将提供数据加密,但损失烧录速度
; user_type = ? ; //私有用法
; verify = 1 ; //要求量产完成后校验是否正确
;
; 注:1、name唯一, 不允许同名
; 2、name最大12个字符
; 3、size = 0, 将创建一个无大小的空分区
; 4、align to logical block size(504 sectors), leb size = 2*(1 nand phy block size - 1 phy page size)
;***************************************************************************************************
[partition_start][partition]name = boot-resourcesize = 504downloadfile = "boot-resource.fex"user_type = 0x8000[partition]name = envsize = 504downloadfile = "env.fex"user_type = 0x8000[partition]name = env-redundsize = 504downloadfile = "env.fex"user_type = 0x8000[partition]name = bootsize = 10080downloadfile = "boot.fex"user_type = 0x8000[partition]name = rootfssize = 126000downloadfile = "rootfs.fex"user_type = 0x8000;[partition]
; name = dsp0
; size = 2048
; downloadfile = "dsp0.fex"
; user_type = 0x8000;[partition]
; name = recovery
; size = 16128
; ;downloadfile = "recovery.fex"
; user_type = 0x8000[partition]name = privatesize = 10240user_type = 0x8000[partition]name = rootfs_datasize = 10240user_type = 0x8000[partition]name = UDISKname = rootfs_datasize = 10240user_type = 0x8000
替换:tina-sdk/device/config/chips/t113/configs/100ask/sys_partition.fex。
5、修改 U-Boot 打印串口
5.1、修改配置文件
从 device/config/chips/t113/configs/100ask/BoardConfig.mk 中找到使用的 U-Boot 配置,将其打印串口改为 UART3,可以发现使用的 U-Boot 配置为 sun8iw20p1_uart3_defconfig。

找到文件并修改 tina-sdk/lichee/brandy-2.0/u-boot-2018/configs/sun8iw20p1_uart3_defconfig,将 CONFIG_CONS_INDEX 的值改为 4(串口号+1)。

找到并修改 tina-sdk/device/config/chips/t113/configs/100ask/sys_config.fex 文件,按图配置串口号和所用的引脚。

查看数据手册引脚复用,发现 PE8 和 PE9 的串口功能是 FUNC5,所以 uart_debug_tx/rx 的配置为 <5><1><default><default>。

5.2、修改设备树
修改设备树,找到 tina-sdk/device/config/chips/t113/configs/100ask/board.dts 文件,在 pio 节点下配置 uart3 的引脚复用功能。

开启 uart3。

5.3、修改寄存器地址
修改 uboot 环境变量文件 tina-sdk/device/config/chips/t113/configs/100ask/env.cfg。

earlyprintk=sunxi-uart,0x02500000 需要修改为 UART3 的地址,查阅手册可知为 0x02500C00。

输入make kernel_menuconfig 找到 Kernel low-level debugging functions 进行勾选。

6、解决编译报错问题
6.1、configure: error: XML::Parser perl module is required for intltool
输入make menuconfig,在 Libraries 目录下关闭 libxkbcommon 和 xkeyboard-config。


6.2、Qt下载失败问题
如果不需要使用 Qt 的话,输入 make menuconfig 关闭 Qt。

6.3、OpenSSH编译问题
修改 tina-sdk/package/network/openssh/Makefile,直接将版本修改为 8.9p1,即可解决编译问题。

7、编译,打包,烧入
输入下列命令,开始构建系统 :
# -j16 指的是使用16线程编译,实际编译时可按照电脑配置来选择使用多少线程编译。
make -j16
输入下列命令,开始单独构建 U-Boot:
mboot
输入下列命令,开始单独构建内核(构建系统会顺带构建内核):
mkernel
输入下列命令,开始打包系统 :
pack
将 SD 卡插入电脑,打开 PhoenixCard.exe,点击固件,加载 img 固件,然后选择启动卡,再点击烧卡即可,需要注意的是,一定要选择启动卡,否则会启动失败!

烧入软件为 PhoenixCard,链接如下,还有一些 T113 的开发文档:

链接: https://pan.baidu.com/s/1hWomuwc-f8OFpt_LMr4Oqg?pwd=ej2v
提取码: ej2v
8、文件系统只读解决方法
这个问题是因为根文件系统是 SquashFS 类型,且挂载为只读 (ro),需要使用 OverlayFS 让文件系统支持写操作。
默认 Tina-Linux 配置可能没有选中 e2fsprogs 包,导致第一次开机无法执行 ext4 格式化数据分区,只要在配置中开启 e2fsprogs 即可,OverlayFS 文件系统可以类似达到把只读文件系统改为可写文件系统的效果。
8.1、make menuconfig 打开 e2fsprog

8.2、make kernel_menuconfig 打开 ext4

8.3、修改设备树
如果你的原理图中 SD 卡如下图所示,则需要修改设备树,否则不需要修改设备树。

在百问网的补丁包基础上修改了串口之后烧录系统启动后会发现 can't open blockdev,原因是因为默认检测低电平为 SD 卡插入。
但是 SD 卡座 det 脚为高电平有效,所以这边不再使用 det 脚检测 SD 卡,而是使用轮询方式修改设备树,把 cd-gpios 注释掉,然后取消broken-cd的注销。
修改 tina-sdk/device/config/chips/t113/configs/100ask/board.dts 文件。

9、没有 eth0 网络接口解决方法
修改 tina-sdk/device/config/chips/t113/configs/100ask/board.dts 文件后,重新编译打包。
9.1、找到 pio 节点中的子节点 gmac0_pins_a 和 gmac0_pins_b
# 修改前:
gmac0_pins_a: gmac@0 {
allwinner,pins = "PE0", "PE1", "PE2", "PE3", "PE4",
"PE5", "PE6", "PE7","PE8", "PE9";
allwinner,function = "gmac0";
allwinner,muxsel = <8>;
allwinner,drive = <1>;
allwinner,pull = <0>;
};gmac0_pins_b: gmac@1 {
allwinner,pins = "PE0", "PE1", "PE2", "PE3", "PE4",
"PE5", "PE6", "PE7","PE8", "PE9";
allwinner,function = "gpio_in";
allwinner,muxsel = <0>;
allwinner,drive = <1>;
allwinner,pull = <0>;
};
# 修改后:gmac0_pins_a: gmac@0 {allwinner,pins = "PG0", "PG1", "PG2", "PG3","PG4", "PG5", "PG6","PG7","PG8","PG9", "PG10","PG11","PG12","PG13","PG14", "PG15";allwinner,function = "gmac0";allwinner,muxsel = <8>;allwinner,drive = <1>;allwinner,pull = <0>;};gmac0_pins_b: gmac@1 {allwinner,pins = "PG0", "PG1", "PG2", "PG3","PG4","PG5", "PG6","PG7","PG8","PG9", "PG10", "PG11","PG12","PG13","PG14", "PG15";allwinner,function = "gpio_in";allwinner,muxsel = <0>;allwinner,drive = <1>;allwinner,pull = <0>;};
9.2、找到 gmac0 节点
# 修改前:
&gmac0 {
pinctrl-0 = <&gmac0_pins_a>;
pinctrl-1 = <&gmac0_pins_b>;
pinctrl-names = "default", "sleep";
phy-mode = "rmii";
use_ephy25m = <0>;
tx-delay = <3>;
rx-delay = <0>;
phy-rst = <&pio PE 10 GPIO_ACTIVE_HIGH>;
status = "okay";
};
# 修改后:&gmac0 {pinctrl-0 = <&gmac0_pins_a>;pinctrl-1 = <&gmac0_pins_b>;pinctrl-names = "default", "sleep";phy-mode = "rgmii";use_ephy25m = <0>;gmac-power0-vol = <3300000>;tx-delay = <4>;rx-delay = <15>;
// phy-rst = <&gpio_ext 2 GPIO_ACTIVE_HIGH>;status = "okay";
};
参考文章链接:https://www.cnblogs.com/TheGathering/p/18137803
以上就是构建 T113 Tina-SDK 的全部内容,如果有什么疑问或者建议欢迎在评论区里提出来嗷。
相关文章:
构建全志 T113 Tina SDK
1、环境配置: 准备一个 Ubuntu 系统,可以是 WSL,虚拟机等,建议版本是 20.04。 1.1、安装必要的软件 进入系统后,输入下方命令安装需要的工具 : sudo apt update -y sudo apt full-upgrade -y sudo apt i…...
(推荐)【通用业务分发架构】1.业务分发 2.rpc调用 3.Event事件系统
一.Reflections和SpringUtil完成扫描包的(反射缓存) 二.id与class的映射泛型上下文(玩家是否登录,rpc调用SeqId,class类名)反射调用 1.netty层的 AccountMsgParam // 登录前 OnlineMsgParam // 登录后 SceneMsgParam // 发到场景层的 2.跨进程rpc调用的…...
最近的一些事情
正义不会缺席 这家公司违法辞退不给工资乱开离职证明。严重影响个人发展。 今天终于收到法院的判决书。 警醒自身发展与社会之间密切交流,敲响警钟。 虽然最终得到的法院的支持,但过程举步维艰。 这其中的过程,也让我对律师、法院和中国…...
CP AUTOSAR标准之FlexRayDriver(AUTOSAR_SWS_FlexRayDriver)(更新中……)
1 简介和功能概述 FlexRay驱动程序(Fr)抽象了特定FlexRay通信控制器(CC)的硬件相关实现细节。本规范主要依赖于符合FlexRay规范[13]的FlexRay CC。此外,本规范还支持符合FlexRay规范[14]的旧版FlexRay控制器。本SWS中因支持的FlexRay规范不同而导致的不同行为在适用的情况下以…...
Cesium 实战 27 - 三维视频融合(视频投影)
Cesium 实战 27 - 三维视频融合(视频投影) 核心代码完整代码在线示例在 Cesium 中有几种展示视频的方式,比如墙体使用视频材质,还有地面多边形使用视频材质,都可以实现视频功能。 但是随着摄像头和无人机的流行,需要视频和场景深度融合,简单的实现方式则不能满足需求。…...
GraphRAG实践:docker部署neo4j
概述 随着图数据库(Graph Database)的流行,越来越多的应用场景开始采用图数据库来处理复杂的关系数据。Neo4j作为领先的图数据库之一,提供了强大的图形查询语言Cypher、高效的存储结构和丰富的生态系统,使得它成为开发…...
常用的数据库类型都有哪些
在Java开发和信息系统架构中,数据库扮演着存储和管理数据的关键角色。数据库种类繁多,各有特色,适用于不同的应用场景。 1. 关系型数据库(RDBMS): • 关系型数据库是最为人熟知的数据库类型,数据…...
swiftui开发页面加载发送请求初始化@State变量
在SwiftUI中,你不能直接在init中更新State变量,因为State是由SwiftUI框架管理的,初始化时不允许直接修改。所以需要在onAppear发送请求然后修改State状态。 在SwiftUI中,如果希望在页面加载时立即发送网络请求,可以使…...
Ribbon和Eureka的集成
Ribbon和Eureka的集成是Spring Cloud Netflix生态系统的一部分,通常用于微服务架构中,以实现客户端负载均衡和服务发现。以下是更详细的集成步骤: 1. 引入依赖 在你的Spring Boot项目的pom.xml文件中添加Eureka客户端和Ribbon的依赖&#x…...
关于UE加载osgb数据的研究(一)
最近关于倾斜数据在UE中加载显示的问题,直接转换格式本地加载的方式避免了数据延迟加载、缓存加载,动态刷新等问题,但是也暴露了突出的问题:常规的模型格式会丢失掉倾斜数据的lod,致使效果缺失。 故而需要深入研究一下UE加载osgb数据的方式方法。 首先,我们需得学习一下…...
探索数据之美,Plotly引领可视化新风尚
在数据如潮的今天,如何精准捕捉信息的脉搏,让数据说话?Plotly,这款强大的数据可视化工具,正以其卓越的性能和丰富的功能,成为数据分析师、科学家及工程师们的得力助手。 Plotly不仅仅是一个绘图库…...
List排序的方法
List 排序方法: 1. list 的 sort() package com.example.a; import java.util.ArrayList; import java.util.Comparator; import java.util.List; class User{private Integer score;private Integer age;public User(Integer score, Integer age){super();this.…...
BurstAttention:高效的分布式注意力计算框架
BurstAttention:高效的分布式注意力计算框架 在现代大型语言模型(LLMs)的应用中,提升注意力机制的计算效率已成为研究的热点。当前,提升计算效率主要有两种方法:一种是优化单设备的计算和存储能力…...
大数据治理:构建稳健的数据生态系统
引言 随着信息技术的迅猛发展,企业每天都在生成海量的数据。这些数据不仅来自传统的业务交易系统,还包括社交媒体、物联网设备、移动应用程序等多个渠道。大数据治理旨在确保组织能够有效地管理其拥有的所有数据资产,以支持决策制定、优化业…...
【图书介绍】几本适合当教材的大数据技术图书
《Spark SQL大数据分析快速上手》 《Spark SQL大数据分析快速上手(大数据技术丛书)》(迟殿委,王泽慧,黄茵茵)【摘要 书评 试读】- 京东图书 《Spark SQL大数据分析快速上手》内容基于Spark新版本展开,符合企业目前开…...
阴阳师の新手如何速刷5个SP/SSR?!(急速育成)
目标:攒5个SP/SSR式神,参与急速育成,省四个黑蛋(想要快速升级技能而且经常上场的式神在攒够5个式神前先不升级)【理论上组成:10蓝40蓝预约召唤福利20修行or抽卡】 关键点:蓝票,新手…...
unity学习4:git和SVN的使用差别
目录 1 svn 1.1 操作逻辑 1.2 对应工具 1.3 SVN避免冲突的好习惯 2 git 2.1 git的基础操作逻辑 2.1.1 commit时,提交文件之外的其他文件需要pull 2.1.2 commit时,发现要提交的本地文件和服务器的文件冲突了 2.1.3 pull 时 2.2 对应工具 2.3 …...
四大自平衡树对比:AVL树、红黑树、B树与B+树
AVL树、红黑树、B树和B树的对比与应用场景 树系列相关文章(置顶) 1、从链表到平衡树:二叉查找树的退化与优化 2、自平衡二叉查找树:如何让二叉查找树始终保持高效 3、AVL树入门:理解自平衡二叉查找树的基础 4、红黑树全…...
BUUCTF Pwn ciscn_2019_es_2 WP
1.下载 checksec 用IDA32打开 定位main函数 发现了个假的后门函数: 看看vul函数: 使用read读取 想到栈溢出 但是只有48个 只能覆盖EBP和返回地址 长度不够构造 所以使用栈迁移: 栈迁移需要用到leave ret 使用ROPgadget找地址: …...
MongoDb-mongosh-登录
本地登录 mongosh --username root --password xxx 参考:Connect to a Deployment - MongoDB Shell...
通过Wrangler CLI在worker中创建数据库和表
官方使用文档:Getting started Cloudflare D1 docs 创建数据库 在命令行中执行完成之后,会在本地和远程创建数据库: npx wranglerlatest d1 create prod-d1-tutorial 在cf中就可以看到数据库: 现在,您的Cloudfla…...
大型活动交通拥堵治理的视觉算法应用
大型活动下智慧交通的视觉分析应用 一、背景与挑战 大型活动(如演唱会、马拉松赛事、高考中考等)期间,城市交通面临瞬时人流车流激增、传统摄像头模糊、交通拥堵识别滞后等问题。以演唱会为例,暖城商圈曾因观众集中离场导致周边…...
c++ 面试题(1)-----深度优先搜索(DFS)实现
操作系统:ubuntu22.04 IDE:Visual Studio Code 编程语言:C11 题目描述 地上有一个 m 行 n 列的方格,从坐标 [0,0] 起始。一个机器人可以从某一格移动到上下左右四个格子,但不能进入行坐标和列坐标的数位之和大于 k 的格子。 例…...
精益数据分析(97/126):邮件营销与用户参与度的关键指标优化指南
精益数据分析(97/126):邮件营销与用户参与度的关键指标优化指南 在数字化营销时代,邮件列表效度、用户参与度和网站性能等指标往往决定着创业公司的增长成败。今天,我们将深入解析邮件打开率、网站可用性、页面参与时…...
网站指纹识别
网站指纹识别 网站的最基本组成:服务器(操作系统)、中间件(web容器)、脚本语言、数据厍 为什么要了解这些?举个例子:发现了一个文件读取漏洞,我们需要读/etc/passwd,如…...
适应性Java用于现代 API:REST、GraphQL 和事件驱动
在快速发展的软件开发领域,REST、GraphQL 和事件驱动架构等新的 API 标准对于构建可扩展、高效的系统至关重要。Java 在现代 API 方面以其在企业应用中的稳定性而闻名,不断适应这些现代范式的需求。随着不断发展的生态系统,Java 在现代 API 方…...
Kafka主题运维全指南:从基础配置到故障处理
#作者:张桐瑞 文章目录 主题日常管理1. 修改主题分区。2. 修改主题级别参数。3. 变更副本数。4. 修改主题限速。5.主题分区迁移。6. 常见主题错误处理常见错误1:主题删除失败。常见错误2:__consumer_offsets占用太多的磁盘。 主题日常管理 …...
React从基础入门到高级实战:React 实战项目 - 项目五:微前端与模块化架构
React 实战项目:微前端与模块化架构 欢迎来到 React 开发教程专栏 的第 30 篇!在前 29 篇文章中,我们从 React 的基础概念逐步深入到高级技巧,涵盖了组件设计、状态管理、路由配置、性能优化和企业级应用等核心内容。这一次&…...
多元隐函数 偏导公式
我们来推导隐函数 z z ( x , y ) z z(x, y) zz(x,y) 的偏导公式,给定一个隐函数关系: F ( x , y , z ( x , y ) ) 0 F(x, y, z(x, y)) 0 F(x,y,z(x,y))0 🧠 目标: 求 ∂ z ∂ x \frac{\partial z}{\partial x} ∂x∂z、 …...
[拓扑优化] 1.概述
常见的拓扑优化方法有:均匀化法、变密度法、渐进结构优化法、水平集法、移动可变形组件法等。 常见的数值计算方法有:有限元法、有限差分法、边界元法、离散元法、无网格法、扩展有限元法、等几何分析等。 将上述数值计算方法与拓扑优化方法结合&#…...
