Code: Select all
__asm__ __volatile("movl %%cr0, %%eax":"=a"(cr0))::"eax");
It looks right to me, but I am no guru. thankstest.c:57: error: expected ';' before ':' token
Code: Select all
__asm__ __volatile("movl %%cr0, %%eax":"=a"(cr0))::"eax");
It looks right to me, but I am no guru. thankstest.c:57: error: expected ';' before ':' token
Really? I'd assume a DOS/Win port of gcc would expect Intel syntax.Combuster wrote:And as long as you haven't told gcc to use something other than AT&T syntax, it will expect AT&T syntax.
Code: Select all
__asm__ __volatile__("movl %%eax, %%cr0", :: "a" (cr0 | 0x00000001 | 0x40000000 | 0x20000000) : "eax");
If I remove that comma it faults saying:
test.c:66: error: expected ':' or ')' before ',' token
Here is the entire code, after all changes described above have been made:test.c:95: error: can't find a register in class 'AREG' while reloading 'asm'
test.c:58: error: 'asm' operand has impossible constraints
Code: Select all
unsigned int mem_end;
unsigned int bse_end;
void count_memory(void)
{
register unsigned long *mem;
unsigned long mem_count, a;
unsigned short memkb;
unsigned char irq1, irq2;
unsigned long cr0;
/* save IRQ's */
irq1=inb(0x21);
irq2=inb(0xA1);
/* kill all irq's */
outb(0x21, 0xFF);
outb(0xA1, 0xFF);
mem_count=0;
memkb=0;
// store a copy of CR0
__asm__ __volatile("movl %%cr0, %%eax":"=a"(cr0)::"eax");
// invalidate the cache
// write-back and invalidate the cache
__asm__ __volatile__ ("wbinvd");
// plug cr0 with just PE/CD/NW
// cache disable(486+), no-writeback(486+), 32bit mode(386+)
__asm__ __volatile__("movl %%eax, %%cr0" :: "a" (cr0 | 0x00000001 | 0x40000000 | 0x20000000) : "eax");
do
{
memkb++;
mem_count+=1024*1024;
mem=(unsigned long*)mem_count;
a=*mem;
*mem=0x55AA55AA;
// the empty asm calls tell gcc not to rely on whats in its registers
// as saved variables (this gets us around GCC optimisations)
asm("":::"memory");
if(*mem!=0x55AA55AA)
mem_count=0;
else
{
*mem=0xAA55AA55;
asm("":::"memory");
if(*mem!=0xAA55AA55)
mem_count=0;
}
asm("":::"memory");
*mem=a;
}while(memkb<4096 && mem_count!=0);
__asm__ __volatile__("movl %%eax, %%cr0" :: "a" (cr0) : "eax");
mem_end=memkb<<20;
mem=(unsigned long*)0x413;
bse_end=((*mem)&0xFFFF)<<6;
outb(0x21, irq1);
outb(0xA1, irq2);
}