Cmi Ac97 Audio Drivers For Mac
Does not work also for me:. Guest is Windows Seven, I tried both the proposed 'ICH AC97' emulation driver and the 'SoundBlaster 16' emulation driver. Host is Windows XP, or Vista or Seven, all of them configured with WHQL-certified audio drivers (either the drivers from Microsoft itself, or the OEM driver) that support both the SB16 and AC97 specifications. Here is the VBOX.log (no sound in Windows Seven (using Directsound+ICH AC97 driver)) Guest Windows reports that no audio hardware was not detected, most probably the Plug'n play descriptors reported by the emulation driver is not correct or is not correctly virtualized. Windows Update does not seem to provide a driver for Windows 7 x64 for the ICH AC97 hardware emulated. Windows 7 32-bit seems to be able to download a driver from Windows Update that works fine (only tested the RC version). This situation is understandable, since I don't think any real 64-bit capable machine would have had that audio chipset so why would anyone release a driver for it (other than for )?
The Realtek AC97 drivers do install (though they complain about being unsigned) but on my system (Fedora 11 64-bit host) the audio output is crackling and distorted. It sounds like the guys should do one of: -fix the problem with the Realtek AC97 driver and the emulated ICH AC97 -find a different AC97 driver that will install and actually function properly with the emulated hardware -emulate some other hardware like some HDA codec that has native Windows 7 drivers for it available. Or add Windows (all versions, or at least XP, Vista and Seven) in the list of Hosts affected by this bug (I've not tested Linux and Unix hosts). Really, the ICH AC97 driver does not match any one of the hardware plug and play identifiers. Robhancock, can you look at your Device Manager and check which hardware device ID is detected on your installation, does it match any of the hardware id that I gave above? Open the Windows device Manager, click in the Multimedia devices category, select the device, and open its properties.
Ac97 Audio Driver For Xp
Then look for the 'hardware device IDs' or the 'compatible device ID's: this is those IDs that are used y the device manager to accept compatible drivers, and that are also searched online with Windows Update. If, this can explain why Windows Update can find a driver for you, and not for me.
But someone needs to explain then why my 'virtualized' hardware PnP device Ids are different. If you have one of the ID's above, can you point the location where you downloaded the driver? Or say which is the manufacturer and version, as reported in your installed device?
Actually, I can't entirely verify that it works with Windows 7 32-bit final release, but I do have a VM running the Windows 7 release candidate 32-bit and Windows Update was able to find a suitable driver there, for Intel 82801AA AC'97 Audio Controller provided by Microsoft. The listed hardware IDs are the same as you posted.
The actual ac97intc.sys file in the driver is copyright 1998-2001 so it seems a fairly old driver. The 82801AA ICH is very old at this point, it was released with the original Intel 810 chipset in 1999. As I mentioned, no actual 64-bit-capable machine would have had this hardware. The host audio doesn't have anything to do with it, the audio is fully virtualized. (The host audio is HDA on this system.).
Avoid this redirecting link (which generates invalid requests and breaks the download, so that the ZIP file appears corrupted, apparently caused by a broken anti-bot script; I note that the redirector sometimes generates HTTP 500 server errors, or causes the ZIP file to be truncated after just a couple of megabytes). Use instead this direct link which is much more reliable: (30,002,195 bytes) I had already tried this driver. This has just worked once, then failed again after restarting Windows (no more sound). Apparently this driver still has difficulties to find the virtualized hardware. And possibly, this indicates a stability problem in the exposed ICH6 emulation used in, or the driver assumes some behavior (ordering of events? Missing or unexpected interrupt? Forget the erroneous '6' that I added inadvertantly after 'ICH'.
But it's true the the ICO/ICH0 whole chipset has been upgraded since lone to version that did not have the various hardware bugs, so not needing the various workarounds implemented in Windows audio drivers. The only important thing here is that this is an unsupported device, and you cannot expect that it will work today or even less tomorrow. The only thing to do is then to upgrade the emulation to a more recent version. I suggest ICH4, which DOES include a AC'97 audio device supporting HDA, but I absolutely don't know if this changes a lot of things in your current hardware emulation. But if this can work, it will make RealTek audio drivers certainly happier withit, with less unsupported workarounds for old hardware bugs. Yes I've googled all around to find a solution, and still I cannot find any one.
None of the solutions found do really apply to emulations, because all these solutions (using various OEM drivers with various workarounds for the same problems) are only meant to solve variably the same issues in a real hardware (but not in the virtual emulation where they are not at all relevant and where they would finally cause more problems). And yes, sandervl73, I understand that your reply was a joke (a form of disguised critic). I don't want to criticize the way you are programming. But I REALLY cannot understand why you chose to emulate a completely unsupported hardware with known problems (even if you had full documentations about it: these docs are certainly not describing enough details if they do not describe the workarounds that have been impelmented on top of them, because even this documentation was certainly bogous and not reflecting the reality as it was perceived in the old Windows drivers written for that bogous hardware device. (But is there only a single device today, without known hardware bugs/problems? Strange enough, my PC supports both AC97 and HDA (it also supports some old games that just support the SB16 working mode), do you mean that it actually has two parallel devices? Or that one is supported only by its OEM driver building some sort of virtual AC97 interface (AC-Link) on top of HDA?
It seems that for Windows, the WDM driver model does not really make a difference between them: as long as the OEM driver correctly exposes the capabilities, all these will still work fine (the driver are supposed to implement what they claim to support, and Windows will attempt to fill the missing capabilities by using a software emulation, using the other exposed and supposedly working capabilities). ICH/ICH0 was already deprecated 4 or 5 years ago, and its severe bugs were already known when there were still some OEMs trying to paliate them by supporting some drivers using workarounds. Anyway, this still does not explain why the SB16 emulation offered in does not work either. And why do we have to choose either SB16 or ICH/ICH0?
Could'nt these two virtual devices be supported in parallel (for the guest OS, they would be seen as two separate audio devices)? We could as well use checkboxes to enable/disable each audio emulation (including the legacy BEEP device) if you integrated a mixer to merge these audio sources, or if you could use the audio mixer of the underlying host OS (when it can accept that the same process can generate several audio sources visible and controlable separately in the host's mixer, without having to mix these sources yourself in the application).
And when you'll add a HDA virtual emulation, you'll have a fourth audio source to mix. By default, all these virtual devices could be enabled and made visible to the guest OS, so the guest OS can use whatever device it supports, and users will hear sound. They will be able to select/turn off these virtual devices in their guest OS according to their need, or using the audio mixer of the guest to mute some or all of them.
And they'ell be also able to uninstall the 'physical' devices from their guest OS by turning off the emulation when unchecking the associated emulations offered by VBOX in its configuration panel. Robhancock, you said 'It almost certainly doesn't support both.
I think you're misunderstanding how the driver interface works - AC97 vs. HDA is a matter between the driver and the hardware'. This is definitely not what I see in the BIOS settings of one of my PCs where both configurations are possible, so the hardware must certainly support both working modes.
I did not say that this was the same driver to use in Windows. (Such BIOS settings frequently appear when a newer device specification is still not very well supported in older OSes, or when the current driver support for the newer device can cause performance issues, or incompatibilities/instabilities with the current driver model used by the running OS.) And when both are enabled in BIOS settings, in Windows I will just see 2 separate audio devices, each one with its own system ressources (IO ports, interrupts, memory maps, and/or DMA channels) and its own driver, and both are integrated in the Windows audio mixer. 'Dual' audio devices have existed since long now (they have existed even when the SoundBlaster 16 devices appeared, offering either an 8-bit or or 16-bit working mode, or both; in this case, the mixing work was made by the hardware without using CPU ressources to compute a single mono or stereo audio channel.). And you can still install a secondary hardware audio board in any PC, if you wish, without having to disable the primary audio device (for Windows it does not matter if they use different working modes, it can perfectly handle several audio devices), just like you can also install a secondary display device, or a secondary keyboard, or a secondary disk controler, or a secondary USB host controler (many PCs today include several USB host controlers, or use a controler working in 'dual' mode with one virtually connected to the other). Verdyp: The SB16 emulation likely doesn't work for the same reason, nobody ever wrote a 64-bit driver for it because nobody would or could use an SB16 in a 64-bit machine.
As far as a device supporting both HDA and AC97, if that's indeed the case, it's either two PCI functions (logical devices) supported by one device, or two separate devices entirely. It remains that AC97 and HDA are not compatible at all, they use entirely separate drivers and implement entirely different interfaces. Technologov: Given that the Realtek drivers seem to work poorly or not at all for many users I don't think it makes any sense for VBox guys to add them to guest additions when people that really want to try them can install them themselves. The SB16 emulation does not work in the 32-bit version of (running on a 32-bit version of Windows, and hosting a 32-bit version of Windows). So the reason is somewhere else, and the response about missing 64-bit support is not relevant. I even suspect that there's a common bug explaining why.both. the SB16 and ICH emulations are not working as intended.
Are you effectively supporting all the needed ressource mappings (IO ports or mapped memory segments, in various 8/16/32-bit mode, possibly using optional DMA channels, and effectively raising the correct IRQ)? Are the emulated device registers returning the correct flags? Are these registers honoring the correct distinctions between read and write accesses? Are read-write access to registers effectively altering the contents of other related registers? When a register is used to index and remap other registers in the allocated IO space (for example to map audio data buffers in the small IO space before writing to them), is this setting remembered? Are they throwing the expected events (notably IRQs and NMI, but also status flags when not using DMA but just simple polling every time frame)?
Do you support all the needed register access orders used by drivers? Are their reported values updated timely and in order (notably status registers, and pending IRQs once they have been handled in the guest OS, in order to allow freeing buffers in the audio queue)? What happens if the guest OS itself uses its own local virtualization (notably for memory-mapped device registers)?
Are you correctly describing the ressources to the guest and honoring the PCI allocations requested by the guest according to the PCI capabilities that were given? Are you supporting power management states described in the ICH specifications (for powering on the device only when it starts being used), or do you assume that these virtual devices will be always on and that the guest's driver will not verify it? An alternative: can you build your own logical audio device specification for Windows and simplify the interface in you own driver, by using your existing VM entry function, instead of depending on various IO/memory/DMA/IRQ ressources and working modes? This is what Microsoft apparently did in VirtualPC (and it works very well).
This approach would mean that you would have to create and port this driver to various guest OSes (not just Windows, but also MacOSX, Linux, FreeBSD, NetBSD, Solaris, OpenVMS and others that can run on a x86 or IA64 or AMD64-based VM. Using their own developement tools, instead of relying on their existing drivers), otherwise the device will not be enumerated and detected. But at least if this can help solve the problem for Windows hosts, and performance issues caused by a complex PCI/PnP emulation layer. Why did you need to restrict this bug to Win64 guest when closing it?
The same defect also occurs on Win32 host running a Win32 guest, as well as on Win64 host running a Win32 guest. I don't think this is specific to the guest (even if sound works on the same machine using the same version of VBOX installed on the same host OS, to run a 32-bit or 64-bit Linux guest: the difference is only in the subset of the device capabilities used by the guest's driver), but lies somewhere in the host part, i.e. Directly in the device emulation layer implemented in VBox, which does not properly emulate the device it is supposed to emulate. Once again, you've not read the log submitted above which clearly indicates that it is running on a Win32 Host, NOT on a Win64 Host. And here too, the sound does not play (and the guest is ALSO Win32). Everywhere above, I spoke about Win32, you've not read it. Really the bug or limitation is not limited to Win64, and I really think it is on the host, not on the guest (even if there's no more supported device for it, all alternate drivers FOR WIN32 do not work: they fail to detect the hardware, these drivers simply don't run as they fail in their detection (or after the first test where the sound is played only once), then never stops, even if the PCI resources are presented to the guest OS and correctly enumerated and allocated and if there are matching PnP IDs.
This can only be explained by a bug in the device emulation on the host. And exactly the same VM image (containing an installation of either Vista 32-bit or Windows Seven 32-bit) works sucessfully and can play sounds if using that VM image in VirtualPC (which does not use this virtual device but its own different virtual device, visible with its own PnP ID and its own addional guest driver specific to VirtualPC's emulated sound device). The sound also works in a 32-bit installation of Linux in the VM image (which works without change, from within or within VirtualPC and on the same hardware machine).
This can only be explained by differences in the emulation layer of the host, not on the guests as they are strictly identical. (their VM images are exact copies of the same '.VHD' image file: I can switch off where sound does not work, and run the same image in VirtualPC where I get sound, then swith off VirtualPC and restart the same VM image in where sound does not work: is it more convincing?). Well I'd prefer to use to VirtualPC, because is performing much faster and has several other benefits for the integration in the Windows host (it uses less CPU ressources, and less energy, the CPU is also cooler and the CPU fan is not constantly active like in VirtualPC): VirtualPC (unlike ) also cannot run on Windows Seven if there's no hardware support for VMs in the CPU (Microsoft suppressed this support in Windows Seven where VirtualPC is not compatible and has been integrated in Pro and Ultimate version only.). If your host is running Windows Seven in 32-bit mode with a CPU without the VTX support, only works. Does not work at all (it just worked once, when playing the first sound, then never again, without even changing any setting. Windows must have disabled it due to failure, such as loss of an expected event, or the driver itself tweaked itself its own internal settings in the registry).
And, the 'High Definition Audio' driver does not install at all (only the Realtek generic driver produced ONE sound). Anyway, I've converted all my PCs now to Windows 7 host. And I still don't have any sound in a Windows 7 guest (32bit or 64bit), or Windows XP guest (32bit only), or Windows Vista guest (32 bit or 64bit); I only get sound in a Linux guest. I can't try with Virtual PC now, because it is not supported on Windows 7.
Do I need a VirtualServer 2008 host? Certainly no, I won't buy it (and anyway none of my PCs have the support for hardware virtualization, even the msot recent one that I bought 1 month ago, due to ambiguous Intel specifications of its processor which has two distinct models with the same commercial name.
OEM manufacturers like HP or Dell still sell PC without clearly indicating if they support VTX, even if they indicate 'Windows 7 ready' and '64bit version suppported') Could that be caused by lack of hardware virtualization? In that case you'll still need to support it for some time (at least for the next 3 years), because lots of customers will ONLY be able to support paravirtualization (In VirtualPC for Vista, this is what Microsoft chose, using a simple entry to the hypervisor, for its virtual audio device driver).