日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

pixhawk px4 commander.cpp

發(fā)布時(shí)間:2024/4/18 编程问答 47 豆豆
生活随笔 收集整理的這篇文章主要介紹了 pixhawk px4 commander.cpp 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

對(duì)于復(fù)雜的函數(shù),要做的就是看函數(shù)的輸入是什么、來(lái)自哪里,經(jīng)過(guò)處理后得到什么、給誰(shuí)用,這樣就可以把程序邏輯理清(中間的分析就是看函數(shù)如何處理的)

extern "C" __EXPORT int commander_main(int argc, char *argv[]);
  • 1

argc和argv是commander_main函數(shù)的形參,它們是程序的“命令行參數(shù)”。agrc(argument count的縮寫,意思是參數(shù)個(gè)數(shù)),argv(argument vector的縮寫,意思是參數(shù)向量),它是一個(gè)*char指針數(shù)組,數(shù)組中每一個(gè)元素指向命令行中的一個(gè)字符串。main函數(shù)是操作系統(tǒng)調(diào)用的,實(shí)參只能由操作系統(tǒng)給出。在操作命令狀態(tài)下,實(shí)參是和執(zhí)行文件的命令一起給出的。例如在DOS、UNIX或Linux等系統(tǒng)的操作命令狀態(tài)下,在命令行中包括了命令名和需要傳給main函數(shù)的參數(shù)。
命令行的一般形式為:
命令名 參數(shù)1 參數(shù)2 …… 參數(shù)n
命令名和各參數(shù)之間用空格分隔。命令名是可執(zhí)行文件名(此文件包含main函數(shù))。
在rcS執(zhí)行的時(shí)候,比如commander_main start
那么agrc就等于2,agrv[0]就是commander_main這個(gè)字符串,argv[1]就是start。
所以要判斷agrv[1]是start還是stop。
就像你在dos命令行里輸入commander start,自然就給agrc和agrv[]賦值。NuttX系統(tǒng)下的模塊的主函數(shù)名字都是以”_main”開始的,但是調(diào)用的時(shí)候不加“_main”。
例如:extern “C” _EXPORT int commander_main (int argc, char *argv[]);
這里extern “C”告訴編譯器在編譯commander_main這個(gè)函數(shù)時(shí)按照C的規(guī)則去翻譯相關(guān)的函數(shù)名而不是C++的;__EXPORT 表示將函數(shù)名輸出到鏈接器(Linker)。
然后跳轉(zhuǎn)到函數(shù)的定義部分int commander_main (int argc, char *argv[]),判斷系統(tǒng)給出的命令行的參數(shù),一系列的判斷,C++在大型項(xiàng)目上的優(yōu)勢(shì)這里有沒(méi)有發(fā)揮出來(lái)!
進(jìn)入commander_main()

int commander_main(int argc, char *argv[]) {if (argc < 2) {usage("missing command");return 1;}if (!strcmp(argv[1], "start")) {if (thread_running) {warnx("already running");/* this is not an error */return 0;}thread_should_exit = false;daemon_task = px4_task_spawn_cmd("commander",SCHED_DEFAULT,SCHED_PRIORITY_DEFAULT + 40,3600,commander_thread_main,(char * const *)&argv[0]);unsigned constexpr max_wait_us = 1000000;unsigned constexpr max_wait_steps = 2000;unsigned i;for (i = 0; i < max_wait_steps; i++) {usleep(max_wait_us / max_wait_steps);if (thread_running) {break;}}return !(i < max_wait_steps);}if (!strcmp(argv[1], "stop")) {if (!thread_running) {warnx("commander already stopped");return 0;}thread_should_exit = true;while (thread_running) {usleep(200000);warnx(".");}warnx("terminated.");return 0;}/* commands needing the app to run below */if (!thread_running) {warnx("\tcommander not started");return 1;}if (!strcmp(argv[1], "status")) {print_status();return 0;}if (!strcmp(argv[1], "calibrate")) {if (argc > 2) {int calib_ret = OK;if (!strcmp(argv[2], "mag")) {calib_ret = do_mag_calibration(&mavlink_log_pub);} else if (!strcmp(argv[2], "accel")) {calib_ret = do_accel_calibration(&mavlink_log_pub);} else if (!strcmp(argv[2], "gyro")) {calib_ret = do_gyro_calibration(&mavlink_log_pub);} else if (!strcmp(argv[2], "level")) {calib_ret = do_level_calibration(&mavlink_log_pub);} else if (!strcmp(argv[2], "esc")) {calib_ret = do_esc_calibration(&mavlink_log_pub, &armed);} else if (!strcmp(argv[2], "airspeed")) {calib_ret = do_airspeed_calibration(&mavlink_log_pub);} else {warnx("argument %s unsupported.", argv[2]);}if (calib_ret) {warnx("calibration failed, exiting.");return 1;} else {return 0;}} else {warnx("missing argument");}}if (!strcmp(argv[1], "check")) {int checkres = 0;checkres = preflight_check(&status, &mavlink_log_pub, false, true, &status_flags, &battery, false, hrt_elapsed_time(&commander_boot_timestamp));warnx("Preflight check: %s", (checkres == 0) ? "OK" : "FAILED");checkres = preflight_check(&status, &mavlink_log_pub, true, true, &status_flags, &battery, true, hrt_elapsed_time(&commander_boot_timestamp));warnx("Prearm check: %s", (checkres == 0) ? "OK" : "FAILED");return 0;}if (!strcmp(argv[1], "arm")) {if (TRANSITION_CHANGED != arm_disarm(true, &mavlink_log_pub, "command line")) {warnx("arming failed");}return 0;}if (!strcmp(argv[1], "disarm")) {if (TRANSITION_DENIED == arm_disarm(false, &mavlink_log_pub, "command line")) {warnx("rejected disarm");}return 0;}if (!strcmp(argv[1], "takeoff")) {/* see if we got a home position */if (status_flags.condition_home_position_valid) {if (TRANSITION_DENIED != arm_disarm(true, &mavlink_log_pub, "command line")) {vehicle_command_s cmd = {};cmd.target_system = status.system_id;cmd.target_component = status.component_id;cmd.command = vehicle_command_s::VEHICLE_CMD_NAV_TAKEOFF;cmd.param1 = NAN; /* minimum pitch *//* param 2-3 unused */cmd.param2 = NAN;cmd.param3 = NAN;cmd.param4 = NAN;cmd.param5 = NAN;cmd.param6 = NAN;cmd.param7 = NAN;orb_advert_t h = orb_advertise_queue(ORB_ID(vehicle_command), &cmd, vehicle_command_s::ORB_QUEUE_LENGTH);(void)orb_unadvertise(h);} else {warnx("arming failed");}} else {warnx("rejecting takeoff, no position lock yet. Please retry..");}return 0;}if (!strcmp(argv[1], "land")) {vehicle_command_s cmd = {};cmd.target_system = status.system_id;cmd.target_component = status.component_id;cmd.command = vehicle_command_s::VEHICLE_CMD_NAV_LAND;/* param 2-3 unused */cmd.param2 = NAN;cmd.param3 = NAN;cmd.param4 = NAN;cmd.param5 = NAN;cmd.param6 = NAN;cmd.param7 = NAN;orb_advert_t h = orb_advertise_queue(ORB_ID(vehicle_command), &cmd, vehicle_command_s::ORB_QUEUE_LENGTH);(void)orb_unadvertise(h);return 0;}if (!strcmp(argv[1], "transition")) {vehicle_command_s cmd = {};cmd.target_system = status.system_id;cmd.target_component = status.component_id;cmd.command = vehicle_command_s::VEHICLE_CMD_DO_VTOL_TRANSITION;/* transition to the other mode */cmd.param1 = (status.is_rotary_wing) ? vtol_vehicle_status_s::VEHICLE_VTOL_STATE_FW : vtol_vehicle_status_s::VEHICLE_VTOL_STATE_MC;/* param 2-3 unused */cmd.param2 = NAN;cmd.param3 = NAN;cmd.param4 = NAN;cmd.param5 = NAN;cmd.param6 = NAN;cmd.param7 = NAN;orb_advert_t h = orb_advertise_queue(ORB_ID(vehicle_command), &cmd, vehicle_command_s::ORB_QUEUE_LENGTH);(void)orb_unadvertise(h);return 0;}if (!strcmp(argv[1], "mode")) {if (argc > 2) {uint8_t new_main_state = commander_state_s::MAIN_STATE_MAX;if (!strcmp(argv[2], "manual")) {new_main_state = commander_state_s::MAIN_STATE_MANUAL;} else if (!strcmp(argv[2], "altctl")) {new_main_state = commander_state_s::MAIN_STATE_ALTCTL;} else if (!strcmp(argv[2], "posctl")) {new_main_state = commander_state_s::MAIN_STATE_POSCTL;} else if (!strcmp(argv[2], "auto:mission")) {new_main_state = commander_state_s::MAIN_STATE_AUTO_MISSION;} else if (!strcmp(argv[2], "auto:loiter")) {new_main_state = commander_state_s::MAIN_STATE_AUTO_LOITER;} else if (!strcmp(argv[2], "auto:rtl")) {new_main_state = commander_state_s::MAIN_STATE_AUTO_RTL;} else if (!strcmp(argv[2], "acro")) {new_main_state = commander_state_s::MAIN_STATE_ACRO;} else if (!strcmp(argv[2], "offboard")) {new_main_state = commander_state_s::MAIN_STATE_OFFBOARD;} else if (!strcmp(argv[2], "stabilized")) {new_main_state = commander_state_s::MAIN_STATE_STAB;} else if (!strcmp(argv[2], "rattitude")) {new_main_state = commander_state_s::MAIN_STATE_RATTITUDE;} else if (!strcmp(argv[2], "auto:takeoff")) {new_main_state = commander_state_s::MAIN_STATE_AUTO_TAKEOFF;} else if (!strcmp(argv[2], "auto:land")) {new_main_state = commander_state_s::MAIN_STATE_AUTO_LAND;} else {warnx("argument %s unsupported.", argv[2]);}if (TRANSITION_DENIED == main_state_transition(&status, new_main_state, main_state_prev, &status_flags, &internal_state)) {warnx("mode change failed");}return 0;} else {warnx("missing argument");}}if (!strcmp(argv[1], "lockdown")) {if (argc < 3) {usage("not enough arguments, missing [on, off]");return 1;}vehicle_command_s cmd = {};cmd.target_system = status.system_id;cmd.target_component = status.component_id;cmd.command = vehicle_command_s::VEHICLE_CMD_DO_FLIGHTTERMINATION;/* if the comparison matches for off (== 0) set 0.0f, 2.0f (on) else */cmd.param1 = strcmp(argv[2], "off") ? 2.0f : 0.0f; /* lockdown */orb_advert_t h = orb_advertise_queue(ORB_ID(vehicle_command), &cmd, vehicle_command_s::ORB_QUEUE_LENGTH);(void)orb_unadvertise(h);return 0;}usage("unrecognized command");return 1; }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
  • 108
  • 109
  • 110
  • 111
  • 112
  • 113
  • 114
  • 115
  • 116
  • 117
  • 118
  • 119
  • 120
  • 121
  • 122
  • 123
  • 124
  • 125
  • 126
  • 127
  • 128
  • 129
  • 130
  • 131
  • 132
  • 133
  • 134
  • 135
  • 136
  • 137
  • 138
  • 139
  • 140
  • 141
  • 142
  • 143
  • 144
  • 145
  • 146
  • 147
  • 148
  • 149
  • 150
  • 151
  • 152
  • 153
  • 154
  • 155
  • 156
  • 157
  • 158
  • 159
  • 160
  • 161
  • 162
  • 163
  • 164
  • 165
  • 166
  • 167
  • 168
  • 169
  • 170
  • 171
  • 172
  • 173
  • 174
  • 175
  • 176
  • 177
  • 178
  • 179
  • 180
  • 181
  • 182
  • 183
  • 184
  • 185
  • 186
  • 187
  • 188
  • 189
  • 190
  • 191
  • 192
  • 193
  • 194
  • 195
  • 196
  • 197
  • 198
  • 199
  • 200
  • 201
  • 202
  • 203
  • 204
  • 205
  • 206
  • 207
  • 208
  • 209
  • 210
  • 211
  • 212
  • 213
  • 214
  • 215
  • 216
  • 217


