mirror of
https://github.com/fail0verflow/mini.git
synced 2024-11-06 03:35:13 +01:00
Use symbolic names for SEEPROM pins
This commit is contained in:
parent
683ea6d8eb
commit
4d1a048d42
23
seeprom.c
23
seeprom.c
@ -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();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user