diff --git a/Models/FlightDeck/a320.flightdeck.xml b/Models/FlightDeck/a320.flightdeck.xml index 2056f527..442c7f43 100644 --- a/Models/FlightDeck/a320.flightdeck.xml +++ b/Models/FlightDeck/a320.flightdeck.xml @@ -462,7 +462,6 @@ select - alt-text-test atc-test audio_att_sgn audio_call_hf2_led @@ -478,19 +477,27 @@ engine_fault_1 engine_fault_2 exped_led - hdg-text-test qnh-test radio_opt_led rudder-trim-test - spd-text-test terr_on_nd_on ver.fmgc + + controls/switches/annun-test + + + + + select + alt-text-test + hdg-text-test + spd-text-test vs-text-test - - controls/switches/annun-test - 1 - + + /FMGC/FCU-working + /controls/switches/annun-test + diff --git a/Models/Instruments/OHpanel/OHpanel.xml b/Models/Instruments/OHpanel/OHpanel.xml index cad8a698..a0363d59 100644 --- a/Models/Instruments/OHpanel/OHpanel.xml +++ b/Models/Instruments/OHpanel/OHpanel.xml @@ -3701,16 +3701,7 @@ 25 - - - systems/electrical/bus/ac-1 - 0 - - - systems/electrical/bus/ac-2 - 0 - - + /systems/electrical/light/rat-emer-gen-fault controls/switches/annun-test 1 diff --git a/Nasal/ECAM/ECAM-controller.nas b/Nasal/ECAM/ECAM-controller.nas index dd0b868b..0cb83edb 100644 --- a/Nasal/ECAM/ECAM-controller.nas +++ b/Nasal/ECAM/ECAM-controller.nas @@ -51,19 +51,21 @@ var warning = { if (me.active == 0) { return; } me.wasActive = 1; lineIndex = 0; - while (lineIndex < 7 and lines[lineIndex].getValue() != "") { + while (lineIndex <= 7 and lines[lineIndex].getValue() != "") { lineIndex = lineIndex + 1; # go to next line until empty line } - if (lineIndex == 7) { + if (lineIndex == 8) { leftOverflow.setBoolValue(1); } elsif (leftOverflow.getBoolValue()) { leftOverflow.setBoolValue(0); } - if (lines[lineIndex].getValue() == "" and me.msg != "" and lineIndex <= 7) { # at empty line. Also checks if message is not blank to allow for some warnings with no displayed msg, eg stall - lines[lineIndex].setValue(me.msg); - linesCol[lineIndex].setValue(me.colour); + if (lineIndex <= 7) { + if (lines[lineIndex].getValue() == "" and me.msg != "") { # at empty line. Also checks if message is not blank to allow for some warnings with no displayed msg, eg stall + lines[lineIndex].setValue(me.msg); + linesCol[lineIndex].setValue(me.colour); + } } }, warnlight: func() { @@ -309,7 +311,7 @@ var ECAM_controller = { } } - if (statusFlag == 1) { + if (statusFlag == 1 and lines[0].getValue() == "") { libraries.SystemDisplay.manCall("sts"); statusFlag = 0; } diff --git a/Nasal/ECAM/ECAM-logic.nas b/Nasal/ECAM/ECAM-logic.nas index 42ecd00f..72f28d7b 100644 --- a/Nasal/ECAM/ECAM-logic.nas +++ b/Nasal/ECAM/ECAM-logic.nas @@ -1058,6 +1058,19 @@ var messages_priority_2 = func { ECAM_controller.warningReset(acBusEssShedAtc); } + if ((athr_offw.clearFlag == 0) and athrWarn.getValue() == 2 and phaseVar != 4 and phaseVar != 8 and phaseVar != 10) { + athr_offw.active = 1; + athr_offw_1.active = 1; + } else { + ECAM_controller.warningReset(athr_offw); + ECAM_controller.warningReset(athr_offw_1); + if (getprop("/it-autoflight/output/athr-warning") == 2) { + setprop("/it-autoflight/output/athr-warning", 0); + setprop("/ECAM/Lower/light/clr", 0); + setprop("/ECAM/warnings/master-caution-light", 0); + } + } + if ((athr_lock.clearFlag == 0) and phaseVar >= 5 and phaseVar <= 7 and getprop("/systems/thrust/thr-locked-alert") == 1) { if (getprop("/systems/thrust/thr-locked-flash") == 0) { athr_lock.msg = " "; @@ -1071,18 +1084,6 @@ var messages_priority_2 = func { ECAM_controller.warningReset(athr_lock_1); } - if ((athr_offw.clearFlag == 0) and athrWarn.getValue() == 2 and phaseVar != 4 and phaseVar != 8 and phaseVar != 10) { - athr_offw.active = 1; - athr_offw_1.active = 1; - } else { - ECAM_controller.warningReset(athr_offw); - ECAM_controller.warningReset(athr_offw_1); - if (getprop("/it-autoflight/output/athr-warning") == 2) { - setprop("/it-autoflight/output/athr-warning", 0); - setprop("/ECAM/Lower/light/clr", 0); - setprop("/ECAM/warnings/master-caution-light", 0); - } - } if ((athr_lim.clearFlag == 0) and getprop("/it-autoflight/output/athr") == 1 and ((getprop("/systems/thrust/eng-out") != 1 and (getprop("/systems/thrust/state1") == "MAN" or getprop("/systems/thrust/state2") == "MAN")) or (getprop("/systems/thrust/eng-out") == 1 and (getprop("/systems/thrust/state1") == "MAN" or getprop("/systems/thrust/state2") == "MAN" or (getprop("/systems/thrust/state1") == "MAN THR" and getprop("/controls/engines/engine[0]/throttle-pos") <= 0.83) or (getprop("/systems/thrust/state2") == "MAN THR" and getprop("/controls/engines/engine[0]/throttle-pos") <= 0.83)))) and (phaseVar >= 5 and phaseVar <= 7)) { athr_lim.active = 1; diff --git a/Nasal/ECAM/ECAM-messages.nas b/Nasal/ECAM/ECAM-messages.nas index 2ee2e3bf..a476031f 100644 --- a/Nasal/ECAM/ECAM-messages.nas +++ b/Nasal/ECAM/ECAM-messages.nas @@ -122,14 +122,8 @@ var warnings = std.Vector.new([ var rud_trim_config_1 = warning.new(msg: " NOT IN T.O. RANGE", colour: "r", aural: 0, light: 0), var park_brk_config = warning.new(msg: "CONFIG PARK BRK ON", colour: "r", aural: 0, light: 0), - # Autopilot + # Autopilot off involuntary var ap_offw = warning.new(msg: "AUTO FLT AP OFF", colour: "r", light: 0), - var athr_offw = warning.new(msg: "AUTO FLT A/THR OFF", colour: "a", aural: 1, light: 1, hasSubmsg: 1), - var athr_offw_1 = warning.new(msg: "-THR LEVERS........MOVE", colour: "c"), - var athr_lock = warning.new(msg: "ENG THRUST LOCKED", colour: "a", aural: 1, light: 1, hasSubmsg: 1), - var athr_lock_1 = warning.new(msg: "-THR LEVERS........MOVE", colour: "c"), - var athr_lim = warning.new(msg: "AUTO FLT A/THR LIMITED", colour: "a", aural: 1, light: 1, hasSubmsg: 1), - var athr_lim_1 = warning.new(msg: "-THR LEVERS........MOVE", colour: "c"), # Cargo smoke var cargoSmokeFwd = warning.new(msg: "SMOKE FWD CARGO SMOKE", colour: "r", aural: 0, light: 0, hasSubmsg: 1), @@ -221,6 +215,14 @@ var warnings = std.Vector.new([ var acBusEssShed = warning.new(msg: "ELEC DC ESS BUS SHED", colour: "a", aural: 1, light: 1), var acBusEssShedAtc = warning.new(msg: " -ATC..............SYS 2", colour: "c"), + # Autothrust + var athr_offw = warning.new(msg: "AUTO FLT A/THR OFF", colour: "a", aural: 1, light: 1, hasSubmsg: 1), + var athr_offw_1 = warning.new(msg: "-THR LEVERS........MOVE", colour: "c"), + var athr_lock = warning.new(msg: "ENG THRUST LOCKED", colour: "a", aural: 1, light: 1, hasSubmsg: 1), + var athr_lock_1 = warning.new(msg: "-THR LEVERS........MOVE", colour: "c"), + var athr_lim = warning.new(msg: "AUTO FLT A/THR LIMITED", colour: "a", aural: 1, light: 1, hasSubmsg: 1), + var athr_lim_1 = warning.new(msg: "-THR LEVERS........MOVE", colour: "c"), + # TCAS FAULT var tcasFault = warning.new(msg: "NAV TCAS FAULT", colour: "a", aural: 1, light: 1), diff --git a/Nasal/FMGC/FCU.nas b/Nasal/FMGC/FCU.nas index ac46f876..b42bbccb 100644 --- a/Nasal/FMGC/FCU.nas +++ b/Nasal/FMGC/FCU.nas @@ -34,6 +34,7 @@ var vertModeInput = props.globals.getNode("/it-autoflight/input/vert", 1); var vsModeInput = props.globals.getNode("/it-autoflight/input/vs", 1); var locArm = props.globals.getNode("/it-autoflight/output/loc-armed", 1); var apprArm = props.globals.getNode("/it-autoflight/output/appr-armed", 1); +var FCUworkingNode = props.globals.initNode("/FMGC/FCU-working", 0, "BOOL"); var FCU = { elecSupply: "", @@ -73,10 +74,12 @@ var FCUController = { me.FCU1.loop(); me.FCU2.loop(); - if (!me.FCU1.failed and !me.FCU2.failed) { + if (!me.FCU1.failed or !me.FCU2.failed) { me.FCUworking = 1; + FCUworkingNode.setValue(1); } else { me.FCUworking = 0; + FCUworkingNode.setValue(0); } notification = nil; diff --git a/Systems/a320-electrical.xml b/Systems/a320-electrical.xml index d94ccaed..c9c235d0 100644 --- a/Systems/a320-electrical.xml +++ b/Systems/a320-electrical.xml @@ -1452,7 +1452,7 @@ - + /systems/electrical/relay/dc-ess-feed-tr/output eq 0 /systems/electrical/bus/ac-1 eq 0 /systems/electrical/bus/ac-2 eq 0