此圖參考了http://blog.csdn.net/oqqenvy12/article/details/69328147
每個(gè)argv[1]所對(duì)應(yīng)的函數(shù)如下

px4_task_spawn_cmd()
守護(hù)進(jìn)程daemon是運(yùn)行在后臺(tái)的進(jìn)程。
在NuttX中守護(hù)進(jìn)程是一個(gè)任務(wù),在POSIX(Linux/Mac OS)中是一個(gè)線程

daemon_task = px4_task_spawn_cmd("commander",SCHED_DEFAULT,SCHED_PRIORITY_DEFAULT + 40,3600,commander_thread_main,(char * const *)&argv[0]);
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

以下是參數(shù):
- arg0: 進(jìn)程名 commander
- arg1: 調(diào)度類型(RR or FIFO)the scheduling type (RR or FIFO)
- arg2: 調(diào)度優(yōu)先級(jí)
- arg3: 新進(jìn)程或線程堆棧大小
- arg4: 任務(wù)/線程主函數(shù)
- arg5: 一個(gè)void指針傳遞給新任務(wù),在這種情況下是命令行參數(shù)
在Unix和其他多任務(wù)操作系統(tǒng)中daemon程序是指作為一個(gè)后臺(tái)進(jìn)程運(yùn)行的計(jì)算機(jī)程序,而不是由用戶直接控制的程序,daemon概念的好處是它不需要被用戶或者shell發(fā)送到后臺(tái)就能被啟動(dòng),并且當(dāng)它在運(yùn)行時(shí)可以通過(guò)shell查詢它的狀態(tài),它也可以被終止。
后臺(tái)應(yīng)用程序只是暫時(shí)存在用與開始后臺(tái)作業(yè),在MakeFile中指定的堆棧大小僅適用于這個(gè)管理任務(wù)。實(shí)際的堆棧大小應(yīng)在task_create( )調(diào)用中設(shè)置。
主函數(shù)由一個(gè)daemon控制函數(shù)代替,主函數(shù)中原來(lái)的部分現(xiàn)在由一個(gè)后臺(tái)任務(wù)(task)/線程(thread)來(lái)代替。
print_status()
打印機(jī)型(旋翼還是固定翼)/USB插還是拔了、電源電壓是否合法/航空電子管的電壓/home點(diǎn)的經(jīng)緯度、高度、偏航角(指南針)/home點(diǎn)的空間坐標(biāo)xyz/數(shù)據(jù)鏈連接還是斷開/main state/nav state/status.arming_state
calibrate
校正函數(shù)分別校正:mag、accel、gyro、level、esc、airspeed。這里對(duì)應(yīng)著起飛前的校正步驟,其具體實(shí)現(xiàn)過(guò)程暫時(shí)不討論。
preflight_check
預(yù)飛檢查

checkres = preflight_check(&status, &mavlink_log_pub, false, true, &status_flags, &battery, false, hrt_elapsed_time(&commander_boot_timestamp));
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
int preflight_check(struct vehicle_status_s *status, orb_advert_t *mavlink_log_pub, bool prearm, bool force_report, status_flags_s *status_flags, battery_status_s *battery, bool can_arm_without_gps, hrt_abstime time_since_boot)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

檢查各項(xiàng)賦值給preflight_ok,首先是用函數(shù)Commander::preflightCheck(…)檢查,然后是否連著USB,最后檢查電壓,返回值為!preflight_ok。
USB:

if (!status_flags->circuit_breaker_engaged_usb_check && status_flags->usb_connected && prearm) {preflight_ok = false;if (reportFailures) {mavlink_log_critical(mavlink_log_pub, "ARMING DENIED: Flying with USB is not safe");}}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

由上述程序可知USB是否連接主要來(lái)自以下判斷

status_flags.circuit_breaker_engaged_usb_check= circuit_breaker_enabled("CBRK_USB_CHK", CBRK_USB_CHK_KEY); /* finally judge the USB connected state based on software detection */ status_flags.usb_connected = _usb_telemetry_active;
  • 1
  • 2
  • 3

prearm是自動(dòng)傳入的參數(shù)true/false
電壓:

orb_copy(ORB_ID(battery_status), battery_sub, &battery);
  • 1

電壓來(lái)源于px4io.cpp

_battery.updateBatteryStatus(timestamp, voltage_v, current_a, _last_throttle, _armed, &battery_status)
  • 1
bool preflight_ok = Commander::preflightCheck(mavlink_log_pub, true, true, true, true,checkAirspeed, (status->rc_input_mode == vehicle_status_s::RC_IN_MODE_DEFAULT),!can_arm_without_gps, true, status->is_vtol, reportFailures, prearm, time_since_boot);
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
bool preflightCheck(orb_advert_t *mavlink_log_pub, bool checkMag, bool checkAcc, bool checkGyro,bool checkBaro, bool checkAirspeed, bool checkRC, bool checkGNSS,bool checkDynamic, bool isVTOL, bool reportFailures, bool prearm, hrt_abstime time_since_boot)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

里面的檢查函數(shù)主要為

magnometerCheck(mavlink_log_pub, i, !required, device_id, reportFailures) accelerometerCheck(mavlink_log_pub, i, !required, checkDynamic, device_id, reportFailures) gyroCheck(mavlink_log_pub, i, !required, device_id, reportFailures) baroCheck(mavlink_log_pub, i, !required, device_id, reportFailures) imuConsistencyCheck(mavlink_log_pub, checkAcc, checkGyro, reportFailures) airspeedCheck(mavlink_log_pub, true, reportFailures, prearm, time_since_boot) rc_calibration_check(mavlink_log_pub, reportFailures, isVTOL) gnssCheck(mavlink_log_pub, reportFailures) ekf2Check(mavlink_log_pub, true, reportFailures)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

分別檢查mag、accel、gyro、baro、imu一致性、airspeed、rc校準(zhǔn)、ekf2。返回值為!failed。
arm_disarm上鎖解鎖判定函數(shù)

arm_disarm(true, &mavlink_log_pub, "command line")---arm arm_disarm(false, &mavlink_log_pub, "command line")---disarm transition_result_t arm_disarm(bool arm, orb_advert_t *mavlink_log_pub_local, const char *armedBy)
  • 1
  • 2
  • 3

參數(shù):
bool arm上鎖/解鎖
orb_advert_t *mavlink_log_pub_local
const char *armedBy
返回TRANSITION_DENIED/TRANSITION_CHANGED/TRANSITION_NOT_CHANGED
實(shí)際飛行上鎖解鎖主要靠arming_state_transition()函數(shù)判斷

