Use symbolic names for SEEPROM pins

This commit is contained in:
marcan 2009-03-06 05:22:22 +01:00 committed by bushing
parent 683ea6d8eb
commit 4d1a048d42

View File

@ -2,6 +2,7 @@
#include "utils.h" #include "utils.h"
#include "hollywood.h" #include "hollywood.h"
#include "start.h" #include "start.h"
#include "gpio.h"
#define gpio_delay() udelay(100) #define gpio_delay() udelay(100)
@ -11,13 +12,13 @@ void send_bits(int b, int bits)
while(bits--) while(bits--)
{ {
if(b & (1 << bits)) if(b & (1 << bits))
set32(HW_GPIO1OUT, 0x1000); set32(HW_GPIO1OUT, GP_EEP_MOSI);
else else
clear32(HW_GPIO1OUT, 0x1000); clear32(HW_GPIO1OUT, GP_EEP_MOSI);
gpio_delay(); gpio_delay();
set32(HW_GPIO1OUT, 0x800); set32(HW_GPIO1OUT, GP_EEP_CLK);
gpio_delay(); gpio_delay();
clear32(HW_GPIO1OUT, 0x800); clear32(HW_GPIO1OUT, GP_EEP_CLK);
gpio_delay(); gpio_delay();
} }
} }
@ -28,11 +29,11 @@ int recv_bits(int bits)
while(bits--) while(bits--)
{ {
res <<= 1; res <<= 1;
set32(HW_GPIO1OUT, 0x800); set32(HW_GPIO1OUT, GP_EEP_CLK);
gpio_delay(); gpio_delay();
clear32(HW_GPIO1OUT, 0x800); clear32(HW_GPIO1OUT, GP_EEP_CLK);
gpio_delay(); gpio_delay();
res |= !!(read32(HW_GPIO1IN) & 0x2000); res |= !!(read32(HW_GPIO1IN) & GP_EEP_MISO);
} }
return res; return res;
} }
@ -46,17 +47,17 @@ int seeprom_read(void *dst, int offset, int size)
if(size & 1) if(size & 1)
return -1; return -1;
clear32(HW_GPIO1OUT, 0x800); clear32(HW_GPIO1OUT, GP_EEP_CLK);
clear32(HW_GPIO1OUT, 0x400); clear32(HW_GPIO1OUT, GP_EEP_CS);
gpio_delay(); gpio_delay();
for(i = 0; i < size; ++i) for(i = 0; i < size; ++i)
{ {
set32(HW_GPIO1OUT, 0x400); set32(HW_GPIO1OUT, GP_EEP_CS);
send_bits((0x600 | (offset + i)), 11); send_bits((0x600 | (offset + i)), 11);
recv = recv_bits(16); recv = recv_bits(16);
*ptr++ = recv; *ptr++ = recv;
clear32(HW_GPIO1OUT, 0x400); clear32(HW_GPIO1OUT, GP_EEP_CS);
gpio_delay(); gpio_delay();
} }