- Timestamp:
- Dec 8, 2010 6:35:19 AM (14 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/VBox/Devices/Audio/DevIchIntelHDA.cpp
r34460 r34818 433 433 CODECState Codec; 434 434 uint8_t u8Counter; 435 uint64_t u64BaseTS; 435 436 } INTELHDLinkState, *PINTELHDLinkState; 436 437 … … 461 462 DECLCALLBACK(int)hdaRegReadGCAP(INTELHDLinkState* pState, uint32_t offset, uint32_t index, uint32_t *pu32Value); 462 463 DECLCALLBACK(int)hdaRegReadINTSTS(INTELHDLinkState* pState, uint32_t offset, uint32_t index, uint32_t *pu32Value); 464 DECLCALLBACK(int)hdaRegReadWALCLK(INTELHDLinkState* pState, uint32_t offset, uint32_t index, uint32_t *pu32Value); 463 465 DECLCALLBACK(int)hdaRegWriteINTSTS(INTELHDLinkState* pState, uint32_t offset, uint32_t index, uint32_t pu32Value); 464 466 DECLCALLBACK(int)hdaRegWriteCORBWP(INTELHDLinkState* pState, uint32_t offset, uint32_t index, uint32_t pu32Value); … … 530 532 { 0x00020, 0x00004, 0xC00000FF, 0xC00000FF, hdaRegReadU32 , hdaRegWriteU32 , "INTCTL" , "Interrupt Control" }, 531 533 { 0x00024, 0x00004, 0xC00000FF, 0x00000000, hdaRegReadINTSTS , hdaRegWriteUnimplemented, "INTSTS" , "Interrupt Status" }, 532 //** @todo r=michaln: Are guests really not reading the WALCLK register at all? 533 { 0x00030, 0x00004, 0xFFFFFFFF, 0x00000000, hdaRegReadUnimplemented, hdaRegWriteUnimplemented, "WALCLK" , "Wall Clock Counter" }, 534 { 0x00030, 0x00004, 0xFFFFFFFF, 0x00000000, hdaRegReadWALCLK, hdaRegWriteUnimplemented, "WALCLK" , "Wall Clock Counter" }, 534 535 //** @todo r=michaln: Doesn't the SSYNC register need to actually stop the stream(s)? 535 536 { 0x00034, 0x00004, 0x000000FF, 0x000000FF, hdaRegReadU32 , hdaRegWriteU32 , "SSYNC" , "Stream Synchronization" }, … … 996 997 v |= v ? RT_BIT(31) : 0; 997 998 *pu32Value = v; 999 return VINF_SUCCESS; 1000 } 1001 1002 DECLCALLBACK(int)hdaRegReadWALCLK(INTELHDLinkState* pState, uint32_t offset, uint32_t index, uint32_t *pu32Value) 1003 { 1004 *pu32Value = (uint32_t)((RTTimeNanoTS() - pState->u64BaseTS) * 24) / 100; 998 1005 return VINF_SUCCESS; 999 1006 } … … 1939 1946 else 1940 1947 pThis->hda.pu64RirbBuf = (uint64_t *)RTMemAllocZ(pThis->hda.cbRirbBuf); 1948 1949 pThis->hda.u64BaseTS = RTTimeNanoTS(); 1941 1950 1942 1951 #if 0
Note:
See TracChangeset
for help on using the changeset viewer.