arming_res = arming_state_transition(&status,&battery,&safety, arm ? vehicle_status_s::ARMING_STATE_ARMED : vehicle_status_s::ARMING_STATE_STANDBY,&armed,true /* fRunPreArmChecks */,mavlink_log_pub_local,&status_flags,avionics_power_rail_voltage,can_arm_without_gps,hrt_elapsed_time(&commander_boot_timestamp));
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
transition_result_t arming_state_transition(struct vehicle_status_s *status,struct battery_status_s *battery,const struct safety_s *safety,arming_state_t new_arming_state,struct actuator_armed_s *armed,bool fRunPreArmChecks,orb_advert_t *mavlink_log_pub, ///< uORB handle for mavlink logstatus_flags_s *status_flags,float avionics_power_rail_voltage,bool can_arm_without_gps,hrt_abstime time_since_boot)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

參數(shù):
當(dāng)前鎖定狀態(tài)是從arming_state_t current_arming_state = status->arming_state傳入的
新的鎖定狀態(tài)是從函數(shù)參數(shù)arming_state_t new_arming_state傳入的
返回TRANSITION_DENIED/TRANSITION_CHANGED/TRANSITION_NOT_CHANGED
判斷是否需要改變鎖定狀態(tài)

if (new_arming_state == current_arming_state) {ret = TRANSITION_NOT_CHANGED; } else { …… }
  • 1
  • 2
  • 3
  • 4
  • 5
if (fRunPreArmChecks && new_arming_state == vehicle_status_s::ARMING_STATE_ARMED&& status->hil_state == vehicle_status_s::HIL_STATE_OFF) {// 1&&1&&1prearm_ret = preflight_check(status, mavlink_log_pub, true /* pre-arm */, false /* force_report */,status_flags, battery, can_arm_without_gps, time_since_boot); }
  • 1
  • 2
  • 3
  • 4

在改變鎖定狀態(tài)前一定會(huì)進(jìn)行預(yù)飛檢查,而prearm_ret = !preflight_ok;

if (!status_flags->condition_system_sensors_initialized&& (new_arming_state == vehicle_status_s::ARMING_STATE_ARMED|| new_arming_state == vehicle_status_s::ARMING_STATE_STANDBY)&& status->hil_state == vehicle_status_s::HIL_STATE_OFF) {if (last_preflight_check == 0 || hrt_absolute_time() - last_preflight_check > 1000 * 1000) {prearm_ret = preflight_check(status, mavlink_log_pub, false /* pre-flight */, false /* force_report */, status_flags, battery, can_arm_without_gps, time_since_boot);status_flags->condition_system_sensors_initialized = !prearm_ret;last_preflight_check = hrt_absolute_time();last_prearm_ret = prearm_ret;} else {prearm_ret = last_prearm_ret;} }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
status_flags.condition_system_sensors_initialized = Commander::preflightCheck(……) //commander
  • 1


如果預(yù)飛檢查有問(wèn)題,那么還需要再檢查一遍

bool valid_transition = arming_transitions[new_arming_state][status->arming_state];
  • 1


行是新的鎖定狀態(tài),列是當(dāng)前鎖定狀態(tài)。True表示轉(zhuǎn)變合法,false表示轉(zhuǎn)變不合法。雖然有的標(biāo)記為true,但是仍然需要額外的檢查判斷。
二次判斷:如果新的鎖定狀態(tài)是armed(解鎖),那么預(yù)飛檢查失敗、安全開關(guān)沒(méi)開、電源分離器沒(méi)連接或航空電源電壓低于4.5v,都不能轉(zhuǎn)變成armed;如果新的鎖定狀態(tài)是STANDBY&&當(dāng)前鎖定狀態(tài)是armed_error,那么新的鎖定狀態(tài)賦為STANDBY_error。
如果當(dāng)前鎖定狀態(tài)為STANDBY_error,而操作者正打算解鎖,那么需要根據(jù)預(yù)飛檢測(cè)傳感器的狀態(tài)告知操作者重啟和一些提示信息。
經(jīng)過(guò)上述多次判斷處理就可以改變鎖定狀態(tài)了

ret = TRANSITION_CHANGED; status->arming_state = new_arming_state;
  • 1
  • 2

說(shuō)到底arm_disarm()和arming_state_transition()處理最后只是返回一個(gè)該不該改變鎖定狀態(tài)的標(biāo)志位

main_state_transition飛行模式切換的條件判斷函數(shù)
main_state_transition(&status,

main_state_transition(&status, new_main_state, main_state_prev, &status_flags, &internal_state) main_state_transition(struct vehicle_status_s *status, main_state_t new_main_state, uint8_t &main_state_prev,status_flags_s *status_flags, struct commander_state_s *internal_state)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

參數(shù):
? status:導(dǎo)航狀態(tài),飛行器應(yīng)該進(jìn)入的狀態(tài);
? new_main_state: 期望切換到的新?tīng)顟B(tài)
? &main_state_prev: 之前的狀態(tài)
? status_flags: commander內(nèi)部的狀態(tài)標(biāo)志;
? internal_state: 內(nèi)部狀態(tài)
返回值:
? ret = TRANSITION_DENIED; // 表示不滿足切換條件,拒絕狀態(tài)切換
? ret = TRANSITION_CHANGED; // 切換到某個(gè)狀態(tài),不一定是用戶想要的目標(biāo)狀態(tài),會(huì)根據(jù)降級(jí)策略,切換至一個(gè)最接近的狀態(tài)。
? ret = TRANSITION_NOT_CHANGED;
根據(jù)status_flags->condition_local_altitude_valid、status_flags->condition_global_position_valid、status_flags->condition_local_position_valid等信息看是否可以轉(zhuǎn)換成新的飛行狀態(tài),判斷通過(guò)則ret = TRANSITION_CHANGED,如果沒(méi)寫判斷,那么默認(rèn)ret = TRANSITION_DENIED。


/**********************commander_thread_main**********************/
(1)param_t xxx=param_find(const char *name)將*name所對(duì)應(yīng)的參數(shù)值賦給xxx
(2)給status、status_flags結(jié)構(gòu)體賦初始值
(3)用dm_read ()讀取mission結(jié)構(gòu)體

/** Retrieve from the data manager file */ dm_read(DM_KEY_MISSION_STATE, 0, &mission, sizeof(mission_s) dm_read(dm_item_t item, unsigned char index, void *buf, size_t count) ssize_t dm_read(dm_item_t item, /* The item type to retrieve */unsigned char index, /* The index of the item */void *buffer, /* Pointer to caller data buffer */size_t buflen /* Length in bytes of data to retrieve */ )
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

(4)status、armed、control_mode、_home、_roi、command_ack、safety、geofence_result、sp_man—ORB_ID(manual_control_setpoint)、offboard_control_mode、global_position、gps_position、sensors、diff_pres、cmd、battery、info、pos_sp_triplet、system_power、actuator_controls、vtol_status、cpuload初始化為0
(5)control_status_leds(&status, &armed, true, &battery, &cpuload);
void control_status_leds(vehicle_status_s *status_local,
const actuator_armed_s *actuator_armed,
bool changed,
battery_status_s *battery_local,
const cpuload_s *cpuload_local)
功能:根據(jù)飛行器的鎖定狀態(tài)、傳感器狀態(tài)檢測(cè)情況和CPU負(fù)載情況選擇如何亮燈。
(6)獲取飛機(jī)機(jī)型

/* update vehicle status to find out vehicle type (required for preflight checks) */ param_get(_param_sys_type, &(status.system_type)); // get system type status.is_rotary_wing = is_rotary_wing(&status) || is_vtol(&status); status.is_vtol = is_vtol(&status);
  • 1
  • 2
  • 3
  • 4

(7)獲取參數(shù)
param_get(param_t param, void *val)
從param獲取參數(shù),存到*val
(8)創(chuàng)建一個(gè)低優(yōu)先級(jí)的進(jìn)程,并運(yùn)行commander_low_prio_loop(),隨后使用pthread_attr_destroy(&commander_low_prio_attr)將低優(yōu)先級(jí)進(jìn)程終結(jié)。

/* initialize low priority thread */pthread_attr_t commander_low_prio_attr;pthread_attr_init(&commander_low_prio_attr);pthread_attr_setstacksize(&commander_low_prio_attr, PX4_STACK_ADJUSTED(3000)); #ifndef __PX4_QURT// This is not supported by QURT (yet).struct sched_param param;(void)pthread_attr_getschedparam(&commander_low_prio_attr, &param);/* low priority */param.sched_priority = SCHED_PRIORITY_DEFAULT - 50;(void)pthread_attr_setschedparam(&commander_low_prio_attr, &param); #endifpthread_create(&commander_low_prio_thread,&commander_low_prio_attr, commander_low_prio_loop, nullptr);pthread_attr_destroy(&commander_low_prio_attr);
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

其中void *commander_low_prio_loop(void *arg)
①等待cmd更新,等待1s,超出1s則跳出本函數(shù);少于1s則進(jìn)行以下處理

/* ignore commands the high-prio loop or the navigator handles */ if (cmd.command == vehicle_command_s::VEHICLE_CMD_DO_SET_MODE || cmd.command == vehicle_command_s::VEHICLE_CMD_COMPONENT_ARM_DISARM || cmd.command == vehicle_command_s::VEHICLE_CMD_NAV_TAKEOFF || cmd.command == vehicle_command_s::VEHICLE_CMD_DO_SET_SERVO || cmd.command == vehicle_command_s::VEHICLE_CMD_DO_CHANGE_SPEED) {continue; }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

以上cmd屬于高優(yōu)先級(jí),直接利用continue跳出本次循環(huán),進(jìn)行下一次循環(huán)
continue表示進(jìn)行下一次循環(huán),只管for、while,不看if,不管多少if都直接無(wú)視

③switch (cmd.command)
cmd來(lái)自

case vehicle_command_s::VEHICLE_CMD_PREFLIGHT_REBOOT_SHUTDOWN: // Request the reboot or shutdown of system components. |0: Do nothing for autopilot, 1: //Reboot autopilot, 2: Shutdown autopilot.| 0: Do nothing for onboard computer, 1: Reboot //onboard computer, 2: Shutdown onboard computer.| Reserved| Reserved| Empty| //Empty| Empty|用answer_command()函數(shù)驅(qū)動(dòng)蜂鳴器不同的音調(diào)回應(yīng)操作命令cmd case vehicle_command_s::VEHICLE_CMD_PREFLIGHT_CALIBRATION: // Trigger calibration. This command will be only accepted if in pre-flight mode. |Gyro //calibration: 0: no, 1: yes| Magnetometer calibration: 0: no, 1: yes| Ground pressure: 0: no, //1: yes| Radio calibration: 0: no, 1: yes| Accelerometer calibration: 0: no, 1: yes| Empty| //Empty|arming_state_transition()根據(jù)cmd.param的值選擇校準(zhǔn)的傳感器 Commander::preflightCheck() arming_state_transition() case vehicle_command_s::VEHICLE_CMD_PREFLIGHT_STORAGE: // Request storage of different parameter values and logs. This command will be only //accepted if in pre-flight mode. |Parameter storage: 0: READ FROM FLASH/EEPROM, 1: //WRITE CURRENT TO FLASH/EEPROM| Mission storage: 0: READ FROM FLASH/EEPROM, 1: //WRITE CURRENT TO FLASH/EEPROM| Reserved| Reserved| Empty| Empty| Empty| cmd.param1=0時(shí),ret = param_load_default(); cmd.param1=1時(shí),ret = param_save_default(); cmd.param1=2時(shí), param_reset_all(); int ret = param_save_default(); case vehicle_command_s::VEHICLE_CMD_START_RX_PAIR:// Starts receiver pairing |0:Spektrum| 0:Spektrum DSM2, 1:Spektrum DSMX|
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16

(9)進(jìn)入循環(huán)while (!thread_should_exit)
[1]orb_check(param_changed_sub, &updated);檢查參數(shù)更新沒(méi)有,若更新了,那么重新get參數(shù)。ORB_ID(parameter_update)來(lái)自src/modules/systemlib/param/param.c、src/modules/systemlib/param/param_shmeem.c
[2]orb_check(sp_man_sub, &updated);
ORB_ID(manual_control_setpoint)來(lái)自src/modules/sensors/rc_update.cpp
[3]orb_check(offboard_control_mode_sub, &updated);
并根據(jù)offboard_control_mode.timestamp給status_flags.offboard_control_signal_lost、status_flags.offboard_control_loss_timeout、status_changed賦值
ORB_ID(offboard_control_mode)來(lái)自src/modules/mavlink/mavlink_reciever.cpp
[4]orb_check(telemetry_subs[i], &updated);//數(shù)傳
//當(dāng)連接了新的數(shù)傳,進(jìn)行系統(tǒng)檢查
Commander::preflightCheck()
hrt_abstime hrt_elapsed_time(const volatile hrt_abstime *then)//計(jì)算上一次到當(dāng)前獲取的時(shí)間戳增量
ORB_ID(telemetry_status)來(lái)自src/modules/mavlink/mavlink_reciever.cpp
[5]orb_check(sensor_sub, &updated);

if (hrt_elapsed_time(&baro_timestamp) < FAILSAFE_DEFAULT_TIMEOUT)
  • 1

//根據(jù)兩次獲取氣壓計(jì)數(shù)據(jù)的時(shí)間差判斷status_flags.barometer_failure
//單獨(dú)檢查氣壓計(jì),是因?yàn)闅鈮河?jì)檢測(cè)的絕對(duì)海拔高度,與其他的空中操作不相關(guān)
ORB_ID(sensor_combined)來(lái)自src/modules/sensors/sensors.cpp
[6]orb_check(diff_pres_sub, &updated);//空速計(jì)用于VTOL的固定翼模式

check_valid(diff_pres.timestamp, DIFFPRESS_TIMEOUT, true, &(status_flags.condition_airspeed_valid), &status_changed);
  • 1

根據(jù)兩次獲取空速計(jì)數(shù)據(jù)的時(shí)間差判斷status_flags.condition_airspeed_valid
ORB_ID(differential_pressure)來(lái)自src/drivers/ets_airspeed/ets_airspeed.cpp、src/drivers/meas_airspeed/meas_airspeed.cpp
[7]orb_check(system_power_sub, &updated);
根據(jù)system_power結(jié)構(gòu)體判斷status_flags.condition_power_input_valid
如果USB移除,但仍然接著電源,發(fā)布警告“重新啟動(dòng)”
判斷是否連接了USB,status_flags.usb_connected = _usb_telemetry_active
_usb_telemetry_active來(lái)自于數(shù)傳的結(jié)構(gòu)體

/* set (and don't reset) telemetry via USB as active once a MAVLink connection is up */ if (telemetry.type == telemetry_status_s::TELEMETRY_STATUS_RADIO_TYPE_USB) {_usb_telemetry_active = true; }
  • 1
  • 2
  • 3
  • 4

ORB_ID(system_power)來(lái)自src/drivers/stm32adc/adc.cpp
[8]orb_check(safety_sub, &updated);//安全開關(guān)
//如果安全開關(guān)被打開(鎖定飛機(jī))而此時(shí)飛機(jī)處于解鎖狀態(tài),那么飛機(jī)利用arming_state_transition()上鎖
//根據(jù)安全開關(guān)狀態(tài)更新,控制閃光和蜂鳴器,示意操作者
ORB_ID(safety)來(lái)自src/drivers/px4io/px4io.cpp(v2版本)、src/drivers/px4fmu/px4fmu.cpp(v4版本)
[9]orb_check(vtol_vehicle_status_sub, &updated);
判斷是否是VTOL,如果是,那么將vtol_status結(jié)構(gòu)體賦值給status和status_flags
ORB_ID(vtol_vehicle_status)來(lái)自src/modules/votl_att_control/votl_att_control.cpp
[10]orb_check(global_position_sub, &updated);
根據(jù)status_flags.condition_global_position_valid和gpos.eph情況,判斷是否orb_copy(ORB_ID(vehicle_global_position), global_position_sub, &global_position);
根據(jù)兩次獲取global_position數(shù)據(jù)的時(shí)間差判斷status_flags.condition_global_position_valid
ORB_ID(vehicle_global_position)來(lái)自src/modules/ekf2/ekf2_main.cpp或src/modules/position_estmator_inav/position_estmator_inav_main.cpp或src/modules/local_position_estmator/local_position_estmator_main.cpp
[11]orb_check(local_position_sub, &updated);
orb_copy(ORB_ID(vehicle_local_position), local_position_sub, &local_position);
根據(jù)兩次獲取local_position數(shù)據(jù)的時(shí)間差,同時(shí)需要綜合local_position.xy_valid && local_eph_good和local_position.z_valid,判斷condition_local_position_valid和condition_local_altitude_valid

check_valid(local_position.timestamp, POSITION_TIMEOUT, local_position.xy_valid&& local_eph_good, &(status_flags.condition_local_position_valid), &status_changed); check_valid(local_position.timestamp, POSITION_TIMEOUT, local_position.z_valid,&(status_flags.condition_local_altitude_valid), &status_changed);
  • 1
  • 2
  • 3
  • 4

ORB_ID(vehicle_local_position)來(lái)自src/modules/ekf2/ekf2_main.cpp或src/modules/position_estmator_inav/position_estmator_inav_main.cpp或src/modules/local_position_estmator/local_position_estmator_main.cpp
[12]orb_check(attitude_sub, &updated);
orb_copy(ORB_ID(vehicle_attitude), attitude_sub, &attitude);
ORB_ID(vehicle_attitude)來(lái)自src/modules/ekf2/ekf2_main.cpp或src/modules/attitude_estmator_q/attitude_estmator_q_main.cpp或src/modules/local_position_estmator/local_position_estmator_main.cpp或
[13]orb_check(land_detector_sub, &updated);
根據(jù)上一次以及當(dāng)前的land和fall狀態(tài)判斷應(yīng)該發(fā)送什么mavlink信息

was_landed = land_detector.landed; was_falling = land_detector.freefall;
  • 1
  • 2

自動(dòng)上鎖。滯后時(shí)間是param_get(_param_disarm_land, &disarm_when_landed),若為起飛狀態(tài),但沒(méi)有及時(shí)起飛,5倍的disarm_when_landed時(shí)間后自動(dòng)上鎖。
ORB_ID(vehicle_land_detected)來(lái)自src/modules/land_detector/LandDetector.cpp
[14]orb_check(cpuload_sub, &updated);
orb_copy(ORB_ID(cpuload), cpuload_sub, &cpuload);
ORB_ID(cpuload)來(lái)自src/modules/load_mon/load_mon.cpp
[15]orb_check(battery_sub, &updated);
根據(jù)電池警告的標(biāo)志

battery.warning == battery_status_s::BATTERY_WARNING_LOW battery.warning == battery_status_s::BATTERY_WARNING_CRITICAL
  • 1
  • 2

做不同的處理,其中battery.warning來(lái)自src/modules/systemlib/battery.cpp

Battery::determineWarning() {// Smallest values must come firstif (_remaining < _param_crit_thr.get()) {_warning = battery_status_s::BATTERY_WARNING_CRITICAL;} else if (_remaining < _param_low_thr.get()) {_warning = battery_status_s::BATTERY_WARNING_LOW;} }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

根據(jù)armed.armed、low_bat_action的狀態(tài),也就是飛機(jī)正處于什么樣的低電壓飛行狀態(tài),采取main_state_transition()將飛機(jī)飛行狀態(tài)轉(zhuǎn)變成commander_state_s::MAIN_STATE_AUTO_RTL或commander_state_s::MAIN_STATE_AUTO_LAND
其中l(wèi)ow_bat_action來(lái)自param_get(_param_low_bat_act, &low_bat_action);(此處分析,這些param參數(shù)是會(huì)實(shí)時(shí)改變的,不一定是用戶實(shí)現(xiàn)全部設(shè)定好了的,不然也不需要放在while (!thread_should_exit) {}循環(huán)里面)
ORB_ID(battery_status)來(lái)自src/drivers/px4io/px4io.cpp
[16]orb_check(subsys_sub, &updated);
將info結(jié)構(gòu)體變量賦值給status.onboard_control_sensors_present、status.onboard_control_sensors_enabled、status.onboard_control_sensors_health
ORB_ID(subsystem_info)來(lái)自airspeed、px4flow等傳感器驅(qū)動(dòng)
[17]orb_check(pos_sp_triplet_sub, &updated);
如果處于init狀態(tài),那么嘗試解鎖arming_state_transition()進(jìn)入standby狀態(tài)
ORB_ID(position_setpoint_triplet) 來(lái)自src/modules/navigator/navigator_main.cpp
[18]orb_check(gps_sub, &updated);
如果沒(méi)有初始化&&GPS精度可用&&兩次數(shù)據(jù)采集時(shí)間在1s內(nèi),使用globallocalconverter_init()函數(shù)里的map_projection_global_init(lat_0, lon_0, timestamp)將經(jīng)緯度的球面地圖到平面直角坐標(biāo)地圖
為什么需要使用投影函數(shù)?
地球橢球體表面是曲面,為了將球面坐標(biāo)轉(zhuǎn)換成平面坐標(biāo),而轉(zhuǎn)換時(shí)首先要把曲面展為平面。然而球面是個(gè)不可展的曲面,換句話說(shuō),就是把它直接展為平面時(shí),不可能不發(fā)生破裂或皺紋,于是需要地圖投影理論,也就構(gòu)成了map_projection()函數(shù)。
http://blog.sciencenet.cn/blog-99337-651267.html
http://baike.baidu.com/link?url=VtAENt2GBYLoYXnTxSfHFxARu9rsQacqT3EMAYitm3bd1nvfngwBKsiasR1lSoluFZlY2G4fQ5wNBnXb7AF6115lPSxz8iTYdbnbNklxAoAjn35Nb3VK2AQd8-bBZrsq
根據(jù)gpsIsNoisy、gps_position.fix_type、hrt_elapsed_time(&gps_position.timestamp)判斷status_flags.gps_failure和status_changed
ORB_ID(vehicle_gps_position)來(lái)自src/drivers/gps/gps.cpp
[19]orb_check(mission_result_sub, &updated);
更新status.mission_failure(status.mission_failure = _mission_result.mission_failure;)
ORB_ID(mission_result)來(lái)自src/drivers/navigator/navigator_main.cpp
[20]orb_check(geofence_result_sub, &updated); 地理圍欄
地理圍欄是指當(dāng)飛機(jī)進(jìn)入、離開某個(gè)特定地理區(qū)域,或在該區(qū)域內(nèi)活動(dòng)時(shí),操作者可以自動(dòng)接收通知和警告。
根據(jù)geofence_result.geofence_action的情況分別采取如下動(dòng)作:none、warn、主狀態(tài)轉(zhuǎn)變?yōu)閘oiter、主狀態(tài)轉(zhuǎn)變?yōu)閞tl、armed.force_failsafe = true。
更新geofence_loiter_on、geofence_rtl_on,如果不在loiter/rtl模式或手動(dòng)轉(zhuǎn)換到loiter/rtl模式時(shí),該標(biāo)志位復(fù)位。
如果緊急動(dòng)作激活了&&在rtl模式之前處于手動(dòng)和協(xié)助模式下,此時(shí)遙控?fù)u桿撥動(dòng)了,那么回到rtl模式之前的模式
ORB_ID(geofence_result)來(lái)自src/drivers/navigator/navigator_main.cpp
[21]根據(jù)_mission_result.flight_termination和counter(記錄commander循環(huán)次數(shù))發(fā)送警告信息。
根據(jù)_mission_result.valid通過(guò)tune_mission_fail()和tune_mission_ok()指示操作者。_mission_result.instance_count是任務(wù)的實(shí)例數(shù),任務(wù)改變時(shí)單調(diào)增加。只有在確定home點(diǎn)之后才評(píng)估任務(wù)完成的狀態(tài),這樣可以避免任務(wù)拒絕的誤報(bào)。
[22]遙控輸入的處理
①上鎖解鎖
根據(jù)是否有操作者上鎖或解鎖的命令(可以是遙控?fù)u桿左下/右下,檔位開關(guān))和旋翼機(jī)是否在MANUAL, Rattitude, or AUTO_READY 模式下(固定翼是否在land模式下),判斷是否運(yùn)行arming_state_transition()函數(shù)以完成鎖定狀態(tài)status->arming_state的更新。
②根據(jù)遙控模式選擇開關(guān)評(píng)估飛機(jī)的主狀態(tài)
transition_result_t main_res = set_main_state_rc(&status);
如果手動(dòng)模式設(shè)定沒(méi)有更改,那么不運(yùn)行手動(dòng)模式設(shè)定更改了的代碼,只需要_last_sp_man結(jié)構(gòu)體=sp_man結(jié)構(gòu)體,因?yàn)榕袛嗪髸?huì)運(yùn)行return TRANSITION_NOT_CHANGED(函數(shù)中無(wú)論什么地方,遇到return函數(shù)就結(jié)束了);
sp_man.offboard_switch開關(guān)如果打開了,那么運(yùn)行main_state_transition()函數(shù),飛機(jī)主狀態(tài)轉(zhuǎn)變?yōu)閏ommander_state_s::MAIN_STATE_OFFBOARD;
sp_man.return_switch開關(guān)如果打開了,那么運(yùn)行main_state_transition()函數(shù),飛機(jī)主狀態(tài)轉(zhuǎn)變?yōu)閏ommander_state_s::MAIN_STATE_AUTO_RTL,如果轉(zhuǎn)變?yōu)閞tl,那么降級(jí)轉(zhuǎn)變?yōu)閏ommander_state_s::MAIN_STATE_AUTO_LOITER;
如果sp_man.mode_slot != manual_control_setpoint_s::MODE_SLOT_NONE,那么利用main_state_transition()函數(shù)將飛機(jī)主狀態(tài)轉(zhuǎn)變?yōu)開flight_mode_slots[sp_man.mode_slot],其中_flight_mode_slots[sp_man.mode_slot]來(lái)自

