mirror of
https://review.coreboot.org/flashrom.git
synced 2025-04-27 23:22:37 +02:00
4BA: Flashrom integration for the 4-bytes addressing extensions
This patch integrates code of the previous patch into Flashrom's code. All the integrations is around 3 functions spi_nbyte_read, spi_nbyte_program and spi_byte_program. After this patch then are not static and can be called by their pointers saved in flashchips array. Also I added to flashrom.c some code to switch a chip to 4-bytes addressing mode. And one error message is corrected in spi.c because it's not suitable for 32-bit addresses. Patched files ------------- flash.h + added set of 4-bytes address functions to flashchip structure definition flashrom.c + added switch to 4-bytes addressing more for chips which support it serprog.c + added 4-bytes addressing spi_nbyte_read call to serprog_spi_read spi.c + fixed flash chip size check in spi_chip_read spi25.c + added 4-bytes addressing spi_nbyte_read call to spi_read_chunked + added 4-bytes addressing spi_nbyte_program call to spi_write_chunked + added 4-bytes addressing spi_byte_program call to spi_chip_write_1 Conflicts: serprog.c Change-Id: Ib051cfc93bd4aa7580519e0e6206d025f3ca8049 Signed-off-by: Boris Baykov <dev@borisbaykov.com>, Russia, Jan 2014 [clg: ported from https://www.flashrom.org/pipermail/flashrom/2015-January/013205.html ] Signed-off-by: Cédric Le Goater <clg@kaod.org> Reviewed-on: https://review.coreboot.org/20505 Reviewed-by: Nico Huber <nico.h@gmx.de> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
parent
b1f88360fc
commit
9912718de1
8
flash.h
8
flash.h
@ -167,6 +167,14 @@ struct flashchip {
|
|||||||
unsigned int page_size;
|
unsigned int page_size;
|
||||||
int feature_bits;
|
int feature_bits;
|
||||||
|
|
||||||
|
/* set of function pointers to use in 4-bytes addressing mode */
|
||||||
|
struct four_bytes_addr_funcs_set {
|
||||||
|
int (*enter_4ba) (struct flashctx *flash);
|
||||||
|
int (*read_nbyte) (struct flashctx *flash, unsigned int addr, uint8_t *bytes, unsigned int len);
|
||||||
|
int (*program_byte) (struct flashctx *flash, unsigned int addr, const uint8_t databyte);
|
||||||
|
int (*program_nbyte) (struct flashctx *flash, unsigned int addr, const uint8_t *bytes, unsigned int len);
|
||||||
|
} four_bytes_addr_funcs;
|
||||||
|
|
||||||
/* Indicate how well flashrom supports different operations of this flash chip. */
|
/* Indicate how well flashrom supports different operations of this flash chip. */
|
||||||
struct tested {
|
struct tested {
|
||||||
enum test_state probe;
|
enum test_state probe;
|
||||||
|
23
flashrom.c
23
flashrom.c
@ -2223,6 +2223,29 @@ int prepare_flash_access(struct flashctx *const flash,
|
|||||||
if (flash->chip->unlock)
|
if (flash->chip->unlock)
|
||||||
flash->chip->unlock(flash);
|
flash->chip->unlock(flash);
|
||||||
|
|
||||||
|
/* Switching to 4-Bytes Addressing mode if flash chip supports it */
|
||||||
|
if(flash->chip->feature_bits & FEATURE_4BA_SUPPORT) {
|
||||||
|
/* Do not switch if chip is already in 4-bytes addressing mode */
|
||||||
|
if (flash->chip->feature_bits & FEATURE_4BA_ONLY) {
|
||||||
|
msg_cdbg("Flash chip is already in 4-bytes addressing mode.\n");
|
||||||
|
}
|
||||||
|
/* Go to 4-Bytes Addressing mode */
|
||||||
|
else {
|
||||||
|
if (!flash->chip->four_bytes_addr_funcs.enter_4ba) {
|
||||||
|
msg_cerr("No function for Enter 4-bytes addressing mode for this flash chip.\n"
|
||||||
|
"Please report to flashrom@flashrom.org\n");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(flash->chip->four_bytes_addr_funcs.enter_4ba(flash)) {
|
||||||
|
msg_cerr("Switching to 4-bytes addressing mode failed!\n");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
msg_cdbg("Switched to 4-bytes addressing mode.\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
5
spi.c
5
spi.c
@ -110,7 +110,10 @@ int spi_chip_read(struct flashctx *flash, uint8_t *buf, unsigned int start,
|
|||||||
* means 0xffffff, the highest unsigned 24bit number.
|
* means 0xffffff, the highest unsigned 24bit number.
|
||||||
*/
|
*/
|
||||||
addrbase = spi_get_valid_read_addr(flash);
|
addrbase = spi_get_valid_read_addr(flash);
|
||||||
if (addrbase + flash->chip->total_size * 1024 > (1 << 24)) {
|
/* Show flash chip size warning if flash chip doesn't support
|
||||||
|
4-Bytes Addressing mode and last address excedes 24 bits */
|
||||||
|
if (!(flash->chip->feature_bits & FEATURE_4BA_SUPPORT) &&
|
||||||
|
addrbase + flash->chip->total_size * 1024 > (1 << 24)) {
|
||||||
msg_perr("Flash chip size exceeds the allowed access window. ");
|
msg_perr("Flash chip size exceeds the allowed access window. ");
|
||||||
msg_perr("Read will probably fail.\n");
|
msg_perr("Read will probably fail.\n");
|
||||||
/* Try to get the best alignment subject to constraints. */
|
/* Try to get the best alignment subject to constraints. */
|
||||||
|
15
spi25.c
15
spi25.c
@ -28,6 +28,7 @@
|
|||||||
#include "chipdrivers.h"
|
#include "chipdrivers.h"
|
||||||
#include "programmer.h"
|
#include "programmer.h"
|
||||||
#include "spi.h"
|
#include "spi.h"
|
||||||
|
#include "spi4ba.h"
|
||||||
|
|
||||||
static int spi_rdid(struct flashctx *flash, unsigned char *readarr, int bytes)
|
static int spi_rdid(struct flashctx *flash, unsigned char *readarr, int bytes)
|
||||||
{
|
{
|
||||||
@ -967,7 +968,10 @@ int spi_read_chunked(struct flashctx *flash, uint8_t *buf, unsigned int start,
|
|||||||
lenhere = min(start + len, (i + 1) * area_size) - starthere;
|
lenhere = min(start + len, (i + 1) * area_size) - starthere;
|
||||||
for (j = 0; j < lenhere; j += chunksize) {
|
for (j = 0; j < lenhere; j += chunksize) {
|
||||||
toread = min(chunksize, lenhere - j);
|
toread = min(chunksize, lenhere - j);
|
||||||
rc = spi_nbyte_read(flash, starthere + j, buf + starthere - start + j, toread);
|
rc = (flash->chip->feature_bits & FEATURE_4BA_SUPPORT) == 0
|
||||||
|
? spi_nbyte_read(flash, starthere + j, buf + starthere - start + j, toread)
|
||||||
|
: flash->chip->four_bytes_addr_funcs.read_nbyte(flash, starthere + j,
|
||||||
|
buf + starthere - start + j, toread);
|
||||||
if (rc)
|
if (rc)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -1012,7 +1016,10 @@ int spi_write_chunked(struct flashctx *flash, const uint8_t *buf, unsigned int s
|
|||||||
lenhere = min(start + len, (i + 1) * page_size) - starthere;
|
lenhere = min(start + len, (i + 1) * page_size) - starthere;
|
||||||
for (j = 0; j < lenhere; j += chunksize) {
|
for (j = 0; j < lenhere; j += chunksize) {
|
||||||
towrite = min(chunksize, lenhere - j);
|
towrite = min(chunksize, lenhere - j);
|
||||||
rc = spi_nbyte_program(flash, starthere + j, buf + starthere - start + j, towrite);
|
rc = (flash->chip->feature_bits & FEATURE_4BA_SUPPORT) == 0
|
||||||
|
? spi_nbyte_program(flash, starthere + j, buf + starthere - start + j, towrite)
|
||||||
|
: flash->chip->four_bytes_addr_funcs.program_nbyte(flash, starthere + j,
|
||||||
|
buf + starthere - start + j, towrite);
|
||||||
if (rc)
|
if (rc)
|
||||||
break;
|
break;
|
||||||
while (spi_read_status_register(flash) & SPI_SR_WIP)
|
while (spi_read_status_register(flash) & SPI_SR_WIP)
|
||||||
@ -1038,7 +1045,9 @@ int spi_chip_write_1(struct flashctx *flash, const uint8_t *buf, unsigned int st
|
|||||||
int result = 0;
|
int result = 0;
|
||||||
|
|
||||||
for (i = start; i < start + len; i++) {
|
for (i = start; i < start + len; i++) {
|
||||||
result = spi_byte_program(flash, i, buf[i - start]);
|
result = (flash->chip->feature_bits & FEATURE_4BA_SUPPORT) == 0
|
||||||
|
? spi_byte_program(flash, i, buf[i - start])
|
||||||
|
: flash->chip->four_bytes_addr_funcs.program_byte(flash, i, buf[i - start]);
|
||||||
if (result)
|
if (result)
|
||||||
return 1;
|
return 1;
|
||||||
while (spi_read_status_register(flash) & SPI_SR_WIP)
|
while (spi_read_status_register(flash) & SPI_SR_WIP)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user