@ -10,8 +10,9 @@ from opendbc.can.packer import CANPacker 
			
		
	
		
		
			
				
					
					VisualAlert  =  car . CarControl . HUDControl . VisualAlert VisualAlert  =  car . CarControl . HUDControl . VisualAlert  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					class  CarController ( ) : class  CarController :  
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					  def  __init__ ( self ,  dbc_name ,  CP ,  VM ) :    def  __init__ ( self ,  dbc_name ,  CP ,  VM ) :   
			
		
	
		
		
			
				
					
					    self . frame  =  0   
			
		
	
		
		
			
				
					
					    self . last_steer  =  0      self . last_steer  =  0   
			
		
	
		
		
			
				
					
					    self . alert_active  =  False      self . alert_active  =  False   
			
		
	
		
		
			
				
					
					    self . last_standstill  =  False      self . last_standstill  =  False   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -22,11 +23,13 @@ class CarController(): 
			
		
	
		
		
			
				
					
					    self . gas  =  0      self . gas  =  0   
			
		
	
		
		
			
				
					
					    self . accel  =  0      self . accel  =  0   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  def  update ( self ,  c ,  CS ,  frame ,  actuators ,  pcm_cancel_cmd ,  hud_alert ,    def  update ( self ,  CC ,  CS ) :   
			
				
				
			
		
	
		
		
			
				
					
					             left_line ,  right_line ,  lead ,  left_lane_depart ,  right_lane_depart ) :      actuators  =  CC . actuators   
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					    hud_control  =  CC . hudControl   
			
		
	
		
		
			
				
					
					    pcm_cancel_cmd  =  CC . cruiseControl . cancel   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    # gas and brake      # gas and brake   
			
		
	
		
		
			
				
					
					    if  CS . CP . enableGasInterceptor  and  c . longActive :      if  CS . CP . enableGasInterceptor  and  CC . longActive :   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					      MAX_INTERCEPTOR_GAS  =  0.5        MAX_INTERCEPTOR_GAS  =  0.5   
			
		
	
		
		
			
				
					
					      # RAV4 has very sensitive gas pedal        # RAV4 has very sensitive gas pedal   
			
		
	
		
		
			
				
					
					      if  CS . CP . carFingerprint  in  ( CAR . RAV4 ,  CAR . RAV4H ,  CAR . HIGHLANDER ,  CAR . HIGHLANDERH ) :        if  CS . CP . carFingerprint  in  ( CAR . RAV4 ,  CAR . RAV4H ,  CAR . HIGHLANDER ,  CAR . HIGHLANDERH ) :   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -49,7 +52,7 @@ class CarController(): 
			
		
	
		
		
			
				
					
					    self . steer_rate_limited  =  new_steer  !=  apply_steer      self . steer_rate_limited  =  new_steer  !=  apply_steer   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    # Cut steering while we're in a known fault state (2s)      # Cut steering while we're in a known fault state (2s)   
			
		
	
		
		
			
				
					
					    if  not  c . latActive  or  CS . steer_state  in  ( 9 ,  25 ) :      if  not  CC . latActive  or  CS . steer_state  in  ( 9 ,  25 ) :   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					      apply_steer  =  0        apply_steer  =  0   
			
		
	
		
		
			
				
					
					      apply_steer_req  =  0        apply_steer_req  =  0   
			
		
	
		
		
			
				
					
					    else :      else :   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -57,7 +60,7 @@ class CarController(): 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    # TODO: probably can delete this. CS.pcm_acc_status uses a different signal      # TODO: probably can delete this. CS.pcm_acc_status uses a different signal   
			
		
	
		
		
			
				
					
					    # than CS.cruiseState.enabled. confirm they're not meaningfully different      # than CS.cruiseState.enabled. confirm they're not meaningfully different   
			
		
	
		
		
			
				
					
					    if  not  c . enabled  and  CS . pcm_acc_status :      if  not  CC . enabled  and  CS . pcm_acc_status :   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					      pcm_cancel_cmd  =  1        pcm_cancel_cmd  =  1   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    # on entering standstill, send standstill request      # on entering standstill, send standstill request   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -78,18 +81,18 @@ class CarController(): 
			
		
	
		
		
			
				
					
					    # toyota can trace shows this message at 42Hz, with counter adding alternatively 1 and 2;      # toyota can trace shows this message at 42Hz, with counter adding alternatively 1 and 2;   
			
		
	
		
		
			
				
					
					    # sending it at 100Hz seem to allow a higher rate limit, as the rate limit seems imposed      # sending it at 100Hz seem to allow a higher rate limit, as the rate limit seems imposed   
			
		
	
		
		
			
				
					
					    # on consecutive messages      # on consecutive messages   
			
		
	
		
		
			
				
					
					    can_sends . append ( create_steer_command ( self . packer ,  apply_steer ,  apply_steer_req ,  frame ) )      can_sends . append ( create_steer_command ( self . packer ,  apply_steer ,  apply_steer_req ,  self . frame ) )   
			
				
				
			
		
	
		
		
			
				
					
					    if  frame  %  2  ==  0  and  CS . CP . carFingerprint  in  TSS2_CAR :      if  self . frame  %  2  ==  0  and  CS . CP . carFingerprint  in  TSS2_CAR :   
			
				
				
			
		
	
		
		
			
				
					
					      can_sends . append ( create_lta_steer_command ( self . packer ,  0 ,  0 ,  frame  / /  2 ) )        can_sends . append ( create_lta_steer_command ( self . packer ,  0 ,  0 ,  self . frame  / /  2 ) )   
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    # LTA mode. Set ret.steerControlType = car.CarParams.SteerControlType.angle and whitelist 0x191 in the panda      # LTA mode. Set ret.steerControlType = car.CarParams.SteerControlType.angle and whitelist 0x191 in the panda   
			
		
	
		
		
			
				
					
					    # if frame % 2 == 0:      # if self. frame % 2 == 0:   
			
				
				
			
		
	
		
		
			
				
					
					    #   can_sends.append(create_steer_command(self.packer, 0, 0, frame // 2))      #   can_sends.append(create_steer_command(self.packer, 0, 0, self. frame // 2))   
			
				
				
			
		
	
		
		
			
				
					
					    #   can_sends.append(create_lta_steer_command(self.packer, actuators.steeringAngleDeg, apply_steer_req, frame // 2))      #   can_sends.append(create_lta_steer_command(self.packer, actuators.steeringAngleDeg, apply_steer_req, self. frame // 2))   
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    # we can spam can to cancel the system even if we are using lat only control      # we can spam can to cancel the system even if we are using lat only control   
			
		
	
		
		
			
				
					
					    if  ( frame  %  3  ==  0  and  CS . CP . openpilotLongitudinalControl )  or  pcm_cancel_cmd :      if  ( self . frame  %  3  ==  0  and  CS . CP . openpilotLongitudinalControl )  or  pcm_cancel_cmd :   
			
				
				
			
		
	
		
		
			
				
					
					      lead  =  lead  or  CS . out . vEgo  <  12.      # at low speed we always assume the lead is present so ACC can be engaged        lead  =  hud_control . leadVisible   or  CS . out . vEgo  <  12.   # at low speed we always assume the lead is present so ACC can be engaged   
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					      # Lexus IS uses a different cancellation message        # Lexus IS uses a different cancellation message   
			
		
	
		
		
			
				
					
					      if  pcm_cancel_cmd  and  CS . CP . carFingerprint  in  ( CAR . LEXUS_IS ,  CAR . LEXUS_RC ) :        if  pcm_cancel_cmd  and  CS . CP . carFingerprint  in  ( CAR . LEXUS_IS ,  CAR . LEXUS_RC ) :   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -100,17 +103,17 @@ class CarController(): 
			
		
	
		
		
			
				
					
					      else :        else :   
			
		
	
		
		
			
				
					
					        can_sends . append ( create_accel_command ( self . packer ,  0 ,  pcm_cancel_cmd ,  False ,  lead ,  CS . acc_type ) )          can_sends . append ( create_accel_command ( self . packer ,  0 ,  pcm_cancel_cmd ,  False ,  lead ,  CS . acc_type ) )   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    if  frame  %  2  ==  0  and  CS . CP . enableGasInterceptor  and  CS . CP . openpilotLongitudinalControl :      if  self . frame  %  2  ==  0  and  CS . CP . enableGasInterceptor  and  CS . CP . openpilotLongitudinalControl :   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					      # send exactly zero if gas cmd is zero. Interceptor will send the max between read value and gas cmd.        # send exactly zero if gas cmd is zero. Interceptor will send the max between read value and gas cmd.   
			
		
	
		
		
			
				
					
					      # This prevents unexpected pedal range rescaling        # This prevents unexpected pedal range rescaling   
			
		
	
		
		
			
				
					
					      can_sends . append ( create_gas_interceptor_command ( self . packer ,  interceptor_gas_cmd ,  frame  / /  2 ) )        can_sends . append ( create_gas_interceptor_command ( self . packer ,  interceptor_gas_cmd ,  self . frame  / /  2 ) )   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					      self . gas  =  interceptor_gas_cmd        self . gas  =  interceptor_gas_cmd   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    # ui mesg is at 1Hz but we send asap if:      # ui mesg is at 1Hz but we send asap if:   
			
		
	
		
		
			
				
					
					    # - there is something to display      # - there is something to display   
			
		
	
		
		
			
				
					
					    # - there is something to stop displaying      # - there is something to stop displaying   
			
		
	
		
		
			
				
					
					    fcw_alert  =  hud_a lert  ==  VisualAlert . fcw      fcw_alert  =  hud_control . visualA lert  ==  VisualAlert . fcw   
			
				
				
			
		
	
		
		
			
				
					
					    steer_alert  =  hud_a lert  in  ( VisualAlert . steerRequired ,  VisualAlert . ldw )      steer_alert  =  hud_control . visualA lert  in  ( VisualAlert . steerRequired ,  VisualAlert . ldw )   
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    send_ui  =  False      send_ui  =  False   
			
		
	
		
		
			
				
					
					    if  ( ( fcw_alert  or  steer_alert )  and  not  self . alert_active )  or  \     if  ( ( fcw_alert  or  steer_alert )  and  not  self . alert_active )  or  \  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -121,15 +124,17 @@ class CarController(): 
			
		
	
		
		
			
				
					
					      # forcing the pcm to disengage causes a bad fault sound so play a good sound instead        # forcing the pcm to disengage causes a bad fault sound so play a good sound instead   
			
		
	
		
		
			
				
					
					      send_ui  =  True        send_ui  =  True   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    if  ( frame  %  100  ==  0  or  send_ui ) :      if  self . frame  %  100  ==  0  or  send_ui :   
			
				
				
			
		
	
		
		
			
				
					
					      can_sends . append ( create_ui_command ( self . packer ,  steer_alert ,  pcm_cancel_cmd ,  left_line ,  right_line ,  left_lane_depart ,  right_lane_depart ,  c . enabled ) )        can_sends . append ( create_ui_command ( self . packer ,  steer_alert ,  pcm_cancel_cmd ,  hud_control . leftLaneVisible ,   
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					                                         hud_control . rightLaneVisible ,  hud_control . leftLaneDepart ,   
			
		
	
		
		
			
				
					
					                                         hud_control . rightLaneDepart ,  CC . enabled ) )   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    if  frame  %  100  ==  0  and  CS . CP . enableDsu :      if  self . frame  %  100  ==  0  and  CS . CP . enableDsu :   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					      can_sends . append ( create_fcw_command ( self . packer ,  fcw_alert ) )        can_sends . append ( create_fcw_command ( self . packer ,  fcw_alert ) )   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    # *** static msgs ***      # *** static msgs ***   
			
		
	
		
		
			
				
					
					    for  ( addr ,  cars ,  bus ,  fr_step ,  vl ) in  STATIC_DSU_MSGS :      for  addr ,  cars ,  bus ,  fr_step ,  vl  in  STATIC_DSU_MSGS :   
			
				
				
			
		
	
		
		
			
				
					
					      if  frame  %  fr_step  ==  0  and  CS . CP . enableDsu  and  CS . CP . carFingerprint  in  cars :        if  self . frame  %  fr_step  ==  0  and  CS . CP . enableDsu  and  CS . CP . carFingerprint  in  cars :   
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					        can_sends . append ( make_can_msg ( addr ,  vl ,  bus ) )          can_sends . append ( make_can_msg ( addr ,  vl ,  bus ) )   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    new_actuators  =  actuators . copy ( )      new_actuators  =  actuators . copy ( )   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -137,4 +142,5 @@ class CarController(): 
			
		
	
		
		
			
				
					
					    new_actuators . accel  =  self . accel      new_actuators . accel  =  self . accel   
			
		
	
		
		
			
				
					
					    new_actuators . gas  =  self . gas      new_actuators . gas  =  self . gas   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    self . frame  + =  1   
			
		
	
		
		
			
				
					
					    return  new_actuators ,  can_sends      return  new_actuators ,  can_sends