http://bugs.winehq.org/show_bug.cgi?id=9444
--- Comment #13 from Dan Kegel dank@kegel.com 2011-10-27 13:12:39 CDT --- Same as before. Log at failure:
trace:msi:MSI_ProcessMessage (nil) (nil) (nil) 0 10 L"Action start 10:56:57: ForceReboot." trace:msi:msiobj_release object 0xee9370 destroyed trace:msi:ACTION_ForceReboot Reboot command L"C:\windows\system32\MsiExec.exe /@ "0BF6FDCFA57A3D11F9E9000972175E37"" trace:msi:MSI_ProcessMessage 4000000 trace:msi:MSI_ProcessMessage (nil) (nil) (nil) 0 10 L"Action ended 10:56:57: ForceReboot. Return value 1604." err:msi:ITERATE_Actions Execution halted, action L"ForceReboot" returned 1604
And, um, this seems completely expected. ACTION_ForceReboot *always* returns #define ERROR_INSTALL_SUSPEND 1604
MSI_InstallPackage even expects ERROR_INSTALL_SUSPEND and handles it.
So maybe the line in ITERATE_Actions is crying wolf? if (rc != ERROR_SUCCESS) ERR("Execution halted, action %s returned %i\n", debugstr_w(action), rc); and somebody who knows MSI well needs to take a look at the full log, attached.