Hyundai longitudinal prerequisites (#22121)
	
		
	
				
					
				
			* panda * bring over changes * dont check car model * remove comment * fix typo * more stuff gated behind long * not * not used * gate that too * try honda tuning * clip accel values * fix up merge * fix stopping * add retry logic around knockout * increase timeout * keep flipping lead bit * true for now * less tuning * update comment * 0.1 s is fine now * merge honda and hyundai knockout * more lead fields * another obj bit * increase timeout * fix stopping flag * only lag compensate for braking * no lead * less tuning * only do knockout if not readonly * try controlling using jerk * tuning * try higher stopping rate * set stopping flag at higher speed * clip upper jerk when stopping * remove comments * tester present 1hz * use positive start accel * 1.0 to maybe improve low speed stuff * no point going over 0 * bump panda * bump panda * revert that change * update refpull/214/head
							parent
							
								
									0dc45eaf1c
								
							
						
					
					
						commit
						c4bac6bd68
					
				
				 13 changed files with 208 additions and 93 deletions
			
			
		| @ -1 +1 @@ | |||||||
| Subproject commit 1befaad8b013209aff58145d006d8d047359797e | Subproject commit dd22fafc3c9f36c9d96dffee5437fb9f56d7ff6d | ||||||
| @ -0,0 +1,34 @@ | |||||||
|  | from selfdrive.car.isotp_parallel_query import IsoTpParallelQuery | ||||||
|  | from selfdrive.swaglog import cloudlog | ||||||
|  | 
 | ||||||
|  | EXT_DIAG_REQUEST = b'\x10\x03' | ||||||
|  | EXT_DIAG_RESPONSE = b'\x50\x03' | ||||||
|  | 
 | ||||||
|  | COM_CONT_RESPONSE = b'' | ||||||
|  | 
 | ||||||
|  | def disable_ecu(logcan, sendcan, bus=0, addr=0x7d0, com_cont_req=b'\x28\x83\x01', timeout=0.1, retry=10, debug=False): | ||||||
|  |   """Silence an ECU by disabling sending and receiving messages using UDS 0x28. | ||||||
|  |   The ECU will stay silent as long as openpilot keeps sending Tester Present. | ||||||
|  | 
 | ||||||
|  |   This is used to disable the radar in some cars. Openpilot will emulate the radar. | ||||||
|  |   WARNING: THIS DISABLES AEB!""" | ||||||
|  |   cloudlog.warning(f"ecu disable {hex(addr)} ...") | ||||||
|  | 
 | ||||||
|  |   for i in range(retry): | ||||||
|  |     try: | ||||||
|  |       query = IsoTpParallelQuery(sendcan, logcan, bus, [addr], [EXT_DIAG_REQUEST], [EXT_DIAG_RESPONSE], debug=debug) | ||||||
|  | 
 | ||||||
|  |       for _, _ in query.get_data(timeout).items(): | ||||||
|  |         cloudlog.warning("communication control disable tx/rx ...") | ||||||
|  | 
 | ||||||
|  |         query = IsoTpParallelQuery(sendcan, logcan, bus, [addr], [com_cont_req], [COM_CONT_RESPONSE], debug=debug) | ||||||
|  |         query.get_data(0) | ||||||
|  | 
 | ||||||
|  |         cloudlog.warning("ecu disabled") | ||||||
|  |         return True | ||||||
|  |     except Exception: | ||||||
|  |       cloudlog.exception("ecu disable exception") | ||||||
|  | 
 | ||||||
|  |     print(f"ecu disable retry ({i+1}) ...") | ||||||
|  |   cloudlog.warning("ecu disable failed") | ||||||
|  |   return False | ||||||
| @ -1 +1 @@ | |||||||
| d8ba159971afb46d9b936517d2911bb9d5cd3377 | 68db6ee0d2afb80b0d271788b3028de6db2da45e | ||||||
					Loading…
					
					
				
		Reference in new issue