Unique files can be deleted due to alt hash matching

Closed

Logic Issue

setup both the regular and dir2dat rollback dats each in their own folders, then setup RV to use the same destination folder. Dats are: MAME 0.257 Rollback CHDs MAME 0.257 Rollback CHDs (dir2dat) place a copy of the following problematic chd files in the tosort: MAME (v0.145) - csplayh5 csplayh5.chd 204,128,041 bytes V4 CHD external sha1 hash: 462f0884b8cf8566e86b17f1dfd670fbc2bf3a31 internal sha1 hash: ce4883ce1351ce5299e41bfbd9a5ae8078b82b8c MAME (v0.254) - csplayh5 csplayh5.chd 203,229,077 bytes V5 CHD external sha1 hash: 43d8f5071a4e1a0d5758767114f62afa316c369f internal sha1 hash: ce4883ce1351ce5299e41bfbd9a5ae8078b82b8c NOTE: the internal hash is identical for both chd's. Do a L3 (full scan) of those 2 CHD's in the tosort so the internal hashes are stored in the AltSHA1 column. run FIND FIXES and note the matches found for each dat: a) "MAME 0.257 Rollback CHDs" dat: we get 2 matches for each of 0.145 and 0.254 entries. This dat is matching both files based on the INTERNAL SHA1 hash and since the internal hash is identical, we will get 2 copies of the same file. b) "MAME 0.257 Rollback CHDs (dir2dat)" dat: we get two matches here too, but the dat is matching based on the EXTERNAL hash of the files. The v0.145 entry is the V4 CHD, and the 0.254 entry is the V5 CHD, so we will get two different filesizes in this folder. Run FIX FILES and note the following: a) the "MAME 0.257 Rollback CHDs" dat gets processed first as it is first in the list alphabetically. It is matching based on internal SHA1, so: - 1st action is to MOVE the csplayh5.chd (0.145, filesize 204,128,041 bytes) into the romroot folder - 2nd action is to make a copy of the 0.145 CHD as the 0.254 CHD (same filesize of 204,128,041 bytes). These are the only 2 actions on this dat, so this dat is now finished. We now have two identical copies of the V4 CHD in two folders. RV now moves on to process the 2nd dat. b) the "MAME 0.257 Rollback CHDs (dir2dat)" starts its rebuild and as noted before, it is matching CHD's based on the EXTERNAL file hash. RV tries to rebuild the first entry which is the csplayh5.chd with a filesize of 204,128,041. BUT WAIT.. that file already exists in the destination folder since we just rebuilt it! RV errors with a "Rescan needed, File Changed" on that file and rebuilding halts. Close out the error and the scan window. We now have 2 identical CHD's in the "MAME 0.257 Rollback CHDs" folder, and nothing in the "MAME 0.257 Rollback CHDs (dir2dat)" folder. The ToSort folder still has the 0.254 V5 CHD (203,229,077 bytes) in it. RV is confused right now and wants us to rescan the datroot so it can confirm where those files are. Right-click on the top of the romroot tree ("RomVault") and do a SCAN FULL (L3). RV now knows where the CHD's are. Remember the results of step #7? In the "MAME 0.257 Rollback CHDs (dir2dat)", which was previously empty, it now finds the V4 CHD and marks it green. But now it can't find the V5 CHD.. but we know it is in the ToSort folder. Run a FIND FIXES. Now, this is where things get interesting.. noticed what happened? In the "MAME 0.257 Rollback CHDs (dir2dat)" dat, RV has now matched the V5 ROM (203,229,077 bytes) which is sitting in the ToSort, but NOW WANTS TO DELETE THE V4 (204,128,041) CHD from the folder, since it doesn't exist in this dat!! But that V4 CHD belongs to the "MAME 0.257 Rollback CHDs" dat. You should now guess what will start to happen.. but go ahead and run a FIX FILES. a) RV straight up deletes the V4 CHD (204,128,041 bytes) from the 0.254 CHD folder, then b) moves the V5 CHD (203,229,077 bytes) from the ToSort into the 0.254 CHD folder. Wait now.. RomVault says everything is green now! Sweet. BUT.... when you look in the rom folder, there is only one copy of each CHD.. MAME (v0.145) - csplayh5 (V5 CHD, 204,128,041 bytes) MAME (v0.254) - csplayh5 (V4 CHD, 203,229,077 bytes) Right-click on "RomVault" in your dat tree and select "Scan Full" again. Yep.. now the "MAME 0.257 Rollback CHDs" dat is missing a CHD. vvvvvvvvvvv BUG STARTS HERE vvvvvvvvvvv Run FIND FIXES. OK.. it can fix the issue, but when you do, it now OUTRIGHT DELETES the (V4 CHD, 203,229,077 bytes) CHD!!!!!!!!!!!! Go check the rom folder.. it's GONE. WHAT DA FUK!! But RV once again says all 4 CHD's between both dats are GREEN. Let's do one more right-click on the RomVault datroot and do a "Scan Full". Oh no.. the 0.254 CHD is now off the list and no longer green.. because RV deleted it. Now RV is reporting in the "MAME 0.257 Rollback CHDs (dir2dat)" folder that the 0.254 V4 CHD is missing. It's toast. I hope you kept a copy of it, or go download it again from the PD torrent :) All that is left in the destination folder is two folders, MAME (v0.145) - csplayh5 (containing the V5 CHD, 204,128,041 bytes) MAME (v0.254) - csplayh5 (folder is now empty)

1

Silent crash under heavy activity

Closed

Crash

RomVault will sometimes silently crash with no error. This seems to occur most frequently when RomVault is scanning / fixing ROMs and you are also navigating around the UI. Most recently I encountered this error while scanning a 25gb ISO and navigating the MAME set with artwork enabled. The windows event viewer showed the following errors: Application: ROMVault3.exe Framework Version: v4.0.30319 Description: The process was terminated due to an unhandled exception. Exception Info: System.AccessViolationException at System.Windows.Forms.UnsafeNativeMethods.CallWindowProc(IntPtr, IntPtr, Int32, IntPtr, IntPtr) at System.Windows.Forms.NativeWindow.DefWndProc(System.Windows.Forms.Message ByRef) at System.Windows.Forms.ToolTip.WndProc(System.Windows.Forms.Message ByRef) at System.Windows.Forms.ToolTip+ToolTipNativeWindow.WndProc(System.Windows.Forms.Message ByRef) at System.Windows.Forms.NativeWindow.Callback(IntPtr, Int32, IntPtr, IntPtr) at System.Windows.Forms.UnsafeNativeMethods.DispatchMessageW(MSG ByRef) at System.Windows.Forms.Application+ComponentManager.System.Windows.Forms.UnsafeNativeMethods.IMsoComponentManager.FPushMessageLoop(IntPtr, Int32, Int32) at System.Windows.Forms.Application+ThreadContext.RunMessageLoopInner(Int32, System.Windows.Forms.ApplicationContext) at System.Windows.Forms.Application+ThreadContext.RunMessageLoop(Int32, System.Windows.Forms.ApplicationContext) at ROMVault.Program.Main() And a few seconds later this error occurred: Faulting application name: ROMVault3.exe, version: 1.0.0.0, time stamp: 0x642596db Faulting module name: comctl32.dll, version: 5.82.19041.1110, time stamp: 0x3e15b9f6 Exception code: 0xc0000005 Fault offset: 0x000000000003d300 Faulting process id: 0x118b0 Faulting application start time: 0x01d96b5d42b97c39 Faulting application path: C:\Emulation\ROMVault3\ROMVault3.exe Faulting module path: C:\WINDOWS\WinSxS\amd64_microsoft.windows.common-controls_6595b64144ccf1df_5.82.19041.1110_none_792d1c772443f647\comctl32.dll Report Id: 43417e29-a0a0-44fd-a6e6-1d310d3e7d0d Faulting package full name: Faulting package-relative application ID:

0

Duplicate directories can occur in the cache

RV 3.6.0

Case Sensitivity Issue

Under certain circumstances, RomVault can have duplicate directory references stored in the cache resulting in frequent "rescan needed" errors when trying to fix roms. This issue occurs in mixed OS setups when the source files are on a case sensitive filesystem and RomVault is running on Windows. A common scenario would be a Linux based NAS for hosting roms exported via a SMB share with case-sensitivity enabled. Note that even though case-sensitive SMB exports are enabled, Windows can still only access a single version of a directory of the same name. For example: "TestFolder" and "TESTFOLDER" could both be viewable in Windows Explorer, but navigating into each would actually only show you the contents of "TestFolder". This behavior appears to be contributing to this bug. Steps to reproduce: Setup an RV instance on Windows Add a ToSort that points to a case-sensitive filesystem Add a directory to that ToSort with a few files in it, for example "TestFolder" Scan the ToSort and notice the files are properly scanned Add another directory in the ToSort with the same name but different case, for example "TESTFOLDER" Scan the ToSort and notice the new directory is also scanned, but the contents are the same as the first directory in step 3, even if the files are different from the directory in step 5 Delete one of the directories on the case sensitive filesystem mimicking a user's attempt to resolve the case-sensitive conflict Rescan the ToSort and notice that both folders still remain, but are normalized to the case of the remaining name From this point, there is no way to clean the cache with RomVault, the user must completely rename the bad directory to something and rescan the contents Screenshots: Duplicate folders with different case Orphaned duplicate folders

1

Powered by Convas