mirror of
https://github.com/Telecominfraproject/OpenCellular.git
synced 2026-01-06 23:51:28 +00:00
Everything now uses flash_dataptr() to get at flash memory rather than calling the read function, since the read function adds a needless memcpy(). BUG=chrome-os-partner:11150 TEST=manual flashwp enable reboot flashinfo -> should show ro_at_boot flashwp disable reboot flashinfo -> should no longer show ro_at_boot Change-Id: I1830e2f036cf6777115c782c1737335ff2eb4ce0 Signed-off-by: Randall Spangler <rspangler@chromium.org> Reviewed-on: https://gerrit.chromium.org/gerrit/27796
178 lines
5.4 KiB
C
178 lines
5.4 KiB
C
/* Copyright (c) 2012 The Chromium OS Authors. All rights reserved.
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
* found in the LICENSE file.
|
|
*/
|
|
|
|
/* Flash memory module for Chrome EC */
|
|
|
|
#ifndef __CROS_EC_FLASH_H
|
|
#define __CROS_EC_FLASH_H
|
|
|
|
#include "common.h"
|
|
|
|
|
|
/*****************************************************************************/
|
|
/* Low-level methods, for use by flash_common. */
|
|
|
|
/**
|
|
* Initialize the physical flash interface.
|
|
*/
|
|
int flash_physical_pre_init(void);
|
|
|
|
/**
|
|
* Return the write / erase / protect block size, in bytes. Operations must be
|
|
* aligned to and multiples of the granularity. For example, erase operations
|
|
* must have offset and size which are multiples of the erase block size.
|
|
*/
|
|
int flash_get_write_block_size(void);
|
|
int flash_get_erase_block_size(void);
|
|
int flash_get_protect_block_size(void);
|
|
|
|
/**
|
|
* Return the physical size of flash in bytes as read from the flash chip
|
|
* itself.
|
|
*
|
|
* Used during testing to confirm CONFIG_FLASH_PHYSICAL_SIZE is correct.
|
|
* Most other code should use CONFIG_FLASH_PHYSICAL_SIZE.
|
|
*/
|
|
int flash_physical_size(void);
|
|
|
|
/**
|
|
* Get the physical memory address of a flash offset
|
|
*
|
|
* This is used for direct flash access. We assume that the flash is
|
|
* contiguous from this start address through to the end of the usable
|
|
* flash.
|
|
*
|
|
* @param offset Flash offset to get address of
|
|
* @param dataptrp Returns pointer to memory address of flash offset
|
|
* @return pointer to flash memory offset, if ok, else NULL
|
|
*/
|
|
static inline char *flash_physical_dataptr(int offset)
|
|
{
|
|
return (char *)offset;
|
|
}
|
|
|
|
/* Write <size> bytes of data to flash at byte offset <offset>.
|
|
* <data> must be 32-bit aligned. */
|
|
int flash_physical_write(int offset, int size, const char *data);
|
|
|
|
/* Erase <size> bytes of flash at byte offset <offset>. */
|
|
int flash_physical_erase(int offset, int size);
|
|
|
|
/* Return non-zero if bank is protected until reboot. */
|
|
int flash_physical_get_protect(int bank);
|
|
|
|
/**
|
|
* Protect the flash banks until reboot.
|
|
*
|
|
* @param start_bank Start bank to protect
|
|
* @param bank_count Number of banks to protect
|
|
*/
|
|
void flash_physical_set_protect(int start_bank, int bank_count);
|
|
|
|
/*****************************************************************************/
|
|
/* High-level interface for use by other modules. */
|
|
|
|
/**
|
|
* Initialize the module.
|
|
*
|
|
* Applies at-boot protection settings if necessary.
|
|
*/
|
|
int flash_pre_init(void);
|
|
|
|
/**
|
|
* Return the usable size of flash in bytes. Note that this may be smaller
|
|
* than the physical flash size.
|
|
*/
|
|
int flash_get_size(void);
|
|
|
|
/**
|
|
* Get the physical memory address of a flash offset
|
|
*
|
|
* This is used for direct flash access. We assume that the flash is
|
|
* contiguous from this start address through to the end of the usable
|
|
* flash.
|
|
*
|
|
* This function returns -1 if offset + size_req extends beyond the end
|
|
* of flash, the offset is out of range, or if either size_req or offset
|
|
* are not aligned to 'align'.
|
|
*
|
|
* @param offset Flash offset to get address of
|
|
* @param size_req Number of bytes requested
|
|
* @param align Ensure offset and size_req are aligned to given
|
|
* power of two.
|
|
* @param ptrp If not NULL, returns a pointer to this flash offset
|
|
* in memory, unless function fails, iwc it is unset.
|
|
* @return size of flash region available at *ptrp, or -1 on error
|
|
*/
|
|
int flash_dataptr(int offset, int size_req, int align, char **ptrp);
|
|
|
|
/**
|
|
* Write to flash.
|
|
*
|
|
* Offset and size must be a multiple of get_flash_write_block_size().
|
|
*
|
|
* @param offset Flash offset to write.
|
|
* @param size Number of bytes to write.
|
|
* @param data Data to write to flash.
|
|
*/
|
|
int flash_write(int offset, int size, const char *data);
|
|
|
|
/**
|
|
* Erase flash.
|
|
*
|
|
* Offset and size must be a multiple of get_flash_erase_block_size().
|
|
*
|
|
* @param offset Flash offset to erase.
|
|
* @param size Number of bytes to erase.
|
|
*/
|
|
int flash_erase(int offset, int size);
|
|
|
|
/**
|
|
* Protect the entire flash until reboot.
|
|
*
|
|
* If the write protect pin is deasserted, this request is ignored.
|
|
*/
|
|
int flash_protect_until_reboot(void);
|
|
|
|
/**
|
|
* Enable write protect for the read-only code.
|
|
*
|
|
* Once write protect is enabled, it will STAY enabled until the system is
|
|
* hard-rebooted with the hardware write protect pin deasserted. If the write
|
|
* protect pin is deasserted, the protect setting is ignored, and the entire
|
|
* flash will be writable.
|
|
*
|
|
* @param enable Enable write protection
|
|
*/
|
|
int flash_enable_protect(int enable);
|
|
|
|
/* Flags for flash_get_protect() */
|
|
/*
|
|
* Flash protection lock has been set. Note that if the write protect pin was
|
|
* deasserted at boot time, this simply indicates the state of the lock
|
|
* setting, and not whether blocks are actually protected.
|
|
*/
|
|
#define FLASH_PROTECT_RO_AT_BOOT (1 << 0)
|
|
/*
|
|
* Flash protection lock has actually been applied. Read-only firmware is
|
|
* protected, and flash protection cannot be unlocked.
|
|
*/
|
|
#define FLASH_PROTECT_RO_NOW (1 << 1)
|
|
/* Write protect pin is currently asserted */
|
|
#define FLASH_PROTECT_PIN_ASSERTED (1 << 2)
|
|
/* Entire flash is protected until reboot */
|
|
#define FLASH_PROTECT_RW_NOW (1 << 3)
|
|
/* At least one bank of flash is stuck locked, and cannot be unlocked */
|
|
#define FLASH_PROTECT_STUCK_LOCKED (1 << 4)
|
|
/* At least one bank of flash which should be protected is not protected */
|
|
#define FLASH_PROTECT_PARTIAL (1 << 5)
|
|
|
|
/**
|
|
* Return the flash protect lock status.
|
|
*/
|
|
int flash_get_protect(void);
|
|
|
|
#endif /* __CROS_EC_FLASH_H */
|