param_get(_param_fmode_1, &_flight_mode_slots[0]); param_get(_param_fmode_2, &_flight_mode_slots[1]); param_get(_param_fmode_3, &_flight_mode_slots[2]); param_get(_param_fmode_4, &_flight_mode_slots[3]); param_get(_param_fmode_5, &_flight_mode_slots[4]); param_get(_param_fmode_6, &_flight_mode_slots[5]);
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

如果轉(zhuǎn)變不了,那么降級(jí)轉(zhuǎn)變

MAIN_STATE_AUTO_MISSION==>MAIN_STATE_AUTO_LOITER MAIN_STATE_AUTO_RTL==>MAIN_STATE_AUTO_LOITER MAIN_STATE_AUTO_LAND==>MAIN_STATE_AUTO_LOITER MAIN_STATE_AUTO_TAKEOFF==>MAIN_STATE_AUTO_LOITER MAIN_STATE_AUTO_FOLLOW_TARGET==>MAIN_STATE_AUTO_LOITER MAIN_STATE_AUTO_LOITER==>MAIN_STATE_POSCTL MAIN_STATE_POSCTL==>MAIN_STATE_ALTCTL MAIN_STATE_ALTCTL==>MAIN_STATE_STAB MAIN_STATE_STAB==>MAIN_STATE_MANUAL
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
如果offboard and RTL開關(guān)off或denied,那么檢查sp_man.mode_switch,sp_man.mode_switch可分為SWITCH_POS_OFF(MANUAL)、SWITCH_POS_MIDDLE(ASSIST)、SWITCH_POS_ON(AUTO)
  • 1
  • 2

