| 
			| 
					
						| Artemisia 
								Full Member     
								Karma: +24/-0
								  Offline 
								Posts: 92
								
								 | 
								|  | 
										
										«  on: June 25, 2024, 01:28:24 PM » |  |  |  | 
 
 Hi, I have been trying lately to do partial OBD2 flashes on VAG MED17 controllers. On older controllers that uses the Inkonsistenz bit check, I was able able to disable it by using the subroutines that are intended for *** device (Development purpose)
 The inkonsistenz bit is reset by a "check programming dependencies" subroutine located in the customer block (CB) which I haven't been able to locate yet
 
 I am wondering if anyone has bothered with this and might want to chime in. I'm seeking any informations or ideas. I'm trying to re-use the VAG subroutine to disable the inkonsistenz bit check and be able to go into ASW when doing partial programming
 
 If anyone have those documents, I would be interested :
 Partielle Flashprogrammierung MEDC17 (VW_AUDI_00155_REQ)
 Partielle Programmierung von UDS−Steuergeräten, Nagler, VW AUDI (VW_AUDI_00127_REQ)
 
 
 |  
						| 
								|  |  
								| « Last Edit: January 05, 2025, 12:18:36 AM by Artemisia » |  Logged | 
 |  |  | 
	|  | 
	| 
			| 
					
						| Artemisia 
								Full Member     
								Karma: +24/-0
								  Offline 
								Posts: 92
								
								 | 
								|  | 
										
										« Reply #2 on: June 25, 2024, 06:14:48 PM » |  |  |  | 
 
 End goal is to be able to flash only the segments I alter to accelerate development on custom subroutine implementations or tuning on the dyno for instance. Going from 10 minutes flashes to 30s - 2 minutes flashes just like the MED17 on MB. I know the solution is to disable the inkonsistenz bit check at startup and I know on development version with ***, there is a subroutine for that and it is stored in the CB. I haven't found it yet and I'm unsure if it is present in the production versions I am also aware VehiCAL offer a live tuning feature, but I'm working wth ME17.5 units (TC1766, TC1767) and there isn't enough cal ram for it to be useful. I also made a flasher and implementing partial flash capability for distributions would be an improvement overall My X problem would be that if I erase and write only 1 segment on a flashing session, the ECU will not boot to normal operation due to the inkonsistenz bit |  
						| 
								|  |  
								| « Last Edit: January 05, 2025, 12:18:21 AM by Artemisia » |  Logged | 
 |  |  | 
	| 
			| 
					
						| prj | 
								|  | 
										
										« Reply #3 on: June 26, 2024, 01:35:36 AM » |  |  |  | 
 
 If it takes you 10 minutes for a full flash on any of these, then you're doing something very wrong.It takes way less time even if you flash raw hex, and even faster if you pack it correctly.
 
 LIVE is not supported on TP2.0.
 There is actually quite a bit of calram, and it is possible to make use of it, but I never bothered to develop it for TP2.0 due to low demand and the people tuning this old stuff not having money to pay for it in the first place.
 |  
						| 
								|  |  
								|  |  Logged | 
 
 |  |  | 
	| 
			| 
					
						| cherry | 
								|  | 
										
										« Reply #4 on: June 26, 2024, 02:18:11 AM » |  |  |  | 
 
 I think every better flashtool will do this from alone. Did you use any commercial tool or only your own stuff?  |  
						| 
								|  |  
								|  |  Logged | 
 |  |  | 
	| 
			| 
					
						| prj | 
								|  | 
										
										« Reply #5 on: June 26, 2024, 02:33:59 AM » |  |  |  | 
 
 I think every better flashtool will do this from alone. Did you use any commercial tool or only your own stuff? 
 Proper commercial flashtool will do calflash only. He wants per sector flashing. Using commercial tools this is only possible in BSL or SBOOT mode, but not OBD. EDIT: That said, he is basing his 10 min flashtime probably on PCMFlash which does a RSA bypass flash every time, in effect flashing the ECU 3 times for each write. Hence with a proper tool that does an unlock a full flash is under 5 minutes and a cal flash is under a minute iirc. |  
						| 
								|  |  
								| « Last Edit: June 26, 2024, 02:52:22 AM by prj » |  Logged | 
 
 |  |  | 
	| 
			| 
					
						| _nameless | 
								|  | 
										
										« Reply #6 on: June 26, 2024, 05:56:30 AM » |  |  |  | 
 
 PCM Flash takes 3 minutes for a full write... Not too sure where you are getting 10min from? Alientech sure, pcm is one of the faster ones imo.   |  
						| 
								|  |  
								|  |  Logged | 
 
 If you are broke or expecting free handouts DO NOT message me. I'll probably put you on blast if you do. |  |  | 
	| 
			| 
					
						| Artemisia 
								Full Member     
								Karma: +24/-0
								  Offline 
								Posts: 92
								
								 | 
								|  | 
										
										« Reply #7 on: June 26, 2024, 01:06:33 PM » |  |  |  | 
 
 Proper commercial flashtool will do calflash only. He wants per sector flashing.Using commercial tools this is only possible in BSL or SBOOT mode, but not OBD.
 
 EDIT:
 That said, he is basing his 10 min flashtime probably on PCMFlash which does a RSA bypass flash every time, in effect flashing the ECU 3 times for each write.
 Hence with a proper tool that does an unlock a full flash is under 5 minutes and a cal flash is under a minute iirc.
 
 Between 7 to 8 minutes to be exact. I do write the first segment 3 times (that's about 1:30). One flash with the original data, second flash with the jump call for RSA bypass. Then I reboot the ECU and do a complete flash of all the segments. That would be on a fresh ECU with RSA active I transfer chunks of 0xFFF with RLE compression. On a unlocked ECU, it takes about 6-7 minutes for a complete flash I think every better flashtool will do this from alone. Did you use any commercial tool or only your own stuff? 
 I did use commercial tool, but for more flexibility, I'm using my own stuff PCM Flash takes 3 minutes for a full write... Not too sure where you are getting 10min from? Alientech sure, pcm is one of the faster ones imo.  
 With PCMFlash on TP2.0, it is about 6-7 minutes |  
						| 
								|  |  
								| « Last Edit: June 26, 2024, 01:11:38 PM by Artemisia » |  Logged | 
 |  |  | 
	| 
			| 
					
						| prj | 
								|  | 
										
										« Reply #8 on: June 26, 2024, 10:52:04 PM » |  |  |  | 
 
 So anyway, XY Problem.
 For calibration use the built in live tuning into the ASW.
 For development, OBD flashing is useless since you're most likely gonna brick the ECU anyway, hence it's much better to flash the ECU in sboot in the first place.
 Also for development most of the code can be tested on the bench.
 |  
						| 
								|  |  
								|  |  Logged | 
 
 |  |  | 
	| 
			| 
					
						| Artemisia 
								Full Member     
								Karma: +24/-0
								  Offline 
								Posts: 92
								
								 | 
								|  | 
										
										« Reply #9 on: June 26, 2024, 11:27:46 PM » |  |  |  | 
 
 So anyway, XY Problem.
 For calibration use the built in live tuning into the ASW.
 For development, OBD flashing is useless since you're most likely gonna brick the ECU anyway, hence it's much better to flash the ECU in sboot in the first place.
 Also for development most of the code can be tested on the bench.
 
 For calibrations, are you refering to the CCP Protocol ? |  
						| 
								|  |  
								|  |  Logged | 
 |  |  | 
	| 
			| 
					
						| elias 
								Full Member     
								Karma: +21/-3
								  Offline 
								Posts: 76
								
								
								
								
								
							 | 
								|  | 
										
										« Reply #10 on: June 27, 2024, 03:56:21 PM » |  |  |  | 
 
 I can give some hints which may or may not be useful:
 I did a similar job for MED9.1, and was able to patch in the functionality for writing only small blocks of the flash.
 
 Start with setting up the code in Ghidra and set up the Memory Map and globals.
 Next step would be to find the entry points in the ASW, just search for the service handler-table which goes like this:
 "<Service-ID>ff ff ff"
 "00 00 00 XX"
 "<Address of corresponding service handler>"
 "00 00 00 00"
 "00 00 00 00"
 
 I know for sure that this table exists in MED9.1 and also in MED17.x. Depending if its a UDS or a KWP over TP20 ECU, the Service ID will be UDS or KWP2000.
 
 There will be multiple instances of this table in the file, one of the is responsible for normal diagnostics, the second one will be for the flashing process. Afterwards, you can look at the documentation which parameters go in and then document the parameters. This will help you to get a overview over the process.
 
 You will notice a lot of calls like this:
 FUNCTION (<eeprom-byte-nr>, buffer1,buffer2) - this is on both MED9 and MED17 the Save/Read Routines for the EEPROM. Document them usign the EEPROM layout mentioned in the FR and you get a overview where its exactly setting this inconsistency byte. Then you can remove the "setting inconsistency process" and you reached your goal. Next step would be to deactivate CRC-Checks to allow to flash small cal-area changes - this is something which i havent done yet.
 
 However there is a catch(at least on MED9.1):
 There is another different code, which is having a completely different style, and being copied to ram and then executed. This is being done to allow to flash the ASW area where this code resides normally. It does not contain this table from above, and uses a lot of crazy If-Statements. They had to cut corners to allow it to fit into the ram. If you spot it(usually a lot of references which do not make sense at all), leave it alone. For my custom code flasher, it was not required, as its only triggered if you use the factory process of flashing.
 
 |  
						| 
								|  |  
								|  |  Logged | 
 |  |  | 
	| 
			| 
					
						| prj | 
								|  | 
										
										« Reply #11 on: June 27, 2024, 11:29:40 PM » |  |  |  | 
 
 The bootloader is always executed from RAM, you can not execute from flash when it is being written. |  
						| 
								|  |  
								|  |  Logged | 
 
 |  |  | 
	| 
			| 
					
						| fastboatster 
								Full Member     
								Karma: +4/-0
								  Offline 
								Posts: 85
								
								
								
								
								
							 | 
								|  | 
										
										« Reply #12 on: June 28, 2024, 02:58:45 PM » |  |  |  | 
 
 I guess Elias is suggesting that these bits are set in the ASW before it shuts down and the control is handed over to the bootloader? On another note, how do you find what exactly is getting loaded into the RAM and when does that happen? I.e., does ASW load it before it shuts down, or more likely, customer block loads it and passes control to it? I am also not happy with factory bootloader, in my case it's MEVD17, there's no compression of any kind and full flash to unlocked ECU is 20 minutes. P.S. well, looks like MED17.5 has a table like below for copying bootloader to RAM:                              PTR_DAT_8000eef8                                XREF[1]:     FUN_8000441a:8000448a(R)  8000eef8 78 45 00 80     addr       DAT_80004578
 PTR_DAT_8000eefc                                XREF[1]:     FUN_8000441a:80004484(R)
 8000eefc 00 14 00 d4     addr       DAT_d4001400                                     = ??
 INT_8000ef00                                    XREF[2]:     FUN_8000441a:8000446c(R),
 FUN_8000441a:80004474(R)
 8000ef00 80 00 00 00     int        80h
 8000ef04 f8 45 00 80     addr       LAB_800045f8
 PTR_DAT_8000ef08                                XREF[1]:     FUN_8000441a:80004484(R)
 8000ef08 00 15 00 d4     addr       DAT_d4001500                                     = ??
 8000ef0c 08 02 00 00     int        208h
 8000ef10 00 48 00 80     addr       LAB_80004800
 8000ef14 c8 0a 00 d0     addr       DAT_d0000ac8                                     = ??
 8000ef18 10 79 00 00     int        7910h
 8000ef1c 10 c1 00 80     addr       LAB_8000c110
 8000ef20 08 17 00 d4     addr       DAT_d4001708                                     = ??
 8000ef24 f8 23 00 00     int        23F8h
 8000ef28 08 e5 00 80     addr       PTR_DAT_8000e508                                 = d400255a
 8000ef2c d8 83 00 d0     addr       DAT_d00083d8                                     = ??
 8000ef30 f0 02 00 00     int        2F0h
 8000ef34 f8 e7 00 80     addr       DAT_8000e7f8                                     = 40h    @
 8000ef38 c8 86 00 d0     addr       DAT_d00086c8                                     = ??
 8000ef3c 00 07 00 00     int        700h
 8000ef40 ff              ??         FFh
 
 MEVD looks similar |  
						| 
								|  |  
								| « Last Edit: June 29, 2024, 12:46:07 PM by fastboatster » |  Logged | 
 |  |  | 
	| 
			| 
					
						| prj | 
								|  | 
										
										« Reply #13 on: June 29, 2024, 01:38:22 AM » |  |  |  | 
 
 Even for MEVD17 you can flash it once and then you can use live tuning after that.I'm adding BMW soon.
 |  
						| 
								|  |  
								|  |  Logged | 
 
 |  |  | 
	| 
			| 
					
						| fastboatster 
								Full Member     
								Karma: +4/-0
								  Offline 
								Posts: 85
								
								
								
								
								
							 | 
								|  | 
										
										« Reply #14 on: June 29, 2024, 11:29:01 AM » |  |  |  | 
 
 Even for MEVD17 you can flash it once and then you can use live tuning after that.I'm adding BMW soon.
 
 that would be great! I'm not changing calibrations at the moment and doing some ugly "custom code" right now, but this still will be helpful. In a mean time, I relocating some parts of the routines I wanted to hijack into CAL area, this way, I don't have to do the entire asw flash too often and make do with quick CAL flashes. perhaps this can be a solution for OPs problem? P.S. when talking about MEVD17, are you talking only about F-series DMEs or are you planning to include E series DMEs as well? |  
						| 
								|  |  
								| « Last Edit: June 29, 2024, 12:34:13 PM by fastboatster » |  Logged | 
 |  |  | 
	|  |