/* * Copyright (C) 2015-2016 Freescale Semiconductor, Inc. * * SPDX-License-Identifier: GPL-2.0+ */ #include #include #ifdef CONFIG_FASTBOOT_STORAGE_NAND #include #endif #include "bcb.h" #ifndef CONFIG_FASTBOOT_STORAGE_NAND int bcb_read_command(char *command) { int ret = 0; char *p_block = NULL; uint offset_in_block = 0; uint blk_size = 0; if (command == NULL) return -1; ret = bcb_rw_block(true, &p_block, &blk_size, NULL, MISC_COMMAND, 32); if (ret) { printf("read_bootctl, bcb_rw_block read failed\n"); return -1; } offset_in_block = MISC_COMMAND%blk_size; memcpy(command, p_block + offset_in_block, 32); free(p_block); return 0; } int bcb_write_command(char *bcb_command) { int ret = 0; char *p_block = NULL; uint offset_in_block = 0; uint blk_size = 0; if (bcb_command == NULL) return -1; ret = bcb_rw_block(true, &p_block, &blk_size, NULL, MISC_COMMAND, 32); if (ret) { printf("write_bootctl, bcb_rw_block read failed\n"); return -1; } offset_in_block = MISC_COMMAND%blk_size; memcpy(p_block + offset_in_block, bcb_command, 32); ret = bcb_rw_block(false, NULL, NULL, p_block, MISC_COMMAND, 32); if (ret) { free(p_block); printf("write_bootctl, bcb_rw_block write failed\n"); return -1; } free(p_block); return 0; } #else #define ALIGN_BYTES 64 #define MISC_PAGES 3 int bcb_read_command(char *command) { char read_cmd[128]; char *addr_str; char *nand_str; ulong misc_info_size; struct mtd_info *nand = &nand_info[0]; if (command == NULL) return -1; memset(read_cmd, 0, 128); misc_info_size = MISC_PAGES * nand->writesize; nand_str = (char *)memalign(ALIGN_BYTES, misc_info_size); sprintf(read_cmd, "nand read 0x%x ${misc_nand_offset} \ 0x%x", nand_str, misc_info_size); run_command(read_cmd, 0); /* The offset of bootloader_message is 1 PAGE. * The offset of bootloader_message and the size of misc info * need align with user space and recovery. */ addr_str = nand_str + nand->writesize; memcpy(command, (char *)addr_str, 32); free(nand_str); return 0; } int bcb_write_command(char *command) { char cmd[128]; char *addr_str; char *nand_str; ulong misc_info_size; struct mtd_info *nand = &nand_info[0]; if (command == NULL) return -1; memset(cmd, 0, 128); misc_info_size = MISC_PAGES * nand->writesize; nand_str = (char *)memalign(ALIGN_BYTES, misc_info_size); sprintf(cmd, "nand read 0x%x ${misc_nand_offset} \ 0x%x", nand_str, misc_info_size); run_command(cmd, 0); /* the offset of bootloader_message is 1 PAGE*/ addr_str = nand_str + nand->writesize; memcpy((char *)addr_str, command, 32); /* erase 3 pages which hold BCB struct.*/ sprintf(cmd, "nand erase ${misc_nand_offset} 0x%x",nand->erasesize); run_command(cmd, 0); sprintf(cmd, "nand write 0x%x ${misc_nand_offset} 0x%x",nand_str, misc_info_size); run_command(cmd, 0); free(nand_str); return 0; } #endif