aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorbarthess <barthess@yandex.ru>2015-05-08 00:04:09 +0300
committerbarthess <barthess@yandex.ru>2015-05-08 00:04:09 +0300
commitf5b812a2e765258c21691e84aafd446089618f62 (patch)
treeee87e6d014fecfee0522db1b149cae05458db13a
parentdd7d31d083981094e68d68d3c3696530a5eb5885 (diff)
downloadChibiOS-Contrib-f5b812a2e765258c21691e84aafd446089618f62.tar.gz
ChibiOS-Contrib-f5b812a2e765258c21691e84aafd446089618f62.tar.bz2
ChibiOS-Contrib-f5b812a2e765258c21691e84aafd446089618f62.zip
NAND. Minor improvements
-rw-r--r--os/hal/src/nand.c35
-rw-r--r--testhal/STM32/STM32F4xx/FSMC_NAND/main.c3
2 files changed, 17 insertions, 21 deletions
diff --git a/os/hal/src/nand.c b/os/hal/src/nand.c
index a2a5863..a621604 100644
--- a/os/hal/src/nand.c
+++ b/os/hal/src/nand.c
@@ -68,32 +68,32 @@ static void pagesize_check(size_t page_data_size) {
/**
* @brief Translate block-page-offset scheme to NAND internal address.
*
- * @param[in] cfg pointer to the @p NANDConfig from
- * corresponding NAND driver
- * @param[in] block block number
- * @param[in] page page number related to begin of block
- * @param[in] offset data offset related to begin of page
- * @param[out] addr buffer to store calculated address
- * @param[in] addr_len length of address buffer
+ * @param[in] cfg pointer to the @p NANDConfig from
+ * corresponding NAND driver
+ * @param[in] block block number
+ * @param[in] page page number related to begin of block
+ * @param[in] page_offset data offset related to begin of page
+ * @param[out] addr buffer to store calculated address
+ * @param[in] addr_len length of address buffer
*
* @notapi
*/
static void calc_addr(const NANDConfig *cfg, uint32_t block, uint32_t page,
- uint32_t offset, uint8_t *addr, size_t addr_len) {
+ uint32_t page_offset, uint8_t *addr, size_t addr_len) {
size_t i = 0;
uint32_t row = 0;
/* Incorrect buffer length.*/
osalDbgCheck(cfg->rowcycles + cfg->colcycles == addr_len);
osalDbgCheck((block < cfg->blocks) && (page < cfg->pages_per_block) &&
- (offset < cfg->page_data_size + cfg->page_spare_size));
+ (page_offset < cfg->page_data_size + cfg->page_spare_size));
/* convert address to NAND specific */
memset(addr, 0, addr_len);
row = (block * cfg->pages_per_block) + page;
for (i=0; i<cfg->colcycles; i++){
- addr[i] = offset & 0xFF;
- offset = offset >> 8;
+ addr[i] = page_offset & 0xFF;
+ page_offset = page_offset >> 8;
}
for (; i<addr_len; i++){
addr[i] = row & 0xFF;
@@ -144,16 +144,13 @@ static void calc_blk_addr(const NANDConfig *cfg, uint32_t block,
* @notapi
*/
static bool read_is_block_bad(NANDDriver *nandp, size_t block) {
- uint8_t m0;
- uint8_t m1;
- m0 = nandReadBadMark(nandp, block, 0);
- m1 = nandReadBadMark(nandp, block, 1);
-
- if ((0xFF != m0) || (0xFF != m1))
+ if (0xFF != nandReadBadMark(nandp, block, 0))
return true;
- else
- return false;
+ if (0xFF != nandReadBadMark(nandp, block, 1))
+ return true;
+
+ return false;
}
/**
diff --git a/testhal/STM32/STM32F4xx/FSMC_NAND/main.c b/testhal/STM32/STM32F4xx/FSMC_NAND/main.c
index 7df235e..2379a12 100644
--- a/testhal/STM32/STM32F4xx/FSMC_NAND/main.c
+++ b/testhal/STM32/STM32F4xx/FSMC_NAND/main.c
@@ -139,7 +139,6 @@ static bitmap_t badblock_map = {
*
*/
static const NANDConfig nandcfg = {
- //&FSMCD1,
NAND_BLOCKS_COUNT,
NAND_PAGE_DATA_SIZE,
NAND_PAGE_SPARE_SIZE,
@@ -643,7 +642,7 @@ int main(void) {
/*
* Normal main() thread activity, in this demo it does nothing.
*/
- while (TRUE) {
+ while (true) {
chThdSleepMilliseconds(500);
}
}