APM 学习 12 --- Linux 下学习库示例

本文介绍了如何在Linux环境下利用ArduPilot的UART_test示例进行APM飞控的深入开发。首先,通过指令查看可用示例,接着以UART_test为例,详细阐述了从源码阅读、修改到编译下载的全过程,并通过串口调试助手验证代码正常运行,帮助读者掌握APM飞控的调试技巧。

        为了方便大家深入了解飞控工作原理与编程,ArduPilot 提供了许多示例,位于 /Library 文件中,本文将以串口为例,为大家展示如何利用这些示例进一步深入开发 APM 飞控。

官方文档内容,方便大家对照查阅:https://ardupilot.org/dev/docs/learning-ardupilot-the-example-sketches.html

1,首先进入源码主目录,如何了解目前有哪里示例可以使用呢 ?通过如下指令:

./waf list | grep 'examples'

 系统将会列出可以使用的示例,随着版本的更新,示例将会越来越多。

2,我们将以 UART_test 为例,演示整个调试流程, 找到示例源码 UART_test.cpp,位于

/ardupilot/libraries/AP_HAL/examples/UART_test/UART_test.cpp

打开源代码,可以看到内容是重复输出代码编号


void loop(void)
{
    test_uart(hal.uartA, "uartA");
    test_uart(hal.uartB, "uartB");
    test_uart(hal.uartC, "uartC");
    test_uart(hal.uartD, "uartD");
    test_uart(hal.uartE, "uartE");

    // also do a raw printf() on some platforms, which prints to the
    // debug console
#if HAL_OS_POSIX_IO
    ::printf("Hello on debug console at %.3f seconds\n", (double)(AP_HAL::millis() * 0.001f));
#endif

    hal.scheduler->delay(1000);
}

3,尝试修改程序,然后编译程序并且下载

3.1,回到源码主目录

3.2,配置硬件,一般不变化不用重新配置,使用指令    ./waf configure --board px4-v2

root@ubuntu:/home/saffron/lrr/ardupilot# ./waf configure --board px4-v2
Setting top to                           : /home/saffron/lrr/ardupilot 
Setting out to                           : /home/saffron/lrr/ardupilot/build 
Autoconfiguration                        : enabled 
Setting board to                         : px4-v2 
Checking for program 'arm-none-eabi-ar'  : /opt/gcc-arm-none-eabi-6-2017-q2-update/bin/arm-none-eabi-ar 
Using toolchain                          : arm-none-eabi 
Checking for 'g++' (C++ compiler)        : /usr/lib/ccache/arm-none-eabi-g++ 
Checking for 'gcc' (C compiler)          : /usr/lib/ccache/arm-none-eabi-gcc 
Checking for c flags '-MMD'              : yes 
Checking for cxx fla
Linux 系统启动 Seata 时出现 'apm-skywalking not enabled' 错误,通常是由于 Seata 中的 APM(应用性能监控)SkyWalking 功能未正确配置或启用导致的。以下是一些可能的解决办法: ### 检查配置文件 首先要确认 Seata 的配置文件中 SkyWalking 相关配置是否正确。Seata 的配置文件一般为 `registry.conf` 和 `file.conf` 。 - **`registry.conf`**:检查其中关于 SkyWalking 的配置是否正确。若没有启用 SkyWalking,可将相关配置项注释掉或者移除。示例如下: ```properties # 注释或移除以下配置 apm { type = "skywalking" skywalking { serverAddr = "127.0.0.1:11800" } } ``` - **`file.conf`**:同样检查该文件中是否存在 SkyWalking 相关的错误配置。 ### 启用或禁用 SkyWalking 功能 若需要使用 SkyWalking 功能,要确保其已正确启用并配置。在 `registry.conf` 中添加或修改 SkyWalking 配置: ```properties apm { type = "skywalking" skywalking { serverAddr = "your_skywalking_server_address:port" } } ``` 将 `your_skywalking_server_address:port` 替换为实际的 SkyWalking 服务器地址和端口。 若不需要使用 SkyWalking 功能,可将 `apm.type` 设置为其他值或者将整个 `apm` 配置块注释掉: ```properties #apm { # type = "skywalking" # skywalking { # serverAddr = "127.0.0.1:11800" # } #} ``` ### 检查 SkyWalking 服务状态 若启用了 SkyWalking 功能,要保证 SkyWalking 服务正在运行,并且地址和端口配置正确。可以使用以下命令检查 SkyWalking 服务状态: ```bash netstat -tuln | grep 11800 # 假设端口为 11800 ``` 若服务未运行,需要启动 SkyWalking 服务。 ### 重启 Seata 服务 在完成上述配置修改后,重启 Seata 服务使配置生效: ```bash ./seata-server.sh stop # 停止 Seata 服务 ./seata-server.sh start # 启动 Seata 服务 ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值