|  |  |  | @ -14,25 +14,28 @@ class CarState(CarStateBase): | 
			
		
	
		
			
				
					|  |  |  |  |     super().__init__(CP) | 
			
		
	
		
			
				
					|  |  |  |  |     can_define = CANDefine(DBC[CP.carFingerprint]['pt']) | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     self.lkas_hud_msg = None | 
			
		
	
		
			
				
					|  |  |  |  |     self.lkas_hud_info_msg = None | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     self.steeringTorqueSamples = deque(TORQUE_SAMPLES*[0], TORQUE_SAMPLES) | 
			
		
	
		
			
				
					|  |  |  |  |     self.shifter_values = can_define.dv["GEARBOX"]["GEAR_SHIFTER"] | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |   def update(self, cp, cp_adas, cp_cam): | 
			
		
	
		
			
				
					|  |  |  |  |     ret = car.CarState.new_message() | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     if self.CP.carFingerprint in [CAR.ROGUE, CAR.XTRAIL]: | 
			
		
	
		
			
				
					|  |  |  |  |     if self.CP.carFingerprint in [CAR.ROGUE, CAR.XTRAIL, CAR.ALTIMA]: | 
			
		
	
		
			
				
					|  |  |  |  |       ret.gas = cp.vl["GAS_PEDAL"]["GAS_PEDAL"] | 
			
		
	
		
			
				
					|  |  |  |  |     elif self.CP.carFingerprint in [CAR.LEAF, CAR.LEAF_IC]: | 
			
		
	
		
			
				
					|  |  |  |  |       ret.gas = cp.vl["CRUISE_THROTTLE"]["GAS_PEDAL"] | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     ret.gasPressed = bool(ret.gas > 3) | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     if self.CP.carFingerprint in [CAR.ROGUE, CAR.XTRAIL]: | 
			
		
	
		
			
				
					|  |  |  |  |     if self.CP.carFingerprint in [CAR.ROGUE, CAR.XTRAIL, CAR.ALTIMA]: | 
			
		
	
		
			
				
					|  |  |  |  |       ret.brakePressed = bool(cp.vl["DOORS_LIGHTS"]["USER_BRAKE_PRESSED"]) | 
			
		
	
		
			
				
					|  |  |  |  |     elif self.CP.carFingerprint in [CAR.LEAF, CAR.LEAF_IC]: | 
			
		
	
		
			
				
					|  |  |  |  |       ret.brakePressed = bool(cp.vl["BRAKE_PEDAL"]["BRAKE_PEDAL"] > 3) | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     if self.CP.carFingerprint in [CAR.ROGUE, CAR.XTRAIL]: | 
			
		
	
		
			
				
					|  |  |  |  |     if self.CP.carFingerprint in [CAR.ROGUE, CAR.XTRAIL, CAR.ALTIMA]: | 
			
		
	
		
			
				
					|  |  |  |  |       ret.brakeLights = bool(cp.vl["DOORS_LIGHTS"]["BRAKE_LIGHT"]) | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     ret.wheelSpeeds.fl = cp.vl["WHEEL_SPEEDS_FRONT"]["WHEEL_SPEED_FL"] * CV.KPH_TO_MS | 
			
		
	
	
		
			
				
					|  |  |  | @ -45,7 +48,11 @@ class CarState(CarStateBase): | 
			
		
	
		
			
				
					|  |  |  |  |     ret.vEgo, ret.aEgo = self.update_speed_kf(ret.vEgoRaw) | 
			
		
	
		
			
				
					|  |  |  |  |     ret.standstill = ret.vEgoRaw < 0.01 | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     if self.CP.carFingerprint == CAR.ALTIMA: | 
			
		
	
		
			
				
					|  |  |  |  |       ret.cruiseState.enabled = bool(cp.vl["CRUISE_STATE"]["CRUISE_ENABLED"]) | 
			
		
	
		
			
				
					|  |  |  |  |     else: | 
			
		
	
		
			
				
					|  |  |  |  |       ret.cruiseState.enabled = bool(cp_adas.vl["CRUISE_STATE"]["CRUISE_ENABLED"]) | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     if self.CP.carFingerprint in [CAR.ROGUE, CAR.XTRAIL]: | 
			
		
	
		
			
				
					|  |  |  |  |       ret.seatbeltUnlatched = cp.vl["HUD"]["SEATBELT_DRIVER_LATCHED"] == 0 | 
			
		
	
		
			
				
					|  |  |  |  |       ret.cruiseState.available = bool(cp_cam.vl["PRO_PILOT"]["CRUISE_ON"]) | 
			
		
	
	
		
			
				
					|  |  |  | @ -55,8 +62,15 @@ class CarState(CarStateBase): | 
			
		
	
		
			
				
					|  |  |  |  |       elif self.CP.carFingerprint == CAR.LEAF_IC: | 
			
		
	
		
			
				
					|  |  |  |  |         ret.seatbeltUnlatched = cp.vl["CANCEL_MSG"]["CANCEL_SEATBELT"] == 1 | 
			
		
	
		
			
				
					|  |  |  |  |       ret.cruiseState.available = bool(cp.vl["CRUISE_THROTTLE"]["CRUISE_AVAILABLE"]) | 
			
		
	
		
			
				
					|  |  |  |  |     elif self.CP.carFingerprint == CAR.ALTIMA: | 
			
		
	
		
			
				
					|  |  |  |  |       ret.seatbeltUnlatched = cp.vl["HUD"]["SEATBELT_DRIVER_LATCHED"] == 0 | 
			
		
	
		
			
				
					|  |  |  |  |       ret.cruiseState.available = bool(cp_adas.vl["PRO_PILOT"]["CRUISE_ON"]) | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     if self.CP.carFingerprint == CAR.ALTIMA: | 
			
		
	
		
			
				
					|  |  |  |  |       speed = cp.vl["PROPILOT_HUD"]["SET_SPEED"] | 
			
		
	
		
			
				
					|  |  |  |  |     else: | 
			
		
	
		
			
				
					|  |  |  |  |       speed = cp_adas.vl["PROPILOT_HUD"]["SET_SPEED"] | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     if speed != 255: | 
			
		
	
		
			
				
					|  |  |  |  |       if self.CP.carFingerprint in [CAR.LEAF, CAR.LEAF_IC]: | 
			
		
	
		
			
				
					|  |  |  |  |         conversion = CV.MPH_TO_MS if cp.vl["HUD_SETTINGS"]["SPEED_MPH"] else CV.KPH_TO_MS | 
			
		
	
	
		
			
				
					|  |  |  | @ -65,7 +79,11 @@ class CarState(CarStateBase): | 
			
		
	
		
			
				
					|  |  |  |  |       speed -= 1  # Speed on HUD is always 1 lower than actually sent on can bus | 
			
		
	
		
			
				
					|  |  |  |  |       ret.cruiseState.speed = speed * conversion | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     if self.CP.carFingerprint == CAR.ALTIMA: | 
			
		
	
		
			
				
					|  |  |  |  |       ret.steeringTorque = cp_cam.vl["STEER_TORQUE_SENSOR"]["STEER_TORQUE_DRIVER"] | 
			
		
	
		
			
				
					|  |  |  |  |     else: | 
			
		
	
		
			
				
					|  |  |  |  |       ret.steeringTorque = cp.vl["STEER_TORQUE_SENSOR"]["STEER_TORQUE_DRIVER"] | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     self.steeringTorqueSamples.append(ret.steeringTorque) | 
			
		
	
		
			
				
					|  |  |  |  |     # Filtering driver torque to prevent steeringPressed false positives | 
			
		
	
		
			
				
					|  |  |  |  |     ret.steeringPressed = bool(abs(sum(self.steeringTorqueSamples) / TORQUE_SAMPLES) > CarControllerParams.STEER_THRESHOLD) | 
			
		
	
	
		
			
				
					|  |  |  | @ -85,6 +103,9 @@ class CarState(CarStateBase): | 
			
		
	
		
			
				
					|  |  |  |  |     can_gear = int(cp.vl["GEARBOX"]["GEAR_SHIFTER"]) | 
			
		
	
		
			
				
					|  |  |  |  |     ret.gearShifter = self.parse_gear_shifter(self.shifter_values.get(can_gear, None)) | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     if self.CP.carFingerprint == CAR.ALTIMA: | 
			
		
	
		
			
				
					|  |  |  |  |       self.lkas_enabled = bool(cp.vl["LKAS_SETTINGS"]["LKAS_ENABLED"]) | 
			
		
	
		
			
				
					|  |  |  |  |     else: | 
			
		
	
		
			
				
					|  |  |  |  |       self.lkas_enabled = bool(cp_adas.vl["LKAS_SETTINGS"]["LKAS_ENABLED"]) | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     self.cruise_throttle_msg = copy.copy(cp.vl["CRUISE_THROTTLE"]) | 
			
		
	
	
		
			
				
					|  |  |  | @ -92,6 +113,7 @@ class CarState(CarStateBase): | 
			
		
	
		
			
				
					|  |  |  |  |     if self.CP.carFingerprint in [CAR.LEAF, CAR.LEAF_IC]: | 
			
		
	
		
			
				
					|  |  |  |  |       self.cancel_msg = copy.copy(cp.vl["CANCEL_MSG"]) | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     if self.CP.carFingerprint != CAR.ALTIMA: | 
			
		
	
		
			
				
					|  |  |  |  |       self.lkas_hud_msg = copy.copy(cp_adas.vl["PROPILOT_HUD"]) | 
			
		
	
		
			
				
					|  |  |  |  |       self.lkas_hud_info_msg = copy.copy(cp_adas.vl["PROPILOT_HUD_INFO_MSG"]) | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
	
		
			
				
					|  |  |  | @ -107,8 +129,6 @@ class CarState(CarStateBase): | 
			
		
	
		
			
				
					|  |  |  |  |       ("WHEEL_SPEED_RL", "WHEEL_SPEEDS_REAR", 0), | 
			
		
	
		
			
				
					|  |  |  |  |       ("WHEEL_SPEED_RR", "WHEEL_SPEEDS_REAR", 0), | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |       ("STEER_TORQUE_DRIVER", "STEER_TORQUE_SENSOR", 0), | 
			
		
	
		
			
				
					|  |  |  |  |       ("STEER_ANGLE", "STEER_ANGLE_SENSOR", 0), | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |       ("DOOR_OPEN_FR", "DOORS_LIGHTS", 1), | 
			
		
	
	
		
			
				
					|  |  |  | @ -128,12 +148,11 @@ class CarState(CarStateBase): | 
			
		
	
		
			
				
					|  |  |  |  |       # sig_address, frequency | 
			
		
	
		
			
				
					|  |  |  |  |       ("WHEEL_SPEEDS_REAR", 50), | 
			
		
	
		
			
				
					|  |  |  |  |       ("WHEEL_SPEEDS_FRONT", 50), | 
			
		
	
		
			
				
					|  |  |  |  |       ("STEER_TORQUE_SENSOR", 100), | 
			
		
	
		
			
				
					|  |  |  |  |       ("STEER_ANGLE_SENSOR", 100), | 
			
		
	
		
			
				
					|  |  |  |  |       ("DOORS_LIGHTS", 10), | 
			
		
	
		
			
				
					|  |  |  |  |     ] | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     if CP.carFingerprint in [CAR.ROGUE, CAR.XTRAIL]: | 
			
		
	
		
			
				
					|  |  |  |  |     if CP.carFingerprint in [CAR.ROGUE, CAR.XTRAIL, CAR.ALTIMA]: | 
			
		
	
		
			
				
					|  |  |  |  |       signals += [ | 
			
		
	
		
			
				
					|  |  |  |  |         ("USER_BRAKE_PRESSED", "DOORS_LIGHTS", 1), | 
			
		
	
		
			
				
					|  |  |  |  |         ("BRAKE_LIGHT", "DOORS_LIGHTS", 1), | 
			
		
	
	
		
			
				
					|  |  |  | @ -159,7 +178,9 @@ class CarState(CarStateBase): | 
			
		
	
		
			
				
					|  |  |  |  |       ] | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |       checks += [ | 
			
		
	
		
			
				
					|  |  |  |  |         ("GAS_PEDAL", 50), | 
			
		
	
		
			
				
					|  |  |  |  |         ("GAS_PEDAL", 100), | 
			
		
	
		
			
				
					|  |  |  |  |         ("CRUISE_THROTTLE", 50), | 
			
		
	
		
			
				
					|  |  |  |  |         ("HUD", 25), | 
			
		
	
		
			
				
					|  |  |  |  |       ] | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     elif CP.carFingerprint in [CAR.LEAF, CAR.LEAF_IC]: | 
			
		
	
	
		
			
				
					|  |  |  | @ -182,11 +203,47 @@ class CarState(CarStateBase): | 
			
		
	
		
			
				
					|  |  |  |  |         ("CRUISE_THROTTLE", 50), | 
			
		
	
		
			
				
					|  |  |  |  |       ] | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     if CP.carFingerprint == CAR.ALTIMA: | 
			
		
	
		
			
				
					|  |  |  |  |       signals += [ | 
			
		
	
		
			
				
					|  |  |  |  |         ("LKAS_ENABLED", "LKAS_SETTINGS", 0), | 
			
		
	
		
			
				
					|  |  |  |  |         ("CRUISE_ENABLED", "CRUISE_STATE", 0), | 
			
		
	
		
			
				
					|  |  |  |  |         ("SET_SPEED", "PROPILOT_HUD", 0), | 
			
		
	
		
			
				
					|  |  |  |  |       ] | 
			
		
	
		
			
				
					|  |  |  |  |       checks += [ | 
			
		
	
		
			
				
					|  |  |  |  |         ("CRUISE_STATE", 10), | 
			
		
	
		
			
				
					|  |  |  |  |         ("LKAS_SETTINGS", 10), | 
			
		
	
		
			
				
					|  |  |  |  |         ("PROPILOT_HUD", 50), | 
			
		
	
		
			
				
					|  |  |  |  |       ] | 
			
		
	
		
			
				
					|  |  |  |  |       return CANParser(DBC[CP.carFingerprint]['pt'], signals, checks, 1) | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     signals += [ | 
			
		
	
		
			
				
					|  |  |  |  |       ("STEER_TORQUE_DRIVER", "STEER_TORQUE_SENSOR", 0), | 
			
		
	
		
			
				
					|  |  |  |  |     ] | 
			
		
	
		
			
				
					|  |  |  |  |     checks += [ | 
			
		
	
		
			
				
					|  |  |  |  |       ("STEER_TORQUE_SENSOR", 100), | 
			
		
	
		
			
				
					|  |  |  |  |     ] | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     return CANParser(DBC[CP.carFingerprint]['pt'], signals, checks, 0) | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |   @staticmethod | 
			
		
	
		
			
				
					|  |  |  |  |   def get_adas_can_parser(CP): | 
			
		
	
		
			
				
					|  |  |  |  |     # this function generates lists for signal, messages and initial values | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     if CP.carFingerprint == CAR.ALTIMA: | 
			
		
	
		
			
				
					|  |  |  |  |       signals = [ | 
			
		
	
		
			
				
					|  |  |  |  |         ("DESIRED_ANGLE", "LKAS", 0), | 
			
		
	
		
			
				
					|  |  |  |  |         ("SET_0x80_2", "LKAS", 0), | 
			
		
	
		
			
				
					|  |  |  |  |         ("MAX_TORQUE", "LKAS", 0), | 
			
		
	
		
			
				
					|  |  |  |  |         ("SET_0x80", "LKAS", 0), | 
			
		
	
		
			
				
					|  |  |  |  |         ("COUNTER", "LKAS", 0), | 
			
		
	
		
			
				
					|  |  |  |  |         ("LKA_ACTIVE", "LKAS", 0), | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |         ("CRUISE_ON", "PRO_PILOT", 0), | 
			
		
	
		
			
				
					|  |  |  |  |       ] | 
			
		
	
		
			
				
					|  |  |  |  |       checks = [ | 
			
		
	
		
			
				
					|  |  |  |  |         ("PRO_PILOT", 100), | 
			
		
	
		
			
				
					|  |  |  |  |       ] | 
			
		
	
		
			
				
					|  |  |  |  |     else: | 
			
		
	
		
			
				
					|  |  |  |  |       signals = [ | 
			
		
	
		
			
				
					|  |  |  |  |         # sig_name, sig_address, default | 
			
		
	
		
			
				
					|  |  |  |  |         ("LKAS_ENABLED", "LKAS_SETTINGS", 0), | 
			
		
	
	
		
			
				
					|  |  |  | @ -278,12 +335,21 @@ class CarState(CarStateBase): | 
			
		
	
		
			
				
					|  |  |  |  |   @staticmethod | 
			
		
	
		
			
				
					|  |  |  |  |   def get_cam_can_parser(CP): | 
			
		
	
		
			
				
					|  |  |  |  |     signals = [] | 
			
		
	
		
			
				
					|  |  |  |  |     checks = [] | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     if CP.carFingerprint in [CAR.ROGUE, CAR.XTRAIL]: | 
			
		
	
		
			
				
					|  |  |  |  |       signals += [ | 
			
		
	
		
			
				
					|  |  |  |  |         ("CRUISE_ON", "PRO_PILOT", 0), | 
			
		
	
		
			
				
					|  |  |  |  |       ] | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     checks = [ | 
			
		
	
		
			
				
					|  |  |  |  |     elif CP.carFingerprint == CAR.ALTIMA: | 
			
		
	
		
			
				
					|  |  |  |  |       signals += [ | 
			
		
	
		
			
				
					|  |  |  |  |         ("STEER_TORQUE_DRIVER", "STEER_TORQUE_SENSOR", 0), | 
			
		
	
		
			
				
					|  |  |  |  |       ] | 
			
		
	
		
			
				
					|  |  |  |  |       checks += [ | 
			
		
	
		
			
				
					|  |  |  |  |         ("STEER_TORQUE_SENSOR", 100), | 
			
		
	
		
			
				
					|  |  |  |  |       ] | 
			
		
	
		
			
				
					|  |  |  |  |       return CANParser(DBC[CP.carFingerprint]['pt'], signals, checks, 0) | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     return CANParser(DBC[CP.carFingerprint]['pt'], signals, checks, 1) | 
			
		
	
	
		
			
				
					|  |  |  | 
 |