summaryrefslogtreecommitdiff
path: root/util/romcc/tests/simple_test45.c
blob: 5e8d742fa8509070ca9381b0e57904586bcc2117 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
static void spd_set_memclk(void)
{
        unsigned min_cycle_time;
        unsigned device;
	int new_cycle_time, new_latency;
	int index;
	int latency;

        min_cycle_time = 0x50;
	device = 0x50;
	new_cycle_time = 0xa0;
	new_latency = 5;


	latency = 0;
	for(index = 0; index < 3; index++, latency++) {
		unsigned long loops;
		loops = 1000000;
		do {
			unsigned short val;
			val = __builtin_inw(0x10e0);
		} while(--loops);
		if (!loops) {
			continue;
		}

		__builtin_outb(device, 0xe4);
		__builtin_outb(index, 0xe8);

		loops = 1000000;
		while(--loops)
			;
	}
	if (new_latency > 4){
		return;
	}

	if (new_cycle_time > min_cycle_time) {
		min_cycle_time = new_cycle_time;
	}
}