4
0
mirror of https://github.com/RT-Thread/rt-thread.git synced 2025-01-26 17:17:36 +08:00
guo ecf2d82159
sync branch rt-smart. (#6641)
* Synchronize the code of the rt mart branch to the master branch.
  * TTY device
  * Add lwP code from rt-smart
  * Add vnode in DFS, but DFS will be re-write for rt-smart
  * There are three libcpu for rt-smart:
    * arm/cortex-a, arm/aarch64
    * riscv64

Co-authored-by: Rbb666 <zhangbingru@rt-thread.com>
Co-authored-by: zhkag <zhkag@foxmail.com>
2022-12-03 12:07:44 +08:00

188 lines
4.1 KiB
C

#include <string.h>
#include <stdlib.h>
#include <time.h>
#include <pthread.h>
#include <errno.h>
#include <unistd.h>
#include <hal_timer.h>
#include <hal_cmd.h>
#include "inter.h"
#define NOR_CMD_BLK_LOCK_ALL (0x7E)
#define NOR_CMD_BLK_UNLOCK_ALL (0x98)
/* #define DEBUG_WRLOCK */
#ifdef DEBUG_WRLOCK
int skip_lock = 0;
#endif
int nor_wr_lock_init(struct nor_flash *nor)
{
if (nor->factory->init_lock)
return nor->factory->init_lock(nor);
return 0;
}
void nor_wr_lock_deinit(struct nor_flash *nor)
{
if (nor->factory->deinit_lock)
nor->factory->deinit_lock(nor);
}
bool nor_wr_islock(struct nor_flash *nor, unsigned int addr, unsigned int len)
{
unsigned int align_size;
unsigned int align_addr;
bool ret = false;
if (nor->factory->islock) {
while (len) {
/* the first and the last block (64K) is lock on sector (4K) unit */
if (addr >= nor->total_size - SZ_64K || addr < SZ_64K)
align_size = SZ_4K;
else
align_size = SZ_64K;
align_addr = ALIGN_DOWN(addr, align_size);
ret = nor->factory->islock(nor, align_addr, align_size);
if (ret)
break;
len -= MIN(align_size, len);
addr += MIN(align_size, len);
}
}
return ret;
}
int nor_wr_lock(struct nor_flash *nor, unsigned int addr, unsigned int len)
{
unsigned int align_size;
unsigned int align_addr;
int ret = 0;
#ifdef DEBUG_WRLOCK
if (skip_lock == 1) {
printf("skip handle lock\n");
return 0;
}
#endif
if (nor->factory->lock) {
while (len) {
/* the first and the last block (64K) is lock on sector (4K) unit */
if (addr >= nor->total_size - SZ_64K || addr < SZ_64K)
align_size = SZ_4K;
else
align_size = SZ_64K;
align_addr = ALIGN_DOWN(addr, align_size);
ret = nor->factory->lock(nor, align_addr, align_size);
if (ret)
break;
len -= MIN(align_size, len);
addr += MIN(align_size, len);
}
}
return ret;
}
int nor_wr_unlock(struct nor_flash *nor, unsigned int addr, unsigned int len)
{
unsigned int align_size;
unsigned int align_addr;
int ret = 0;
#ifdef DEBUG_WRLOCK
if (skip_lock == 1) {
printf("skip handle lock\n");
return 0;
}
#endif
if (nor->factory->unlock) {
while (len) {
/* the first and the last block (64K) is lock on sector (4K) unit */
if (addr >= nor->total_size - SZ_64K || addr < SZ_64K)
align_size = SZ_4K;
else
align_size = SZ_64K;
align_addr = ALIGN_DOWN(addr, align_size);
ret = nor->factory->unlock(nor, align_addr, align_size);
if (ret)
break;
len -= MIN(align_size, len);
addr += MIN(align_size, len);
}
}
return ret;
}
int nor_wr_unlock_all(struct nor_flash *nor)
{
int ret;
#ifdef DEBUG_WRLOCK
if (skip_lock == 1) {
printf("skip handle lock\n");
return 0;
}
#endif
ret = nor_write_enable();
if (ret)
return ret;
ret = nor_send_cmd(NOR_CMD_BLK_UNLOCK_ALL);
if (ret) {
SPINOR_ERR("unlock all block failed - %d\n", ret);
return ret;
}
return 0;
}
int nor_wr_lock_all(struct nor_flash *nor)
{
int ret;
#ifdef DEBUG_WRLOCK
if (skip_lock == 1) {
printf("skip handle lock\n");
return 0;
}
#endif
ret = nor_write_enable();
if (ret)
return ret;
ret = nor_send_cmd(NOR_CMD_BLK_LOCK_ALL);
if (ret) {
SPINOR_ERR("lock all block failed - %d\n", ret);
return ret;
}
return 0;
}
#ifdef DEBUG_WRLOCK
int cmd_skip_lock(int argc, char ** argv)
{
printf("skip lock\n");
skip_lock = 1;
}
FINSH_FUNCTION_EXPORT_CMD(cmd_skip_lock, skip_lock, skip lock)
int cmd_not_skip_lock(int argc, char ** argv)
{
printf("not skip lock\n");
skip_lock = 0;
}
FINSH_FUNCTION_EXPORT_CMD(cmd_not_skip_lock, not_skip_lock, not skip lock)
#endif