sp_man.mode_switch= SWITCH_POS_OFF(MANUAL) 時(shí),由sp_man.acro_switch、sp_man.rattitude_switch兩個(gè)開關(guān)選擇模式
sp_man.mode_switch= SWITCH_POS_MIDDLE(ASSIST)時(shí),由sp_man.posctl_switch選擇模式
sp_man.loiter_switch= SWITCH_POS_ON(AUTO) 時(shí),由sp_man.loiter_switch選擇模式
里面的邏輯為,其中也包含了降級(jí)策略(如果不能轉(zhuǎn)變成想要的狀態(tài),那么轉(zhuǎn)變成與其最接近的狀態(tài),還不能轉(zhuǎn)變,再下一級(jí))


set_main_state_rc ()返回TRANSITION_DENIED、TRANSITION_CHANGED 、TRANSITION_NOT_CHANGED,并且根據(jù)遙控器指令將internal_state->main_state賦予新的狀態(tài)。
根據(jù)set_main_state_rc()是否能轉(zhuǎn)變飛行模式,發(fā)送指示給操作者。
檢測(cè)油門鎖定開關(guān)(Set to true if actuators are forced to being disabled (due to emergency or HIL)),根據(jù)檢測(cè)sp_man.kill_switch 狀態(tài),確定armed.manual_lockdown狀態(tài)。
③若遙控信息丟失,那么status.rc_signal_lost = true,記錄下當(dāng)前的時(shí)間戳rc_signal_lost_timestamp = sp_man.timestamp;
[23]檢測(cè)無(wú)線數(shù)傳的數(shù)據(jù)鏈?zhǔn)欠襁B接
for (int i = 0; i < ORB_MULTI_MAX_INSTANCES; i++) {…}循環(huán)四次,輸出have_link狀態(tài)量,根據(jù)have_link 確定status.data_link_lost狀態(tài)量
循環(huán)里if(telemetry_last_heartbeat[i] != 0 && hrt_elapsed_time(&telemetry_last_heartbeat[i]) < datalink_loss_timeout * 1e6)符合該條件表示數(shù)據(jù)鏈連接了
循環(huán)里if (telemetry_lost[i] && hrt_elapsed_time(&telemetry_last_dl_loss[i]) > datalink_regain_timeout * 1e6) 符合該條件表示上次數(shù)據(jù)鏈?zhǔn)菙嚅_的
[24] orb_check(actuator_controls_sub, &updated);
針對(duì)固定翼機(jī)型檢測(cè)發(fā)動(dòng)機(jī)是否有故障。
actuator_controls主題包含actuator_controls_0、actuator_controls_1、actuator_controls_2、actuator_controls_3
ORB_ID_VEHICLE_ATTITUDE_CONTROLS來(lái)自于
或,分析如下

#define ORB_ID_VEHICLE_ATTITUDE_CONTROLS ORB_ID(actuator_controls_0)
旋翼機(jī)型中
_actuators_id = ORB_ID(actuator_controls_0);
orb_publish(_actuators_id, _actuators_0_pub, &_actuators);
vtol機(jī)型中
orb_publish(ORB_ID(actuator_controls_0), _actuators_0_pub, &_actuators_out_0);
[25]orb_check(cmd_sub, &updated);
ORB_ID(vehicle_command)來(lái)自或也就是接收數(shù)傳指令,遠(yuǎn)距離在地面站中傳輸操作者指令

