corrected all dummyreads to use volatile pointers. Thanks Marcus Overhagen for reading along.
git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@13082 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
3b10d8ead3
commit
081f461390
@ -1264,7 +1264,7 @@ static void nv_start_dma(void)
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* dummy read the first adress of the framebuffer to flush MTRR-WC buffers */
|
/* dummy read the first adress of the framebuffer to flush MTRR-WC buffers */
|
||||||
dummy = *((uint32 *)(si->framebuffer));
|
dummy = *((volatile uint32 *)(si->framebuffer));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* actually start DMA to execute all commands now in buffer */
|
/* actually start DMA to execute all commands now in buffer */
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/* Read initialisation information from card */
|
/* Read initialisation information from card */
|
||||||
/* some bits are hacks, where PINS is not known */
|
/* some bits are hacks, where PINS is not known */
|
||||||
/* Author:
|
/* Author:
|
||||||
Rudolf Cornelissen 7/2003-5/2005
|
Rudolf Cornelissen 7/2003-6/2005
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define MODULE_BIT 0x00002000
|
#define MODULE_BIT 0x00002000
|
||||||
@ -1916,10 +1916,10 @@ static void setup_ram_config_nv10_up(uint8* rom)
|
|||||||
/* reset first RAM adress */
|
/* reset first RAM adress */
|
||||||
((uint32 *)si->framebuffer)[0x00] = 0x00000000;
|
((uint32 *)si->framebuffer)[0x00] = 0x00000000;
|
||||||
/* dummyread first RAM adress four times */
|
/* dummyread first RAM adress four times */
|
||||||
dummy = ((uint32 *)si->framebuffer)[0x00];
|
dummy = ((volatile uint32 *)si->framebuffer)[0x00];
|
||||||
dummy = ((uint32 *)si->framebuffer)[0x00];
|
dummy = ((volatile uint32 *)si->framebuffer)[0x00];
|
||||||
dummy = ((uint32 *)si->framebuffer)[0x00];
|
dummy = ((volatile uint32 *)si->framebuffer)[0x00];
|
||||||
dummy = ((uint32 *)si->framebuffer)[0x00];
|
dummy = ((volatile uint32 *)si->framebuffer)[0x00];
|
||||||
/* check testpattern to have survived */
|
/* check testpattern to have survived */
|
||||||
if (((uint32 *)si->framebuffer)[(data >> 2)] == 0x4e564441) stat = B_OK;
|
if (((uint32 *)si->framebuffer)[(data >> 2)] == 0x4e564441) stat = B_OK;
|
||||||
cnt++;
|
cnt++;
|
||||||
@ -1958,13 +1958,13 @@ static void setup_ram_config_nv28(uint8* rom)
|
|||||||
/* reset first RAM adress */
|
/* reset first RAM adress */
|
||||||
((uint32 *)si->framebuffer)[0x00000000] = 0x00000000;
|
((uint32 *)si->framebuffer)[0x00000000] = 0x00000000;
|
||||||
/* dummyread first RAM adress four times */
|
/* dummyread first RAM adress four times */
|
||||||
dummy = ((uint32 *)si->framebuffer)[0x00000000];
|
dummy = ((volatile uint32 *)si->framebuffer)[0x00000000];
|
||||||
LOG(8,("INFO: (#%d) dummy1 = $%08x, ", cnt, dummy));
|
LOG(8,("INFO: (#%d) dummy1 = $%08x, ", cnt, dummy));
|
||||||
dummy = ((uint32 *)si->framebuffer)[0x00000000];
|
dummy = ((volatile uint32 *)si->framebuffer)[0x00000000];
|
||||||
LOG(8,("dummy2 = $%08x, ", dummy));
|
LOG(8,("dummy2 = $%08x, ", dummy));
|
||||||
dummy = ((uint32 *)si->framebuffer)[0x00000000];
|
dummy = ((volatile uint32 *)si->framebuffer)[0x00000000];
|
||||||
LOG(8,("dummy3 = $%08x, ", dummy));
|
LOG(8,("dummy3 = $%08x, ", dummy));
|
||||||
dummy = ((uint32 *)si->framebuffer)[0x00000000];
|
dummy = ((volatile uint32 *)si->framebuffer)[0x00000000];
|
||||||
LOG(8,("dummy4 = $%08x\n", dummy));
|
LOG(8,("dummy4 = $%08x\n", dummy));
|
||||||
/* check testpattern to have survived */
|
/* check testpattern to have survived */
|
||||||
if (((uint32 *)si->framebuffer)[0x01fc0000] == 0x4e564441) stat = B_OK;
|
if (((uint32 *)si->framebuffer)[0x01fc0000] == 0x4e564441) stat = B_OK;
|
||||||
|
Loading…
Reference in New Issue
Block a user