/*************************************************************************** * * Copyright 2015-2019 BES. * All rights reserved. All unpublished rights reserved. * * No part of this work may be used or reproduced in any form or by any * means, or stored in a database or retrieval system, without prior written * permission of BES. * * Use of this work is governed by a license granted by BES. * This work contains confidential and proprietary information of * BES. which is protected by copyright, trade secret, * trademark and other intellectual property rights. * ****************************************************************************/ #if (CHIP_FLASH_CTRL_VER <= 1) #include "plat_types.h" #include "plat_addr_map.h" #include "reg_norflaship_v1.h" #include "hal_norflaship.h" #ifdef PROGRAMMER #include "task_schedule.h" #else #define TASK_SCHEDULE true #endif //==================================================================================== // Flash IP Operations //==================================================================================== /* Supported Command List (Based on GD25Q32C): parameter NOP = 8'h00 ; parameter WRR = 8'h01 ; parameter PP = 8'h02 ; parameter READ = 8'h03 ; parameter WRDI = 8'h04 ; parameter RDSR = 8'h05 ; parameter WREN = 8'h06 ; parameter FAST_READ = 8'h0B ; parameter P4E = 8'h20 ; parameter SE2 = 8'h20 ; parameter CLSR = 8'h30 ; parameter QPP = 8'h32 ; parameter RCR = 8'h35 ; parameter DOR = 8'h3B ; parameter P8E = 8'h40 ; parameter OTPP = 8'h42 ; parameter PSR = 8'h42 ; parameter ESR = 8'h44 ; parameter RSR = 8'h48 ; parameter OTPR = 8'h4B ; parameter BE32 = 8'h52 ; parameter CE = 8'h60 ; parameter QOR = 8'h6B ; parameter PES = 8'h75 ; parameter PER = 8'h7A ; parameter READ_ID = 8'h90 ; parameter RDID = 8'h9F ; parameter HPM = 8'hA3 ; parameter RES = 8'hAB ; parameter DP = 8'hB9 ; parameter DIOR = 8'hBB ; parameter BE = 8'hC7 ; parameter BE64 = 8'hD8 ; parameter SE = 8'hD8 ; parameter QIOWR = 8'hE7 ; parameter QIOR = 8'hEB ; parameter CRR = 8'hFF ; */ /* register memory address */ #define NORFLASHIP_BASEADDR FLASH_CTRL_BASE #define norflaship_readb(a) \ (*(volatile unsigned char*)(NORFLASHIP_BASEADDR+a)) #define norflaship_read32(a) \ (*(volatile unsigned int *)(NORFLASHIP_BASEADDR+a)) #define norflaship_write32(v,a) \ ((*(volatile unsigned int *)(NORFLASHIP_BASEADDR+a)) = v) /* ip ops */ uint8_t norflaship_continuous_read_mode_bit(uint8_t mode_bit) { uint32_t val = 0; norflaship_busy_wait(); val = norflaship_read32(TX_CONFIG2_BASE); val &= ~(TX_MODBIT_MASK); val |= (mode_bit< 0) { st = norflaship_read32(INT_STATUS_BASE); if (st & TXFIFOFULL_MASK) { continue; } norflaship_write32(*val, TXDATA_BASE); val++; len--; } return 0; } uint8_t norflaship_read_rxfifo_count(void) { uint32_t val = 0; val = norflaship_readb(INT_STATUS_BASE); return ((val&RXFIFOCOUNT_MASK)>>RXFIFOCOUNT_SHIFT); } uint8_t norflaship_read_rxfifo(void) { uint32_t val = 0; val = norflaship_readb(RXDATA_BASE); return val&0xff; } void norflaship_blksize(uint32_t blksize) { uint32_t val = 0; val = norflaship_read32(TX_CONFIG2_BASE); val = ((~(TX_BLKSIZE_MASK))&val) | (blksize<>RXFIFOCOUNT_SHIFT) < cnt) && TASK_SCHEDULE); } void norflaship_rxfifo_empty_wait(void) { uint32_t st = 0; do { st = norflaship_read32(INT_STATUS_BASE); } while ((st&RXFIFOEMPTY_MASK) && TASK_SCHEDULE); } void norflaship_busy_wait(void) { uint32_t st = 0; do { st = norflaship_read32(INT_STATUS_BASE); } while ((st&BUSY_MASK) && TASK_SCHEDULE); } int norflaship_is_busy(void) { uint32_t st = 0; st = norflaship_read32(INT_STATUS_BASE); return !!(st&BUSY_MASK); } void norflaship_clear_fifos(void) { norflaship_busy_wait(); norflaship_write32(RXFIFOCLR_MASK|TXFIFOCLR_MASK, FIFO_CONFIG_BASE); norflaship_busy_wait(); } void norflaship_clear_rxfifo(void) { norflaship_busy_wait(); norflaship_write32(RXFIFOCLR_MASK, FIFO_CONFIG_BASE); norflaship_busy_wait(); } void norflaship_clear_txfifo(void) { norflaship_busy_wait(); norflaship_write32(TXFIFOCLR_MASK, FIFO_CONFIG_BASE); norflaship_busy_wait(); } void norflaship_div(uint32_t div) { uint32_t val = 0; norflaship_busy_wait(); val = norflaship_read32(MODE1_CONFIG_BASE); val = (~(CLKDIV_MASK) & val) | (div<> CLKDIV_SHIFT; } void norflaship_cmdquad(uint32_t v) { uint32_t val = 0; norflaship_busy_wait(); val = norflaship_read32(MODE1_CONFIG_BASE); if (v) val |= CMDQUAD_MASK; else val &= ~CMDQUAD_MASK; norflaship_write32(val, MODE1_CONFIG_BASE); } uint32_t norflaship_get_pos_neg(void) { uint32_t val = 0; val = norflaship_read32(MODE1_CONFIG_BASE); return !!(val & POS_NEG_MASK); } void norflaship_pos_neg(uint32_t v) { uint32_t val = 0; norflaship_busy_wait(); val = norflaship_read32(MODE1_CONFIG_BASE); if (v) val |= POS_NEG_MASK; else val &= ~POS_NEG_MASK; norflaship_write32(val, MODE1_CONFIG_BASE); } uint32_t norflaship_get_neg_phase(void) { uint32_t val = 0; val = norflaship_read32(MODE1_CONFIG_BASE); return !!(val & NEG_PHASE_MASK); } void norflaship_neg_phase(uint32_t v) { uint32_t val = 0; norflaship_busy_wait(); val = norflaship_read32(MODE1_CONFIG_BASE); if (v) val |= NEG_PHASE_MASK; else val &= ~NEG_PHASE_MASK; norflaship_write32(val, MODE1_CONFIG_BASE); } uint32_t norflaship_get_samdly(void) { uint32_t val = 0; val = norflaship_read32(MODE1_CONFIG_BASE); return (val & SAMDLY_MASK) >> SAMDLY_SHIFT; } void norflaship_samdly(uint32_t v) { uint32_t val = 0; norflaship_busy_wait(); val = norflaship_read32(MODE1_CONFIG_BASE); val = (~(SAMDLY_MASK) & val) | (v<> RDCMD_SHIFT); } void norflaship_sleep(void) { } void norflaship_wakeup(void) { } #endif