handle_command(&status, &safety, &cmd, &armed, &_home, &global_position, &local_position,&attitude, &home_pub, &command_ack_pub, &command_ack, &_roi, &roi_pub)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
bool handle_command(struct vehicle_status_s *status_local, const struct safety_s *safety_local,struct vehicle_command_s *cmd, struct actuator_armed_s *armed_local,struct home_position_s *home, struct vehicle_global_position_s *global_pos,struct vehicle_local_position_s *local_pos, struct vehicle_attitude_s *attitude, orb_advert_t *home_pub,orb_advert_t *command_ack_pub, struct vehicle_command_ack_s *command_ack,struct vehicle_roi_s *roi, orb_advert_t *roi_pub) switch (cmd->command) { case vehicle_command_s::VEHICLE_CMD_DO_REPOSITION: case vehicle_command_s::VEHICLE_CMD_DO_SET_MODE: case vehicle_command_s::VEHICLE_CMD_COMPONENT_ARM_DISARM: case vehicle_command_s::VEHICLE_CMD_OVERRIDE_GOTO: case vehicle_command_s::VEHICLE_CMD_DO_FLIGHTTERMINATION: case vehicle_command_s::VEHICLE_CMD_DO_SET_HOME: case vehicle_command_s::VEHICLE_CMD_NAV_GUIDED_ENABLE: case vehicle_command_s::VEHICLE_CMD_NAV_RETURN_TO_LAUNCH: case vehicle_command_s::VEHICLE_CMD_NAV_TAKEOFF: case vehicle_command_s::VEHICLE_CMD_NAV_LAND: case vehicle_command_s::VEHICLE_CMD_DO_SET_ROI: case vehicle_command_s::VEHICLE_CMD_MISSION_START:
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26

每個(gè)case是一個(gè)大類,同時(shí)根據(jù)傳入的cmd->param,調(diào)用main_state_transition()轉(zhuǎn)變飛行模式,轉(zhuǎn)變結(jié)果賦值給cmd_result,最后調(diào)用answer_command(*cmd, cmd_result, *command_ack_pub, *command_ack)回應(yīng)操作者。
[26]如果數(shù)據(jù)鏈(無(wú)線數(shù)傳)和GPS工作故障了,并且飛行器不在手動(dòng)模式(MAIN_STATE_MANUAL、MAIN_STATE_ACRO、MAIN_STATE_RATTITUDE、MAIN_STATE_STAB、MAIN_STATE_ALTCTL、MAIN_STATE_POSCTL)那么結(jié)束飛行
如果遙控和GPS工作故障了,并且飛行器在手動(dòng)模式,那么結(jié)束飛行
[27]commander_set_home_position()
這個(gè)函數(shù)初始化飛行器的home點(diǎn)的位置,此函數(shù)運(yùn)行在第一次得到fix的GPS信號(hào)時(shí)和每次解鎖時(shí)(并且此時(shí)GPS為fix狀態(tài))
[28]

bool nav_state_changed = set_nav_state(&status,&armed,&internal_state,&mavlink_log_pub, (link_loss_actions_t)datalink_loss_act, _mission_result.finished, _mission_result.stay_in_failsafe, &status_flags, land_detector.landed, (link_loss_actions_t)rc_loss_act, offboard_loss_act, offboard_loss_rc_act);
  • 1
  • 2
  • 3
  • 4
bool set_nav_state(struct vehicle_status_s *status,struct actuator_armed_s *armed,struct commander_state_s *internal_state,orb_advert_t *mavlink_log_pub,const link_loss_actions_t data_link_loss_act,const bool mission_finished,const bool stay_in_failsafe,status_flags_s *status_flags,bool landed,const link_loss_actions_t rc_loss_act,const int offb_loss_act,const int offb_loss_rc_act)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
bool set_nav_state(struct vehicle_status_s *status,struct actuator_armed_s *armed,struct commander_state_s *internal_state,orb_advert_t *mavlink_log_pub,const link_loss_actions_t data_link_loss_act,const bool mission_finished,const bool stay_in_failsafe,status_flags_s *status_flags,bool landed,const link_loss_actions_t rc_loss_act,const int offb_loss_act,const int offb_loss_rc_act)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

status:導(dǎo)航狀態(tài),飛行器應(yīng)該進(jìn)入的狀態(tài);
?internal_state: 主狀態(tài),用戶想要的狀態(tài);
?data_link_loss_enabled:與地面站的數(shù)據(jù)鏈丟失;
?mission_finished: 任務(wù)完成;
?stay_in_failsafe:故障保護(hù);
?status_flags:commander內(nèi)部的狀態(tài)標(biāo)志;
?landed: 著陸;
?rc_loss_enabled:遙控信號(hào)丟失;
?offb_loss_act:
?offb_loss_rc_act:

檢查故障和internal_state->main_state,按照降級(jí)策略,給status->nav_state賦狀態(tài)status->nav_state用于navigator.cpp。
一般情況為:
①global位置有效 && 起飛點(diǎn)(home)有效 && GPS有效
進(jìn)入NAVIGATION_STATE_AUTO_**RCRECOVER**模式
②local位置有效 && GPS有效
進(jìn)入NAVIGATION_STATE_AUTO_**LAND**模式(自動(dòng)降落)
③local高度有效
進(jìn)入NAVIGATION_STATE_**DESCEND**模式(無(wú)位置控制的下降模式)
④終止飛行
進(jìn)入NAVIGATION_STATE_**TERMINATION**模式
[29]set_control_mode()
根據(jù)status->nav_state,確定control_mode結(jié)構(gòu)體的狀態(tài),用于mc_att_control.cpp和mc_pos_control.cpp
[30]最后做一些指示信號(hào)、發(fā)布一些主題就可以終止commander進(jìn)程了。

總結(jié)

以上是生活随笔為你收集整理的pixhawk px4 commander.cpp的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

麻豆影视在线免费观看 | 精品久久影院 | 久久婷婷一区二区三区 | 91精品在线免费视频 | 国产五月天婷婷 | 久久精品高清 | 久久网页| 婷婷国产在线 | 国产精品乱码久久久久 | 日日天天狠狠 | 成x99人av在线www| 国产高清免费av | 久久99免费视频 | 亚洲性少妇性猛交wwww乱大交 | 亚洲成人二区 | 99国产成+人+综合+亚洲 欧美 | 日日爱夜夜爱 | 免费av网站在线看 | 黄色一级在线观看 | 超碰成人免费电影 | 国产日韩精品在线 | 午夜久久福利视频 | 精品国产人成亚洲区 | 久久精品国产成人 | 中文永久字幕 | 亚洲va天堂va欧美ⅴa在线 | 久久伊人操 | 婷婷久久五月天 | 亚洲 精品在线视频 | 天天天天色综合 | 午夜三级影院 | 亚洲涩涩网站 | 国产97色 | 天天狠狠| 国产自偷自拍 | 久热av在线 | 91在线播放国产 | 女人18片 | 欧美福利在线播放 | 精品久久久网 | 成人在线免费看视频 | 欧美大香线蕉线伊人久久 | 久草在线免费看视频 | 亚洲欧美色婷婷 | 国内精品亚洲 | 国产第一页在线播放 | 国产天天爽 | 国产黄色成人av | 免费在线观看av网站 | 久久久久9999亚洲精品 | 91在线精品观看 | 色免费在线 | 97精品一区二区三区 | 免费在线观看不卡av | 手机成人在线 | 欧美大片aaa | 天天草天天干 | 免费看三级黄色片 | 亚洲欧洲精品久久 | 成人小视频免费在线观看 | 国产免费久久精品 | 国产小视频在线观看免费 | 欧美色图另类 | 国产视频精品视频 | 免费h漫在线观看 | 国产精品ssss在线亚洲 | 99国产视频在线 | 97成人在线免费视频 | 久久久久观看 | 日韩影视大全 | 中文字幕 国产 一区 | 成人免费观看a | 在线国产能看的 | 四虎永久免费在线观看 | 久久久亚洲电影 | 国产午夜免费视频 | 精品国产视频一区 | 天天操夜夜看 | 日韩黄色在线 | 国产精品入口66mio女同 | 亚洲视屏 | 日日麻批40分钟视频免费观看 | 国产成人99久久亚洲综合精品 | 日韩乱码在线 | 亚洲免费不卡 | 伊人伊成久久人综合网站 | 91成人精品 | 国产三级国产精品国产专区50 | 午夜三级理论 | 婷婷黄色片 | 五月天国产精品 | 久久夜视频 | 色综合天天狠天天透天天伊人 | 成人av一区二区三区 | 日韩精品电影在线播放 | 中文字幕第 | 顶级欧美色妇4khd | 日韩免费三区 | 在线影视 一区 二区 三区 | 九九三级毛片 | 免费的黄色的网站 | 久久免费电影网 | 日韩一区二区免费播放 | 国产精品爽爽久久久久久蜜臀 | 精品国产欧美一区二区 | 久久久久国产精品免费免费搜索 | 又黄又爽又无遮挡的视频 | 欧美一二区在线 | 国产精品自产拍 | 久操视频在线播放 | 永久精品视频 | 最近日本mv字幕免费观看 | 欧美国产日韩一区 | 午夜国产一区二区 | 婷婷色在线 | 亚洲爱爱视频 | 天天色官网 | 久久成年人视频 | 香蕉网在线观看 | 91九色在线观看 | 国产一区二区三区 在线 | 欧美日韩在线网站 | 国产小视频在线观看 | a在线播放 | 五月天综合色 | 97在线影院| 亚洲 欧洲 国产 精品 | 午夜视频免费在线观看 | 国产视频在线看 | 天天操天天操天天操 | 97在线精品国自产拍中文 | 国产综合在线观看视频 | 人人爽人人爽 | 久久久久久久影视 | 在线免费观看一区二区三区 | www.日韩免费 | 免费午夜视频在线观看 | 国产一级视频在线观看 | 精品影院一区二区久久久 | 久久精品牌麻豆国产大山 | 日本中文一区二区 | 色.www| 在线岛国av| 久久高清 | 日韩一区二区三免费高清在线观看 | 亚洲一二三久久 | 成人免费视频免费观看 | 国产淫a| 天天插天天 | 五月天久久婷 | 亚洲欧洲中文日韩久久av乱码 | 国产亚洲精品久久久久久 | 五月天久久激情 | 久久久毛片 | 久久久香蕉视频 | 国产精品自产拍在线观看 | 久草观看视频 | 色精品视频 | 亚洲人在线7777777精品 | 日本特黄特色aaa大片免费 | 在线亚洲激情 | 91免费版成人 | 久久综合五月婷婷 | 91视频在线免费观看 | 亚洲欧美怡红院 | 99视频在线观看视频 | 中文字幕国产一区二区 | 99热这里只有精品在线观看 | 成人毛片在线观看视频 | 97在线观看| 亚洲成人av片 | 伊人成人精品 | 国产精品福利在线播放 | 精品一区二区日韩 | 久久久久久久久久久影院 | 在线免费精品视频 | 在线国产激情视频 | 在线免费观看成人 | 人人玩人人添人人 | 最新中文字幕在线观看视频 | av一区二区三区在线观看 | 国产精品美女久久久网av | 视色网站| 四虎永久精品在线 | 国产精品黑丝在线观看 | 麻豆成人精品视频 | 国产精品亚洲人在线观看 | 婷婷色在线视频 | 日韩一区二区三区高清在线观看 | 超碰免费av | 成人免费xxxxxx视频 | 国产 欧美 日本 | 99久久久久久久久 | 麻豆视频入口 | 国产精品久久久久久久久久久免费 | 亚洲欧美精品在线 | 久久亚洲视频 | 欧美精品黑人性xxxx | 久久综合综合久久综合 | 中文字幕免费观看视频 | 在线观看亚洲专区 | 国内精品久久久久影院一蜜桃 | 欧美色操 | 久久五月情影视 | 精品久久久99 | 一级片免费在线 | 国产精品久久在线 | 亚洲在线成人精品 | 综合久久久久久久 | 成人黄色大片 | 成人资源在线观看 | 丁香激情综合 | www免费视频com━ | 欧美一区二区三区四区夜夜大片 | 天堂va在线观看 | 久草视频首页 | 亚洲最新av在线网站 | 91在线免费观看网站 | 日韩久久影院 | 欧美极品在线播放 | 国产成人三级在线 | 夜夜躁狠狠躁日日躁视频黑人 | 激情综合一区 | 成人黄大片视频在线观看 | 天天射天天操天天色 | 国产高清视频免费在线观看 | 天天色天天射天天综合网 | 六月丁香激情综合色啪小说 | 精品视频免费观看 | 天天色天天色天天色 | 成人久久视频 | 亚洲va欧美va人人爽 | 国产成人黄色在线 | 激情五月***国产精品 | 啪啪动态视频 | 国产免费一区二区三区最新6 | 日本h在线播放 | 超碰97免费观看 | 欧美日韩国产色综合一二三四 | 日韩视频在线观看免费 | 久久国产香蕉视频 | 91精品无人成人www | 午夜色场| 麻豆一精品传二传媒短视频 | 日本久久成人中文字幕电影 | 亚洲精品欧美精品 | 亚洲日本国产精品 | 中中文字幕av在线 | 国产欧美精品一区二区三区 | 日韩av一区二区三区在线观看 | 免费在线观看国产黄 | 不卡av电影在线观看 | 日韩区在线观看 | 日本黄色大片免费 | 99精品美女 | 久久精品视频4 | 亚洲欧美日韩国产 | 国产香蕉97碰碰碰视频在线观看 | 在线观看免费观看在线91 | 久久久免费精品 | 日本视频精品 | 91亚洲精品久久久蜜桃借种 | 九九久久久 | 欧洲亚洲女同hd | 亚洲国产日韩欧美 | 九九九热精品免费视频观看网站 | 免费在线播放视频 | 狠狠操.com | 久久久久成人精品 | 国产成人一区二区三区久久精品 | 中文字幕123区 | 日韩午夜大片 | 亚洲天堂自拍视频 | 久久久久久不卡 | 97国产超碰在线 | 91九色性视频 | 精品国产一区二区三区四区在线观看 | 中文字幕色在线视频 | 国模吧一区 | 激情网五月天 | 国产中文字幕一区二区三区 | 亚洲第二色 | av女优中文字幕在线观看 | 久久福利小视频 | 免费看色的网站 | 久久久福利 | 丁香婷婷综合网 | 亚洲日本色 | 色香蕉网 | 国产精品国产亚洲精品看不卡15 | 国产小视频免费观看 | 就要干b| 在线免费观看视频一区 | 少妇搡bbbb搡bbb搡aa | 日本在线中文在线 | 国产剧情一区二区 | 久久久在线观看 | 国产日韩欧美视频在线观看 | 国产一二三精品 | av丝袜制服 | 免费黄色小网站 | 韩国av免费 | 2021av在线 | 日韩精品欧美专区 | 亚洲成av人片在线观看香蕉 | 中文字幕在线免费看 | 高清av不卡| 久久99国产综合精品免费 | 国产免费一区二区三区最新 | 亚洲成av人影院 | 偷拍视频一区 | 国产伦精品一区二区三区… | 开心激情婷婷 | 在线小视频 | 国产亚洲精品电影 | 精品国产精品久久一区免费式 | 久99精品| 91精品国产福利在线观看 | 国产亚洲精品久久久久久大师 | 中文字幕日韩精品有码视频 | 日本在线视频一区二区三区 | 亚洲一级国产 | 亚洲一区二区三区毛片 | 激情网在线观看 | 国产丝袜在线 | 国产精品成人免费精品自在线观看 | 成人在线免费看视频 | 欧美日韩在线观看不卡 | 国产麻豆精品久久一二三 | 色综合 久久精品 | 五月天婷婷在线播放 | 久久久久久久久久免费 | 又紧又大又爽精品一区二区 | 欧美二区在线播放 | 成人教育av | 亚洲成人av在线电影 | 麻豆精品视频在线 | 精品在线观看国产 | 激情欧美一区二区免费视频 | 美女国内精品自产拍在线播放 | 国产日产精品一区二区三区四区 | 国产一线二线三线性视频 | 亚洲理论在线观看 | 欧美日韩伦理在线 | 国产91精品一区二区麻豆网站 | 免费黄色小网站 | 天天综合网久久综合网 | 欧美日韩综合在线观看 | 国产精品久久久久久久久久久免费看 | 午夜精品三区 | 中文字幕在线乱 | 97免费中文视频在线观看 | 国产三级国产精品国产专区50 | 久草免费在线观看 | 国产成人精品久 | 久久综合桃花 | 久久久久成人精品免费播放动漫 | 欧美性天天 | 成全免费观看视频 | 成人 国产 在线 | av在线com | 黄色大全视频 | av电影中文 | 精品久久久久一区二区国产 | 日韩一区二区免费视频 | av高清影院| a在线免费观看视频 | 国际av在线| 日韩黄色在线 | 国产又粗又猛又黄又爽的视频 | 免费亚洲视频在线观看 | 东方av免费在线观看 | 免费三级网 | 丝袜少妇在线 | 99在线精品视频 | 久久综合婷婷综合 | 特级xxxxx欧美 | 99精品国产高清在线观看 | 成人av亚洲| 美女视频黄免费 | 日韩在线激情 | 久久综合欧美精品亚洲一区 | 97精品超碰一区二区三区 | 亚洲精品免费在线视频 | 久久久国产视频 | 色婷婷综合视频在线观看 | 国产高清免费 | av电影 一区二区 | 91精品久久久久久 | 亚洲精品www | 日韩欧美在线观看一区二区 | 激情视频一区 | 国产精品久久久久av福利动漫 | 久久夜夜爽 | www.亚洲精品 | 人人澡av | 日日天天av | 五月香视频在线观看 | 国内精品久久久久久久影视麻豆 | 蜜臀av性久久久久蜜臀aⅴ四虎 | 午夜久久福利视频 | 亚洲精品自拍视频在线观看 | 国产精品麻豆欧美日韩ww | 在线一二三区 | 久久久精品亚洲 | 国产精品99免视看9 国产精品毛片一区视频 | 99欧美| 麻豆成人在线观看 | 欧美精品v国产精品 | 婷婷久久五月天 | av天天色| 欧美日韩中文国产 | 五月婷婷激情六月 | 欧美一二区视频 | 色婷婷88av视频一二三区 | 国产精品毛片久久蜜 | 天天综合网久久综合网 | h视频日本| 成人超碰97| 久久精品99久久久久久2456 | 欧美精品一级视频 | 亚洲欧美日韩精品久久奇米一区 | 天堂av影院 | 国产亚洲视频中文字幕视频 | 欧美精品一区二区三区四区在线 | 婷婷色在线播放 | 日韩免费小视频 | 日韩视| 91激情在线视频 | 麻豆视频在线播放 | 五月天综合色激情 | 天堂在线成人 | 久久高清视频免费 | 男女啪啪免费网站 | 天天天天色综合 | 免费亚洲一区二区 | 久久国产影视 | 免费在线观看av电影 | 国产精品专区h在线观看 | 国产高清免费观看 | 三级免费黄色 | 人人澡人人爽欧一区 | 日韩精品久久中文字幕 | 热久久这里只有精品 | 人人干狠狠干 | 日日操天天操夜夜操 | 色婷婷伊人 | 欧日韩在线视频 | 久久久视频在线 | 久久成 | 久久九九免费 | 天天弄天天干 | 日韩免费观看一区二区 | 91看片在线观看 | 日韩免费视频一区二区 | 天天躁天天躁天天躁婷 | 国产精品一区二区久久精品爱涩 | 免费在线h | 黄色大片免费网站 | 免费精品在线 | 骄小bbw搡bbbb揉bbbb | 亚洲精品免费视频 | 国产午夜在线观看 | 韩日三级av | 深爱激情开心 | 久久久国产精品电影 | 国产韩国精品一区二区三区 | 日本久久精品视频 | 一区二区三区在线免费观看视频 | 亚洲综合射 | 麻豆视频免费看 | 91尤物在线播放 | 欧美日韩中文另类 | www.五月激情.com | 在线精品观看国产 | 九9热这里真品2 | 91丨九色丨国产丨porny精品 | 国产专区日韩专区 | 五月天激情视频在线观看 | 中文字幕在线播放第一页 | 视频91在线| 日本久久久影视 | 超碰97在线人人 | 狠狠干成人综合网 | 亚洲精品久久久蜜臀下载官网 | 国产精品第7页 | 日韩免费视频 | 美女黄久久 | 国产亚洲永久域名 | 精品一区二三区 | 日韩激情视频在线观看 | 亚洲精品美女 | 色婷婷免费| 日韩欧美一级二级 | 国产精品99久久久久人中文网介绍 | 亚洲精品成人av在线 | 欧美有色 | 国产免费人成xvideos视频 | 日日操网站 | 欧美一区二视频在线免费观看 | 国产在线视频资源 | 亚洲免费在线播放视频 | 久久狠狠婷婷 | 五月天网页 | 婷婷四房综合激情五月 | 亚洲精品h | 久久国产精品一区二区三区四区 | 国产一级视频在线免费观看 | 久久综合精品国产一区二区三区 | 免费a视频在线 | 91夫妻自拍| 国产精品免费久久 | www.福利视频 | 九九在线精品视频 | 激情在线网址 | 在线观看黄色大片 | 91高清免费在线观看 | 久久久久久综合 | 国产手机在线观看 | 最新日韩在线观看 | 99久久影院 | 国内精品久久久久久久久久久 | 欧美日韩性视频 | 伊人影院得得 | 久久中文字幕视频 | 国产精品久久久久一区二区三区 | 亚洲精品在线资源 | 不卡的av在线播放 | 亚洲成人av电影 | 久久久亚洲电影 | 亚洲 中文 在线 精品 | 在线观看国产中文字幕 | 91av观看| av黄色一级片 | 日韩精品一区二区三区三炮视频 | 国产精品高潮久久av | 国产91学生粉嫩喷水 | 草久久久久 | 在线看小早川怜子av | 成 人 免费 黄 色 视频 | 国产精品入口66mio女同 | 99久久精品无免国产免费 | 久久99精品国产麻豆婷婷 | 欧美在一区 | 国产精品99久久久 | 青青草国产在线 | 国产视频在线观看一区 | 久久99精品久久久久蜜臀 | 伊人国产女 | 中文字幕av电影下载 | 国产精品视频线看 | 午夜精品一区二区三区在线观看 | 91在线免费播放 | 久草在线费播放视频 | 成人黄色视 | 香蕉视频免费在线播放 | 亚洲欧美乱综合图片区小说区 | 天天色天天搞 | 狠狠的操你 | 在线亚州| 91成人精品一区在线播放69 | 亚洲精品h | 精品欧美一区二区在线观看 | 在线之家免费在线观看电影 | 日日夜操| 欧美日视频 | 丁香花在线视频观看免费 | 91成人亚洲 | 欧美日韩天堂 | 成年人黄色免费视频 | 久久久久在线视频 | 久草在线在线精品观看 | 特黄特色特刺激视频免费播放 | 国产黄色片免费看 | 久久精品8 | 国产成人精品不卡 | 亚洲电影在线看 | 亚洲aⅴ一区二区三区 | 国产精品国产亚洲精品看不卡 | 欧美a免费| 国产在线观看你懂得 | 色亚洲网 | 亚洲天堂网在线观看视频 | 美女福利视频一区二区 | 97精品一区 | 日本精品久久久一区二区三区 | 色综合夜色一区 | 久久99精品久久久久久久久久久久 | 日本在线h| av网址最新 | 激情五月在线视频 | 亚洲男男gⅴgay双龙 | 在线看污网站 | ww亚洲ww亚在线观看 | 日本xxxxav| 日韩中文字幕免费在线观看 | 国产精品无 | 97超碰人人模人人人爽人人爱 | 久久精品视频在线观看 | 亚洲欧洲成人精品av97 | 91精品国产欧美一区二区成人 | 成年人免费电影 | 亚洲精品久久久久999中文字幕 | 精品播放 | 国产视频丨精品|在线观看 国产精品久久久久久久久久久久午夜 | 最新不卡av | 91人人人 | 正在播放久久 | av大全在线 | 成年人免费看的视频 | 亚洲国内精品在线 | 久久国产乱| 亚洲一区二区三区四区精品 | 亚洲欧美日韩一二三区 | 亚洲三级黄 | 日韩视频a | 国产高清不卡一区二区三区 | 国产精品美女久久久久久久 | 在线精品亚洲一区二区 | 国产精品久久在线 | 91成年人网站 | 天天色棕合合合合合合 | www.五月婷| 久色网| 九九久久国产精品 | 国产在线精品播放 | 成人黄色在线观看视频 | 国产精品久久久区三区天天噜 | 999成人网 | 日韩av视屏在线观看 | 欧美亚洲另类在线视频 | 国产成人黄色片 | 人人插人人玩 | 成人免费在线看片 | 综合久久久 | 日韩中文字幕在线不卡 | 国产又粗又猛又色又黄视频 | 国产97色在线 | av免费线看 | 97免费在线观看视频 | 夜夜操天天操 | 能在线观看的日韩av | 欧美国产精品久久久久久免费 | 伊人激情综合 | 久久艹中文字幕 | 欧美aaa大片 | 亚洲激情国产精品 | 五月天色丁香 | 在线免费av观看 | 久久久久久久久国产 | 亚洲精品网页 | av一本久道久久波多野结衣 | 免费看一级特黄a大片 | 国产无套精品久久久久久 | 久久爱综合 | 精品一区二三区 | 精品在线二区 | 亚洲 欧美变态 另类 综合 | 亚洲视频专区在线 | 亚洲午夜不卡 | 日日干网址 | 亚洲国产精品推荐 | 最近日韩中文字幕中文 | 国产精品一区二区三区四 | 日韩性色| 免费福利在线播放 | 欧美成人h版 | 欧美 日韩 性 | 蜜臀av.com | 国产黄a三级 | 最新三级在线 | 亚洲精品中文在线 | 日韩欧美一区二区不卡 | 国产亚洲精品久久久久久 | 一区二区三区四区不卡 | 久久er99热精品一区二区三区 | 亚洲精品午夜一区人人爽 | 成 人 黄 色 视频 免费观看 | 欧美在线视频一区二区三区 | 亚洲精品久久久久中文字幕m男 | 国产一级一片免费播放放 | 一级黄色a视频 | 欧美中文字幕久久 | 蜜臀av在线一区二区三区 | 精品在线视频一区二区三区 | 日韩精品亚洲专区在线观看 | 国产中文字幕大全 | 久久大视频 | 亚洲婷婷免费 | 日韩毛片一区 | 97国产小视频 | 瑞典xxxx性hd极品 | 久久99九九99精品 | 日韩av视屏在线观看 | 免费看日韩 | 精品久久久久久久久久久院品网 | 欧美成年网站 | 亚洲欧美激情精品一区二区 | 欧美在线资源 | 欧美日韩aa | 国产 在线观看 | 亚洲人片在线观看 | 激情丁香婷婷 | 二区三区在线视频 | 91日韩精品视频 | 国产黄a三级三级 | 97成人在线观看视频 | 久久久久久久久免费 | 婷婷色网站 | 97精品国产97久久久久久久久久久久 | 超碰公开在线观看 | 91av综合 | 成人av高清在线观看 | 丁香六月天婷婷 | 久久蜜臀一区二区三区av | 成人黄色大片 | 成人国产精品av | 日本中文一区二区 | 成人在线观看资源 | 久久久久高清毛片一级 | 亚洲成人影音 | 成在线播放| 黄色com| 91九色国产在线 | 久久超 | 日韩中文字幕91 | 男女靠逼app | 中文字幕在线观看完整版 | 狠狠色伊人亚洲综合网站色 | 丁香五月亚洲综合在线 | 国产精品自在欧美一区 | a天堂在线看 | 国产在线视频在线观看 | 天天干天天射天天插 | 国产精品永久免费观看 | av中文字幕在线电影 | 亚洲精品男人的天堂 | 成片免费观看视频 | 91尤物在线播放 | 美州a亚洲一视本频v色道 | 天天综合人人 | 久草视频国产 | 欧美a级片网站 | 97热久久免费频精品99 | 99这里只有久久精品视频 | 日韩免费福利 | 韩国一区二区三区在线观看 | 九九久久影视 | 91在线视频网址 | 久久不射网站 | 在线观看免费av片 | 国产日本在线 | 欧美激情精品 | 国产精品成人免费精品自在线观看 | 亚洲精品视频在线免费播放 | 亚洲天堂网在线视频观看 | av黄色免费网站 | 99这里有精品 | 国产日韩欧美在线一区 | 丁香五月亚洲综合在线 | 国产成人av一区二区三区在线观看 | 天堂av网在线 | 免费在线激情视频 | 香蕉在线影院 | 综合网在线视频 | 久久久综合九色合综国产精品 | 麻豆极品| 99视频精品全部免费 在线 | 日本最新高清不卡中文字幕 | 日韩av中文 | 91毛片在线观看 | 亚洲激精日韩激精欧美精品 | 日韩中文字幕一区 | 黄网在线免费观看 | 外国av网 | 超碰精品在线 | 国产黄a三级三级三级三级三级 | 久草免费手机视频 | 国产在线探花 | 国产精品久久免费看 | 在线综合 亚洲 欧美在线视频 | 97超碰人人澡人人爱学生 | av大全在线免费观看 | 久久久久综合网 | 中文字幕有码在线播放 | 99久久精品免费视频 | 久久久国产网站 | 鲁一鲁影院 | 亚洲黄色高清 | 美女免费黄网站 | 欧美黑人xxxx猛性大交 | 免费观看黄色12片一级视频 | 91视频久久久久 | 午夜婷婷综合 | 日本中文在线播放 | 亚洲精品动漫久久久久 | 久久精品影片 | 亚洲在线黄色 | 久久国产精品一区二区三区 | 久草精品视频在线看网站免费 | 一本色道久久精品 | 一区二区三区四区不卡 | 国产高清视频在线观看 | 天天综合网久久 | 日韩二区精品 | 美女视频黄频大全免费 | 天天干天天干天天干天天干天天干天天干 | 国产情侣一区 | 99久热在线精品视频观看 | 久久久福利视频 | av丁香花 | 亚洲精选视频免费看 | 黄色免费电影网站 | 9999精品免费视频 | 亚洲九九影院 | 亚洲欧洲精品一区二区精品久久久 | 97精产国品一二三产区在线 | 日韩aⅴ视频 | 久久爱导航| 欧美亚洲一区二区在线 | 久久久久久高潮国产精品视 | 手机在线欧美 | 久久国产精品免费观看 | 手机在线日韩视频 | 97在线播放视频 | 亚洲影院一区 | 国产精品毛片一区二区 | 97精品国自产拍在线观看 | 美女黄久久 | 999精品网 | 成人免费一级 | 久久精品视频在线免费观看 | 三级在线视频播放 | 毛片一二区 | 青青草国产成人99久久 | 久久爱影视i | www.五月天婷婷.com | 国产一区二区午夜 | 欧美久久久久久久久中文字幕 | 国产呻吟在线 | 久草在线手机观看 | 国产成人91| av资源中文字幕 | 色综合久久88色综合天天免费 | 久久国产手机看片 | 97品白浆高清久久久久久 | 欧美日韩综合在线 | 天天狠狠干 | 亚洲国产成人久久综合 | 尤物97国产精品久久精品国产 | 国产精品久久久久一区二区国产 | 国产精品福利午夜在线观看 | 99精品免费在线观看 | 九九精品久久久 | 日韩欧美国产成人 | 国产剧情一区二区 | 成人黄色片免费看 | 成人视屏免费看 | 国产91成人在在线播放 | 丁香视频全集免费观看 | 九九亚洲精品 | 国产精品久久久亚洲 | 精品久久久久久亚洲综合网站 | 日本黄色大片免费 | 在线观看麻豆av | 午夜精品婷婷 | 欧美另类sm图片 | 国产一卡二卡四卡国 | 欧美久久久一区二区三区 | 日韩理论影院 | 成人久久久精品国产乱码一区二区 | 亚洲精品黄色 | 欧美另类成人 | 久久公开免费视频 | 午夜视频免费在线观看 | 国产又粗又硬又爽视频 | 国产中文字幕网 | 日韩亚洲在线观看 | 91丨九色丨91啦蝌蚪老版 | 伊人久久电影网 | 成人avav| 色婷婷丁香| 又大又硬又黄又爽视频在线观看 | 啪啪免费观看网站 | 中文字幕av全部资源www中文字幕在线观看 | 免费国产ww| 天天激情 | 国产精品一码二码三码在线 | 国产又黄又爽无遮挡 | 国产精品免费成人 | 国产精品久久久久久一区二区三区 | 高清免费在线视频 | 免费网站污| 超碰在线最新地址 | 色黄www小说 | 天天综合成人网 | 久久96国产精品久久99软件 | 伊香蕉大综综综合久久啪 | 射射射av | 亚洲国产色一区 | 日韩精品不卡 | 99精品国产兔费观看久久99 | 国产精品久久久久久久av电影 | 99热高清| 久久优 | 国内小视频 | 久久综合狠狠综合 | 亚洲激情久久 | 日本精品免费看 | 亚洲精品系列 | 中文字幕在线一区二区三区 | 亚洲免费公开视频 | 欧美精品久久久久久久久久久 | 成人黄色小视频 | 婷婷九月激情 | 免费视频久久久 | 欧美一级免费片 | 日韩免费av网址 | 日韩在线一二三区 | 国产福利一区二区三区在线观看 | 夜夜操天天干, | 国产对白av| 久久久久国产一区二区三区四区 | 日本久久成人中文字幕电影 | 欧洲激情在线 | 97色国产 | 97视频在线观看播放 | 欧美一级片在线 | 日韩成人在线一区二区 | 97视频在线观看视频免费视频 | 欧美91成人网| 中文在线免费观看 | 免费a网址 | 国产在线观看不卡 | 99爱这里只有精品 | 亚洲欧美日韩精品久久奇米一区 | 久久一久久 | 国产一区二区在线观看视频 | 一本一本久久aa综合精品 | 日韩中文在线观看 | 992tv人人草| 精品国产乱码一区二区三区在线 | 久久激情婷婷 | 日本韩国精品一区二区在线观看 | 午夜精品视频免费在线观看 | 久久久久久久久久毛片 | 国产精品久久久久aaaa九色 | 国产精品视屏 | 久久黄色网址 | 91成人网在线 | 免费网站看v片在线a | 国产在线播放观看 | 激情综合久久 | 免费福利视频网 | 亚洲 av网站 | 久草在线免费播放 | 日日夜色 | 日本女人在线观看 | 国产精品久久久久久久av大片 | 国产精品av免费在线观看 | 深爱激情综合网 | 黄污网站在线观看 | 91看片网址 | 天天夜操| 国产一区二区精 | 日韩免费视频网站 | 91观看视频 | 开心色插 | 色99导航| 操久| 久久久亚洲国产精品麻豆综合天堂 | 日韩精品免费在线 | 久久久精品国产一区二区电影四季 | 久久国产精品精品国产色婷婷 | 亚洲精品毛片一级91精品 | 四虎国产免费 | 日韩在线不卡av | 久久电影国产免费久久电影 | 国产一区二区三区高清播放 | 欧美日韩国产一区二区三区 | 99久久婷婷国产综合亚洲 | 伊人天天 | 亚洲国产精品久久久久久 | 五月婷婷综 | 国产精品美女久久久久久网站 | 高清av中文字幕 | 欧美日韩xx | 久久久精品福利视频 | 久久国产精品第一页 | 久久免费美女视频 | 波多野结衣动态图 | 色天天综合久久久久综合片 | 国产精品一区二区精品视频免费看 | 丝袜美女在线观看 | 亚洲国产免费 | 麻豆极品| 欧美日韩中字 | 欧美色图亚洲图片 |