mirror of
https://github.com/silenty4ng/uv-k5-firmware-chinese-lts
synced 2025-01-24 19:24:48 +00:00
eeproom
This commit is contained in:
parent
f57f344672
commit
6e35fb8ea1
4 changed files with 58 additions and 95 deletions
|
@ -22,12 +22,8 @@
|
||||||
<component name="ChangeListManager">
|
<component name="ChangeListManager">
|
||||||
<list default="true" id="cea36e80-e289-4d69-9030-7186d540ac0e" name="更改" comment="中英文字符对齐">
|
<list default="true" id="cea36e80-e289-4d69-9030-7186d540ac0e" name="更改" comment="中英文字符对齐">
|
||||||
<change beforePath="$PROJECT_DIR$/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" />
|
<change beforePath="$PROJECT_DIR$/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" />
|
||||||
<change beforePath="$PROJECT_DIR$/Makefile" beforeDir="false" afterPath="$PROJECT_DIR$/Makefile" afterDir="false" />
|
<change beforePath="$PROJECT_DIR$/driver/eeprom.c" beforeDir="false" afterPath="$PROJECT_DIR$/driver/eeprom.c" afterDir="false" />
|
||||||
<change beforePath="$PROJECT_DIR$/driver/bk4819.c" beforeDir="false" afterPath="$PROJECT_DIR$/driver/bk4819.c" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/font.h" beforeDir="false" afterPath="$PROJECT_DIR$/font.h" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/main.c" beforeDir="false" afterPath="$PROJECT_DIR$/main.c" afterDir="false" />
|
<change beforePath="$PROJECT_DIR$/main.c" beforeDir="false" afterPath="$PROJECT_DIR$/main.c" afterDir="false" />
|
||||||
<change beforePath="$PROJECT_DIR$/settings.c" beforeDir="false" afterPath="$PROJECT_DIR$/settings.c" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/uv-k5font/font_new/font.cpp" beforeDir="false" afterPath="$PROJECT_DIR$/uv-k5font/font_new/font.cpp" afterDir="false" />
|
|
||||||
</list>
|
</list>
|
||||||
<option name="SHOW_DIALOG" value="false" />
|
<option name="SHOW_DIALOG" value="false" />
|
||||||
<option name="HIGHLIGHT_CONFLICTS" value="true" />
|
<option name="HIGHLIGHT_CONFLICTS" value="true" />
|
||||||
|
@ -100,7 +96,7 @@
|
||||||
<recent name="C:\Users\RUPC\Desktop\UV-K6\uv-k5-firmware-chinese" />
|
<recent name="C:\Users\RUPC\Desktop\UV-K6\uv-k5-firmware-chinese" />
|
||||||
</key>
|
</key>
|
||||||
</component>
|
</component>
|
||||||
<component name="RunManager" selected="Shell Script.win docker">
|
<component name="RunManager" selected="Shell Script.linux docker">
|
||||||
<configuration name="clean" type="MAKEFILE_TARGET_RUN_CONFIGURATION" factoryName="Makefile" temporary="true">
|
<configuration name="clean" type="MAKEFILE_TARGET_RUN_CONFIGURATION" factoryName="Makefile" temporary="true">
|
||||||
<makefile filename="$PROJECT_DIR$/Makefile" target="clean" workingDirectory="" arguments="">
|
<makefile filename="$PROJECT_DIR$/Makefile" target="clean" workingDirectory="" arguments="">
|
||||||
<envs />
|
<envs />
|
||||||
|
@ -115,7 +111,6 @@
|
||||||
<env name="PYTHONUNBUFFERED" value="1" />
|
<env name="PYTHONUNBUFFERED" value="1" />
|
||||||
</envs>
|
</envs>
|
||||||
<option name="SDK_HOME" value="C:\Users\RUPC\py32\python.exe" />
|
<option name="SDK_HOME" value="C:\Users\RUPC\py32\python.exe" />
|
||||||
<option name="SDK_NAME" value="Python 3.5 (uv-k5-firmware-chinese)" />
|
|
||||||
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$/MDC_WRITE" />
|
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$/MDC_WRITE" />
|
||||||
<option name="IS_MODULE_SDK" value="false" />
|
<option name="IS_MODULE_SDK" value="false" />
|
||||||
<option name="ADD_CONTENT_ROOTS" value="true" />
|
<option name="ADD_CONTENT_ROOTS" value="true" />
|
||||||
|
@ -161,7 +156,7 @@
|
||||||
</configuration>
|
</configuration>
|
||||||
<configuration name="win" type="ShConfigurationType">
|
<configuration name="win" type="ShConfigurationType">
|
||||||
<option name="SCRIPT_TEXT" value="" />
|
<option name="SCRIPT_TEXT" value="" />
|
||||||
<option name="INDEPENDENT_SCRIPT_PATH" value="false" />
|
<option name="INDEPENDENT_SCRIPT_PATH" value="true" />
|
||||||
<option name="SCRIPT_PATH" value="$PROJECT_DIR$/win_make.bat" />
|
<option name="SCRIPT_PATH" value="$PROJECT_DIR$/win_make.bat" />
|
||||||
<option name="SCRIPT_OPTIONS" value="" />
|
<option name="SCRIPT_OPTIONS" value="" />
|
||||||
<option name="INDEPENDENT_SCRIPT_WORKING_DIRECTORY" value="true" />
|
<option name="INDEPENDENT_SCRIPT_WORKING_DIRECTORY" value="true" />
|
||||||
|
@ -228,6 +223,7 @@
|
||||||
<workItem from="1702888356614" duration="3552000" />
|
<workItem from="1702888356614" duration="3552000" />
|
||||||
<workItem from="1702896385700" duration="1302000" />
|
<workItem from="1702896385700" duration="1302000" />
|
||||||
<workItem from="1702910927065" duration="2432000" />
|
<workItem from="1702910927065" duration="2432000" />
|
||||||
|
<workItem from="1703038736949" duration="3997000" />
|
||||||
</task>
|
</task>
|
||||||
<task id="LOCAL-00041" summary="MDC RX">
|
<task id="LOCAL-00041" summary="MDC RX">
|
||||||
<created>1701692190748</created>
|
<created>1701692190748</created>
|
||||||
|
|
101
driver/eeprom.c
101
driver/eeprom.c
|
@ -21,8 +21,8 @@
|
||||||
#include "driver/i2c.h"
|
#include "driver/i2c.h"
|
||||||
#include "driver/system.h"
|
#include "driver/system.h"
|
||||||
|
|
||||||
void EEPROM_ReadBuffer(uint16_t Address, void *pBuffer, uint8_t Size)
|
void EEPROM_ReadBuffer(uint32_t Address, void *pBuffer, uint8_t Size) {
|
||||||
{
|
if(Address<0x10000) {
|
||||||
I2C_Start();
|
I2C_Start();
|
||||||
|
|
||||||
I2C_Write(0xA0);
|
I2C_Write(0xA0);
|
||||||
|
@ -37,17 +37,33 @@ void EEPROM_ReadBuffer(uint16_t Address, void *pBuffer, uint8_t Size)
|
||||||
I2C_ReadBuffer(pBuffer, Size);
|
I2C_ReadBuffer(pBuffer, Size);
|
||||||
|
|
||||||
I2C_Stop();
|
I2C_Stop();
|
||||||
}
|
} else{
|
||||||
void EEPROM_WriteBuffer(uint16_t Address, const void *pBuffer)
|
I2C_Start();
|
||||||
{
|
uint8_t P0 = (StartAddr / 0x10000) << 1;
|
||||||
if (pBuffer == NULL || Address >= 0x2000)
|
|
||||||
return;
|
|
||||||
|
|
||||||
|
I2C_Write(0xA4|P0);
|
||||||
|
|
||||||
|
I2C_Write((Address >> 8) & 0xFF);
|
||||||
|
I2C_Write((Address >> 0) & 0xFF);
|
||||||
|
|
||||||
|
I2C_Start();
|
||||||
|
|
||||||
|
I2C_Write((0xA4|P0)+1);
|
||||||
|
|
||||||
|
I2C_ReadBuffer(pBuffer, Size);
|
||||||
|
|
||||||
|
I2C_Stop();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void EEPROM_WriteBuffer(uint32_t Address, const void *pBuffer) {
|
||||||
|
if (pBuffer == NULL || Address >= 0x20000)
|
||||||
|
return;
|
||||||
|
if (Address < 0x10000) {
|
||||||
|
|
||||||
uint8_t buffer[8];
|
uint8_t buffer[8];
|
||||||
EEPROM_ReadBuffer(Address, buffer, 8);
|
EEPROM_ReadBuffer(Address, buffer, 8);
|
||||||
if (memcmp(pBuffer, buffer, 8) != 0)
|
if (memcmp(pBuffer, buffer, 8) != 0) {
|
||||||
{
|
|
||||||
I2C_Start();
|
I2C_Start();
|
||||||
I2C_Write(0xA0);
|
I2C_Write(0xA0);
|
||||||
I2C_Write((Address >> 8) & 0xFF);
|
I2C_Write((Address >> 8) & 0xFF);
|
||||||
|
@ -58,66 +74,19 @@ void EEPROM_WriteBuffer(uint16_t Address, const void *pBuffer)
|
||||||
|
|
||||||
// give the EEPROM time to burn the data in (apparently takes 5ms)
|
// give the EEPROM time to burn the data in (apparently takes 5ms)
|
||||||
SYSTEM_DelayMs(8);
|
SYSTEM_DelayMs(8);
|
||||||
}
|
} else {
|
||||||
|
uint8_t P0 = (Address / 0x10000) << 1;
|
||||||
#define AT24C1024_ADDRESS 0xA4
|
|
||||||
#define AT24C1024_PAGE_SIZE 64
|
|
||||||
|
|
||||||
void E1EPROM_ReadBuffer_1024(uint32_t Address, void *pBuffer, uint16_t Size) {
|
|
||||||
if (pBuffer == NULL || Address >= 0x20000) // Address limit for AT24C1024 (17-bit address)
|
|
||||||
return;
|
|
||||||
|
|
||||||
uint16_t bytesRead = 0;
|
|
||||||
uint8_t* dataPointer = (uint8_t*)pBuffer;
|
|
||||||
|
|
||||||
while (bytesRead < Size) {
|
|
||||||
uint16_t bytesToRead = (Size - bytesRead < AT24C1024_PAGE_SIZE) ? (Size - bytesRead) : AT24C1024_PAGE_SIZE;
|
|
||||||
uint16_t offset = Address % AT24C1024_PAGE_SIZE;
|
|
||||||
|
|
||||||
I2C_Start();
|
I2C_Start();
|
||||||
I2C_Write(AT24C1024_ADDRESS | ((Address >> 16) & 0x01)); // Sending device address and MSB of memory address
|
I2C_Write(0xA4 | P0);
|
||||||
I2C_Write((uint8_t)(Address >> 8)); // Sending address high byte
|
I2C_Write((Address >> 8) & 0xFF);
|
||||||
I2C_Write((uint8_t)(Address & 0xFF)); // Sending address low byte
|
I2C_Write((Address >> 0) & 0xFF);
|
||||||
I2C_Start();
|
I2C_WriteBuffer(pBuffer, 64);
|
||||||
I2C_Write(AT24C1024_ADDRESS | 0x01); // Sending device address with read bit
|
|
||||||
|
|
||||||
uint8_t buffer[AT24C1024_PAGE_SIZE];
|
|
||||||
I2C_ReadBuffer(buffer, AT24C1024_PAGE_SIZE);
|
|
||||||
|
|
||||||
// Copy the relevant portion of the buffer to the output buffer
|
|
||||||
memcpy(dataPointer, buffer + offset, bytesToRead);
|
|
||||||
|
|
||||||
bytesRead += bytesToRead;
|
|
||||||
dataPointer += bytesToRead;
|
|
||||||
Address += bytesToRead;
|
|
||||||
|
|
||||||
I2C_Stop();
|
I2C_Stop();
|
||||||
}
|
SYSTEM_DelayMs(8);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void E1EPROM_WriteBuffer_1024(uint32_t Address, const void *pBuffer, uint16_t Size) {
|
|
||||||
if (pBuffer == NULL || Address >= 0x20000) // Address limit for AT24C1024 (17-bit address)
|
|
||||||
return;
|
|
||||||
|
|
||||||
uint8_t buffer[AT24C1024_PAGE_SIZE];
|
|
||||||
uint32_t endAddress = Address + Size;
|
|
||||||
for (uint32_t addr = Address; addr < endAddress; addr += AT24C1024_PAGE_SIZE) {
|
|
||||||
uint16_t bytesToWrite = (endAddress - addr < AT24C1024_PAGE_SIZE) ? (endAddress - addr) : AT24C1024_PAGE_SIZE;
|
|
||||||
uint16_t offset = Address % AT24C1024_PAGE_SIZE;
|
|
||||||
uint16_t remaining = AT24C1024_PAGE_SIZE - offset;
|
|
||||||
bytesToWrite = (bytesToWrite < remaining) ? bytesToWrite : remaining;
|
|
||||||
|
|
||||||
EEPROM_ReadBuffer(addr - offset, buffer, AT24C1024_PAGE_SIZE);
|
|
||||||
if (memcmp(pBuffer, buffer + offset, bytesToWrite) != 0) {
|
|
||||||
I2C_Start();
|
|
||||||
I2C_Write(AT24C1024_ADDRESS | ((addr >> 16) & 0x01)); // Sending device address and MSB of memory address
|
|
||||||
I2C_Write((uint8_t)(addr >> 8)); // Sending address high byte
|
|
||||||
I2C_Write((uint8_t)(addr & 0xFF)); // Sending address low byte
|
|
||||||
I2C_WriteBuffer(pBuffer, bytesToWrite);
|
|
||||||
I2C_Stop();
|
|
||||||
}
|
|
||||||
pBuffer += bytesToWrite;
|
|
||||||
// give the EEPROM time to burn the data in (assuming 5ms per page write)
|
|
||||||
SYSTEM_DelayMs(5);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -19,10 +19,8 @@
|
||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
void EEPROM_ReadBuffer(uint16_t Address, void *pBuffer, uint8_t Size);
|
void EEPROM_ReadBuffer(uint32_t Address, void *pBuffer, uint8_t Size);
|
||||||
void EEPROM_WriteBuffer(uint16_t Address, const void *pBuffer);
|
void EEPROM_WriteBuffer(uint32_t Address, const void *pBuffer);
|
||||||
void E1EPROM_ReadBuffer_1024(uint32_t Address, void *pBuffer, uint16_t Size) ;
|
|
||||||
void E1EPROM_WriteBuffer_1024(uint32_t Address, const void *pBuffer, uint16_t Size) ;
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
12
main.c
12
main.c
|
@ -212,14 +212,14 @@ void Main(void)
|
||||||
// for (int i =MDC_ADD[0]; i < MDC_ADD[0]+16; ++i) {
|
// for (int i =MDC_ADD[0]; i < MDC_ADD[0]+16; ++i) {
|
||||||
// EEPROM_WriteBuffer(i,&A[i-MDC_ADD[0]]);
|
// EEPROM_WriteBuffer(i,&A[i-MDC_ADD[0]]);
|
||||||
// }
|
// }
|
||||||
uint8_t B[64];
|
|
||||||
memset(B,'B',sizeof (B));
|
|
||||||
E1EPROM_WriteBuffer_1024(0x10000,B,64);
|
|
||||||
E1EPROM_ReadBuffer_1024(0x10000,B,64);
|
|
||||||
UART_Send(B,64);
|
|
||||||
while(1)
|
while(1)
|
||||||
{
|
{
|
||||||
|
uint8_t B[64];
|
||||||
|
memset(B,'B',sizeof (B));
|
||||||
|
EEPROM_ReadBuffer(0x10000,B,64);
|
||||||
|
EEPROM_ReadBuffer(0x10000,B,64);
|
||||||
|
UART_Send(B,64);
|
||||||
}
|
}
|
||||||
while (1)
|
while (1)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue