mirror of
https://github.com/PX4/PX4-Autopilot.git
synced 2026-05-31 10:26:52 +08:00
@@ -11,7 +11,7 @@ px4io recovery
|
|||||||
# Adjust PX4IO update rate limit
|
# Adjust PX4IO update rate limit
|
||||||
#
|
#
|
||||||
set PX4IO_LIMIT 400
|
set PX4IO_LIMIT 400
|
||||||
if hw_ver compare PX4FMU_V1
|
if ver hwcmp PX4FMU_V1
|
||||||
then
|
then
|
||||||
set PX4IO_LIMIT 200
|
set PX4IO_LIMIT 200
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
|
|
||||||
if [ -d /fs/microsd ]
|
if [ -d /fs/microsd ]
|
||||||
then
|
then
|
||||||
if hw_ver compare PX4FMU_V1
|
if ver hwcmp PX4FMU_V1
|
||||||
then
|
then
|
||||||
echo "Start sdlog2 at 50Hz"
|
echo "Start sdlog2 at 50Hz"
|
||||||
sdlog2 start -r 50 -a -b 8 -t
|
sdlog2 start -r 50 -a -b 8 -t
|
||||||
|
|||||||
@@ -22,7 +22,7 @@ then
|
|||||||
echo "[init] Using L3GD20(H)"
|
echo "[init] Using L3GD20(H)"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if hw_ver compare PX4FMU_V2
|
if ver hwcmp PX4FMU_V2
|
||||||
then
|
then
|
||||||
if lsm303d start
|
if lsm303d start
|
||||||
then
|
then
|
||||||
|
|||||||
@@ -248,7 +248,7 @@ then
|
|||||||
echo "[init] ERROR: PX4IO not found, disabling output"
|
echo "[init] ERROR: PX4IO not found, disabling output"
|
||||||
|
|
||||||
# Avoid using ttyS0 for MAVLink on FMUv1
|
# Avoid using ttyS0 for MAVLink on FMUv1
|
||||||
if hw_ver compare PX4FMU_V1
|
if ver hwcmp PX4FMU_V1
|
||||||
then
|
then
|
||||||
set FMU_MODE serial
|
set FMU_MODE serial
|
||||||
fi
|
fi
|
||||||
@@ -262,7 +262,7 @@ then
|
|||||||
if [ $HIL == yes ]
|
if [ $HIL == yes ]
|
||||||
then
|
then
|
||||||
set OUTPUT_MODE hil
|
set OUTPUT_MODE hil
|
||||||
if hw_ver compare PX4FMU_V1
|
if ver hwcmp PX4FMU_V1
|
||||||
then
|
then
|
||||||
set FMU_MODE serial
|
set FMU_MODE serial
|
||||||
fi
|
fi
|
||||||
@@ -308,7 +308,7 @@ then
|
|||||||
tone_alarm $TUNE_OUT_ERROR
|
tone_alarm $TUNE_OUT_ERROR
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if hw_ver compare PX4FMU_V1
|
if ver hwcmp PX4FMU_V1
|
||||||
then
|
then
|
||||||
if [ $FMU_MODE == pwm -o $FMU_MODE == gpio ]
|
if [ $FMU_MODE == pwm -o $FMU_MODE == gpio ]
|
||||||
then
|
then
|
||||||
@@ -383,7 +383,7 @@ then
|
|||||||
tone_alarm $TUNE_OUT_ERROR
|
tone_alarm $TUNE_OUT_ERROR
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if hw_ver compare PX4FMU_V1
|
if ver hwcmp PX4FMU_V1
|
||||||
then
|
then
|
||||||
if [ $FMU_MODE == pwm -o $FMU_MODE == gpio ]
|
if [ $FMU_MODE == pwm -o $FMU_MODE == gpio ]
|
||||||
then
|
then
|
||||||
|
|||||||
@@ -55,8 +55,8 @@ MODULES += systemcmds/top
|
|||||||
MODULES += systemcmds/tests
|
MODULES += systemcmds/tests
|
||||||
MODULES += systemcmds/config
|
MODULES += systemcmds/config
|
||||||
MODULES += systemcmds/nshterm
|
MODULES += systemcmds/nshterm
|
||||||
MODULES += systemcmds/hw_ver
|
|
||||||
MODULES += systemcmds/dumpfile
|
MODULES += systemcmds/dumpfile
|
||||||
|
MODULES += systemcmds/ver
|
||||||
|
|
||||||
#
|
#
|
||||||
# General system control
|
# General system control
|
||||||
|
|||||||
@@ -63,8 +63,8 @@ MODULES += systemcmds/tests
|
|||||||
MODULES += systemcmds/config
|
MODULES += systemcmds/config
|
||||||
MODULES += systemcmds/nshterm
|
MODULES += systemcmds/nshterm
|
||||||
MODULES += systemcmds/mtd
|
MODULES += systemcmds/mtd
|
||||||
MODULES += systemcmds/hw_ver
|
|
||||||
MODULES += systemcmds/dumpfile
|
MODULES += systemcmds/dumpfile
|
||||||
|
MODULES += systemcmds/ver
|
||||||
|
|
||||||
#
|
#
|
||||||
# General system control
|
# General system control
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ MODULES += systemcmds/reboot
|
|||||||
MODULES += systemcmds/tests
|
MODULES += systemcmds/tests
|
||||||
MODULES += systemcmds/nshterm
|
MODULES += systemcmds/nshterm
|
||||||
MODULES += systemcmds/mtd
|
MODULES += systemcmds/mtd
|
||||||
MODULES += systemcmds/hw_ver
|
MODULES += systemcmds/ver
|
||||||
|
|
||||||
#
|
#
|
||||||
# Library modules
|
# Library modules
|
||||||
|
|||||||
@@ -1,73 +0,0 @@
|
|||||||
/****************************************************************************
|
|
||||||
*
|
|
||||||
* Copyright (c) 2014 PX4 Development Team. All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions
|
|
||||||
* are met:
|
|
||||||
*
|
|
||||||
* 1. Redistributions of source code must retain the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer.
|
|
||||||
* 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in
|
|
||||||
* the documentation and/or other materials provided with the
|
|
||||||
* distribution.
|
|
||||||
* 3. Neither the name PX4 nor the names of its contributors may be
|
|
||||||
* used to endorse or promote products derived from this software
|
|
||||||
* without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
|
||||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
|
||||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
||||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
||||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
|
||||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
|
||||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
||||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
|
||||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*
|
|
||||||
****************************************************************************/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @file hw_ver.c
|
|
||||||
*
|
|
||||||
* Show and test hardware version.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <nuttx/config.h>
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <errno.h>
|
|
||||||
#include <version/version.h>
|
|
||||||
|
|
||||||
__EXPORT int hw_ver_main(int argc, char *argv[]);
|
|
||||||
|
|
||||||
int
|
|
||||||
hw_ver_main(int argc, char *argv[])
|
|
||||||
{
|
|
||||||
if (argc >= 2) {
|
|
||||||
if (!strcmp(argv[1], "show")) {
|
|
||||||
printf(HW_ARCH "\n");
|
|
||||||
exit(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!strcmp(argv[1], "compare")) {
|
|
||||||
if (argc >= 3) {
|
|
||||||
int ret = strcmp(HW_ARCH, argv[2]) != 0;
|
|
||||||
if (ret == 0) {
|
|
||||||
printf("hw_ver match: %s\n", HW_ARCH);
|
|
||||||
}
|
|
||||||
exit(ret);
|
|
||||||
|
|
||||||
} else {
|
|
||||||
errx(1, "not enough arguments, try 'compare PX4FMU_1'");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
errx(1, "expected a command, try 'show' or 'compare'");
|
|
||||||
}
|
|
||||||
@@ -32,11 +32,12 @@
|
|||||||
############################################################################
|
############################################################################
|
||||||
|
|
||||||
#
|
#
|
||||||
# Show and test hardware version
|
# "version" nsh-command displays version infromation for hw,sw, gcc,build etc
|
||||||
|
# can be also included and used in own code via "ver.h"
|
||||||
#
|
#
|
||||||
|
|
||||||
MODULE_COMMAND = hw_ver
|
MODULE_COMMAND = ver
|
||||||
SRCS = hw_ver.c
|
SRCS = ver.c
|
||||||
|
|
||||||
MODULE_STACKSIZE = 1024
|
MODULE_STACKSIZE = 1024
|
||||||
|
|
||||||
@@ -0,0 +1,123 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright (c) 2014 PX4 Development Team. All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in
|
||||||
|
* the documentation and/or other materials provided with the
|
||||||
|
* distribution.
|
||||||
|
* 3. Neither the name PX4 nor the names of its contributors may be
|
||||||
|
* used to endorse or promote products derived from this software
|
||||||
|
* without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||||
|
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||||
|
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||||
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||||
|
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||||
|
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||||
|
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||||
|
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
* POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @file ver.c
|
||||||
|
*
|
||||||
|
* Version command, unifies way of showing versions of HW, SW, Build, GCC
|
||||||
|
* In case you want to add new version just extend version_main function
|
||||||
|
*
|
||||||
|
* @author Vladimir Kulla <ufon@kullaonline.net>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <version/version.h>
|
||||||
|
#include <systemlib/err.h>
|
||||||
|
|
||||||
|
// string constants for version commands
|
||||||
|
static const char sz_ver_hw_str[] = "hw";
|
||||||
|
static const char sz_ver_hwcmp_str[] = "hwcmp";
|
||||||
|
static const char sz_ver_git_str[] = "git";
|
||||||
|
static const char sz_ver_bdate_str[] = "bdate";
|
||||||
|
static const char sz_ver_gcc_str[] = "gcc";
|
||||||
|
static const char sz_ver_all_str[] = "all";
|
||||||
|
|
||||||
|
static void usage(const char *reason)
|
||||||
|
{
|
||||||
|
if (reason != NULL) {
|
||||||
|
printf("%s\n", reason);
|
||||||
|
}
|
||||||
|
|
||||||
|
printf("usage: ver {hw|hwcmp|git|bdate|gcc|all}\n\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
__EXPORT int ver_main(int argc, char *argv[]);
|
||||||
|
|
||||||
|
int ver_main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
int ret = 1; //defaults to an error
|
||||||
|
|
||||||
|
// first check if there are at least 2 params
|
||||||
|
if (argc >= 2) {
|
||||||
|
if (argv[1] != NULL) {
|
||||||
|
if (!strncmp(argv[1], sz_ver_hw_str, sizeof(sz_ver_hw_str))) {
|
||||||
|
printf("%s\n", HW_ARCH);
|
||||||
|
ret = 0;
|
||||||
|
|
||||||
|
} else if (!strncmp(argv[1], sz_ver_hwcmp_str, sizeof(sz_ver_hwcmp_str))) {
|
||||||
|
if (argc >= 3 && argv[2] != NULL) {
|
||||||
|
// compare 3rd parameter with HW_ARCH string, in case of match, return 0
|
||||||
|
ret = strncmp(HW_ARCH, argv[2], strlen(HW_ARCH));
|
||||||
|
|
||||||
|
if (ret == 0) {
|
||||||
|
printf("ver hwcmp match: %s\n", HW_ARCH);
|
||||||
|
}
|
||||||
|
|
||||||
|
} else {
|
||||||
|
errx(1, "Not enough arguments, try 'ver hwcmp PX4FMU_V2'");
|
||||||
|
}
|
||||||
|
|
||||||
|
} else if (!strncmp(argv[1], sz_ver_git_str, sizeof(sz_ver_git_str))) {
|
||||||
|
printf("%s\n", FW_GIT);
|
||||||
|
ret = 0;
|
||||||
|
|
||||||
|
} else if (!strncmp(argv[1], sz_ver_bdate_str, sizeof(sz_ver_bdate_str))) {
|
||||||
|
printf("%s %s\n", __DATE__, __TIME__);
|
||||||
|
ret = 0;
|
||||||
|
|
||||||
|
} else if (!strncmp(argv[1], sz_ver_gcc_str, sizeof(sz_ver_gcc_str))) {
|
||||||
|
printf("%s\n", __VERSION__);
|
||||||
|
ret = 0;
|
||||||
|
|
||||||
|
} else if (!strncmp(argv[1], sz_ver_all_str, sizeof(sz_ver_all_str))) {
|
||||||
|
printf("HW arch: %s\n", HW_ARCH);
|
||||||
|
printf("Build datetime: %s %s\n", __DATE__, __TIME__);
|
||||||
|
printf("FW git-hash: %s\n", FW_GIT);
|
||||||
|
printf("GCC toolchain: %s\n", __VERSION__);
|
||||||
|
ret = 0;
|
||||||
|
|
||||||
|
} else {
|
||||||
|
errx(1, "unknown command.\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
} else {
|
||||||
|
usage("Error, input parameter NULL.\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
} else {
|
||||||
|
usage("Error, not enough parameters.");
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user