mirror of
https://review.coreboot.org/flashrom.git
synced 2025-04-26 22:52:34 +02:00
tree/: Rename 'internal_delay()' to 'default_delay()'
The non-custom driver programmer delay implementation 'internal_delay()' is unrelated specifically to the 'internal' programmer. The delay implementation is simply a platform-agnostic host delay implementation. Therefore, rename to simply default_delay(). Change-Id: I5e04adf16812ceb1480992c92bca25ed80f8897a Signed-off-by: Edward O'Callaghan <quasisec@google.com> Reviewed-on: https://review.coreboot.org/c/flashrom/+/68855 Reviewed-by: Alexander Goncharov <chat@joursoir.net> Reviewed-by: Felix Singer <felixsinger@posteo.net> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
parent
d1212796ab
commit
76f28a3fc2
@ -60,7 +60,7 @@ static int mbox_wait_ack(uint16_t mbox_port)
|
|||||||
msg_pwarn("IMC MBOX: Timeout!\n");
|
msg_pwarn("IMC MBOX: Timeout!\n");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
internal_delay(1000);
|
default_delay(1000);
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
4
atavia.c
4
atavia.c
@ -90,7 +90,7 @@ static bool atavia_ready(struct pci_dev *pcidev_dev)
|
|||||||
ready = true;
|
ready = true;
|
||||||
break;
|
break;
|
||||||
} else {
|
} else {
|
||||||
internal_delay(1);
|
default_delay(1);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -170,7 +170,7 @@ static int atavia_init(const struct programmer_cfg *cfg)
|
|||||||
|
|
||||||
/* Test if a flash chip is attached. */
|
/* Test if a flash chip is attached. */
|
||||||
pci_write_long(dev, PCI_ROM_ADDRESS, (uint32_t)PCI_ROM_ADDRESS_MASK);
|
pci_write_long(dev, PCI_ROM_ADDRESS, (uint32_t)PCI_ROM_ADDRESS_MASK);
|
||||||
internal_delay(90);
|
default_delay(90);
|
||||||
uint32_t base = pci_read_long(dev, PCI_ROM_ADDRESS);
|
uint32_t base = pci_read_long(dev, PCI_ROM_ADDRESS);
|
||||||
msg_pdbg2("BROM base=0x%08x\n", base);
|
msg_pdbg2("BROM base=0x%08x\n", base);
|
||||||
if ((base & PCI_ROM_ADDRESS_MASK) == 0) {
|
if ((base & PCI_ROM_ADDRESS_MASK) == 0) {
|
||||||
|
@ -76,10 +76,10 @@ static uint8_t bitbang_spi_read_byte(const struct bitbang_spi_master *master, vo
|
|||||||
bitbang_spi_set_sck_set_mosi(master, 0, 0, spi_data);
|
bitbang_spi_set_sck_set_mosi(master, 0, 0, spi_data);
|
||||||
else
|
else
|
||||||
bitbang_spi_set_sck(master, 0, spi_data);
|
bitbang_spi_set_sck(master, 0, spi_data);
|
||||||
internal_delay(master->half_period);
|
default_delay(master->half_period);
|
||||||
ret <<= 1;
|
ret <<= 1;
|
||||||
ret |= bitbang_spi_set_sck_get_miso(master, 1, spi_data);
|
ret |= bitbang_spi_set_sck_get_miso(master, 1, spi_data);
|
||||||
internal_delay(master->half_period);
|
default_delay(master->half_period);
|
||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -90,9 +90,9 @@ static void bitbang_spi_write_byte(const struct bitbang_spi_master *master, uint
|
|||||||
|
|
||||||
for (i = 7; i >= 0; i--) {
|
for (i = 7; i >= 0; i--) {
|
||||||
bitbang_spi_set_sck_set_mosi(master, 0, (val >> i) & 1, spi_data);
|
bitbang_spi_set_sck_set_mosi(master, 0, (val >> i) & 1, spi_data);
|
||||||
internal_delay(master->half_period);
|
default_delay(master->half_period);
|
||||||
bitbang_spi_set_sck(master, 1, spi_data);
|
bitbang_spi_set_sck(master, 1, spi_data);
|
||||||
internal_delay(master->half_period);
|
default_delay(master->half_period);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -122,9 +122,9 @@ static int bitbang_spi_send_command(const struct flashctx *flash,
|
|||||||
readarr[i] = bitbang_spi_read_byte(master, data->spi_data);
|
readarr[i] = bitbang_spi_read_byte(master, data->spi_data);
|
||||||
|
|
||||||
bitbang_spi_set_sck(master, 0, data->spi_data);
|
bitbang_spi_set_sck(master, 0, data->spi_data);
|
||||||
internal_delay(master->half_period);
|
default_delay(master->half_period);
|
||||||
bitbang_spi_set_cs(master, 1, data->spi_data);
|
bitbang_spi_set_cs(master, 1, data->spi_data);
|
||||||
internal_delay(master->half_period);
|
default_delay(master->half_period);
|
||||||
/* FIXME: Run bitbang_spi_release_bus here or in programmer init? */
|
/* FIXME: Run bitbang_spi_release_bus here or in programmer init? */
|
||||||
bitbang_spi_release_bus(master, data->spi_data);
|
bitbang_spi_release_bus(master, data->spi_data);
|
||||||
|
|
||||||
|
@ -326,10 +326,10 @@ static void ch341a_spi_delay(const struct flashctx *flash, unsigned int usecs)
|
|||||||
{
|
{
|
||||||
/* There is space for 28 bytes instructions of 750 ns each in the CS packet (32 - 4 for the actual CS
|
/* There is space for 28 bytes instructions of 750 ns each in the CS packet (32 - 4 for the actual CS
|
||||||
* instructions), thus max 21 us, but we avoid getting too near to this boundary and use
|
* instructions), thus max 21 us, but we avoid getting too near to this boundary and use
|
||||||
* internal_delay() for durations over 20 us. */
|
* default_delay() for durations over 20 us. */
|
||||||
if ((usecs + stored_delay_us) > 20) {
|
if ((usecs + stored_delay_us) > 20) {
|
||||||
unsigned int inc = 20 - stored_delay_us;
|
unsigned int inc = 20 - stored_delay_us;
|
||||||
internal_delay(usecs - inc);
|
default_delay(usecs - inc);
|
||||||
usecs = inc;
|
usecs = inc;
|
||||||
}
|
}
|
||||||
stored_delay_us += usecs;
|
stored_delay_us += usecs;
|
||||||
|
@ -316,7 +316,7 @@ static int dediprog_set_spi_voltage(libusb_device_handle *dediprog_handle, int m
|
|||||||
|
|
||||||
if (voltage_selector == 0) {
|
if (voltage_selector == 0) {
|
||||||
/* Wait some time as the original driver does. */
|
/* Wait some time as the original driver does. */
|
||||||
internal_delay(200 * 1000);
|
default_delay(200 * 1000);
|
||||||
}
|
}
|
||||||
ret = dediprog_write(dediprog_handle, CMD_SET_VCC, voltage_selector, 0, NULL, 0);
|
ret = dediprog_write(dediprog_handle, CMD_SET_VCC, voltage_selector, 0, NULL, 0);
|
||||||
if (ret != 0x0) {
|
if (ret != 0x0) {
|
||||||
@ -326,7 +326,7 @@ static int dediprog_set_spi_voltage(libusb_device_handle *dediprog_handle, int m
|
|||||||
}
|
}
|
||||||
if (voltage_selector != 0) {
|
if (voltage_selector != 0) {
|
||||||
/* Wait some time as the original driver does. */
|
/* Wait some time as the original driver does. */
|
||||||
internal_delay(200 * 1000);
|
default_delay(200 * 1000);
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -897,7 +897,7 @@ static int dummy_spi_send_command(const struct flashctx *flash, unsigned int wri
|
|||||||
msg_pspew(" 0x%02x", readarr[i]);
|
msg_pspew(" 0x%02x", readarr[i]);
|
||||||
msg_pspew("\n");
|
msg_pspew("\n");
|
||||||
|
|
||||||
internal_delay((writecnt + readcnt) * emu_data->delay_us);
|
default_delay((writecnt + readcnt) * emu_data->delay_us);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -260,18 +260,18 @@ void programmer_delay(const struct flashctx *flash, unsigned int usecs)
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Drivers should either use internal_delay() directly or their
|
* Drivers should either use default_delay() directly or their
|
||||||
* own custom delay. Only core flashrom logic calls programmer_delay()
|
* own custom delay. Only core flashrom logic calls programmer_delay()
|
||||||
* which should always have a valid flash context. A NULL context
|
* which should always have a valid flash context. A NULL context
|
||||||
* more than likely indicates a layering violation or BUG however
|
* more than likely indicates a layering violation or BUG however
|
||||||
* for now dispatch a internal_delay() as a safe default for the NULL
|
* for now dispatch a default_delay() as a safe default for the NULL
|
||||||
* base case.
|
* base case.
|
||||||
*/
|
*/
|
||||||
if (!flash) {
|
if (!flash) {
|
||||||
msg_perr("%s called with NULL flash context. "
|
msg_perr("%s called with NULL flash context. "
|
||||||
"Please report a bug at flashrom@flashrom.org\n",
|
"Please report a bug at flashrom@flashrom.org\n",
|
||||||
__func__);
|
__func__);
|
||||||
return internal_delay(usecs);
|
return default_delay(usecs);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (flash->mst->buses_supported & BUS_SPI) {
|
if (flash->mst->buses_supported & BUS_SPI) {
|
||||||
@ -282,7 +282,7 @@ void programmer_delay(const struct flashctx *flash, unsigned int usecs)
|
|||||||
return flash->mst->par.delay(flash, usecs);
|
return flash->mst->par.delay(flash, usecs);
|
||||||
}
|
}
|
||||||
|
|
||||||
return internal_delay(usecs);
|
return default_delay(usecs);
|
||||||
}
|
}
|
||||||
|
|
||||||
int read_memmapped(struct flashctx *flash, uint8_t *buf, unsigned int start,
|
int read_memmapped(struct flashctx *flash, uint8_t *buf, unsigned int start,
|
||||||
|
10
ichspi.c
10
ichspi.c
@ -875,7 +875,7 @@ static int ich7_run_opcode(OPCODE op, uint32_t offset,
|
|||||||
|
|
||||||
timeout = 100 * 60; /* 60 ms are 9.6 million cycles at 16 MHz. */
|
timeout = 100 * 60; /* 60 ms are 9.6 million cycles at 16 MHz. */
|
||||||
while ((REGREAD16(ICH7_REG_SPIS) & SPIS_SCIP) && --timeout) {
|
while ((REGREAD16(ICH7_REG_SPIS) & SPIS_SCIP) && --timeout) {
|
||||||
internal_delay(10);
|
default_delay(10);
|
||||||
}
|
}
|
||||||
if (!timeout) {
|
if (!timeout) {
|
||||||
msg_perr("Error: SCIP never cleared!\n");
|
msg_perr("Error: SCIP never cleared!\n");
|
||||||
@ -951,7 +951,7 @@ static int ich7_run_opcode(OPCODE op, uint32_t offset,
|
|||||||
/* Wait for Cycle Done Status or Flash Cycle Error. */
|
/* Wait for Cycle Done Status or Flash Cycle Error. */
|
||||||
while (((REGREAD16(ICH7_REG_SPIS) & (SPIS_CDS | SPIS_FCERR)) == 0) &&
|
while (((REGREAD16(ICH7_REG_SPIS) & (SPIS_CDS | SPIS_FCERR)) == 0) &&
|
||||||
--timeout) {
|
--timeout) {
|
||||||
internal_delay(10);
|
default_delay(10);
|
||||||
}
|
}
|
||||||
if (!timeout) {
|
if (!timeout) {
|
||||||
msg_perr("timeout, ICH7_REG_SPIS=0x%04x\n", REGREAD16(ICH7_REG_SPIS));
|
msg_perr("timeout, ICH7_REG_SPIS=0x%04x\n", REGREAD16(ICH7_REG_SPIS));
|
||||||
@ -991,7 +991,7 @@ static int ich9_run_opcode(OPCODE op, uint32_t offset,
|
|||||||
|
|
||||||
timeout = 100 * 60; /* 60 ms are 9.6 million cycles at 16 MHz. */
|
timeout = 100 * 60; /* 60 ms are 9.6 million cycles at 16 MHz. */
|
||||||
while ((REGREAD8(swseq_data.reg_ssfsc) & SSFS_SCIP) && --timeout) {
|
while ((REGREAD8(swseq_data.reg_ssfsc) & SSFS_SCIP) && --timeout) {
|
||||||
internal_delay(10);
|
default_delay(10);
|
||||||
}
|
}
|
||||||
if (!timeout) {
|
if (!timeout) {
|
||||||
msg_perr("Error: SCIP never cleared!\n");
|
msg_perr("Error: SCIP never cleared!\n");
|
||||||
@ -1071,7 +1071,7 @@ static int ich9_run_opcode(OPCODE op, uint32_t offset,
|
|||||||
/* Wait for Cycle Done Status or Flash Cycle Error. */
|
/* Wait for Cycle Done Status or Flash Cycle Error. */
|
||||||
while (((REGREAD32(swseq_data.reg_ssfsc) & (SSFS_FDONE | SSFS_FCERR)) == 0) &&
|
while (((REGREAD32(swseq_data.reg_ssfsc) & (SSFS_FDONE | SSFS_FCERR)) == 0) &&
|
||||||
--timeout) {
|
--timeout) {
|
||||||
internal_delay(10);
|
default_delay(10);
|
||||||
}
|
}
|
||||||
if (!timeout) {
|
if (!timeout) {
|
||||||
msg_perr("timeout, REG_SSFS=0x%08x\n", REGREAD32(swseq_data.reg_ssfsc));
|
msg_perr("timeout, REG_SSFS=0x%08x\n", REGREAD32(swseq_data.reg_ssfsc));
|
||||||
@ -1319,7 +1319,7 @@ static int ich_hwseq_wait_for_cycle_complete(unsigned int len, enum ich_chipset
|
|||||||
while ((((hsfs = REGREAD16(ICH9_REG_HSFS)) &
|
while ((((hsfs = REGREAD16(ICH9_REG_HSFS)) &
|
||||||
(HSFS_FDONE | HSFS_FCERR)) == 0) &&
|
(HSFS_FDONE | HSFS_FCERR)) == 0) &&
|
||||||
--timeout_us) {
|
--timeout_us) {
|
||||||
internal_delay(8);
|
default_delay(8);
|
||||||
}
|
}
|
||||||
REGWRITE16(ICH9_REG_HSFS, REGREAD16(ICH9_REG_HSFS));
|
REGWRITE16(ICH9_REG_HSFS, REGREAD16(ICH9_REG_HSFS));
|
||||||
if (!timeout_us) {
|
if (!timeout_us) {
|
||||||
|
@ -60,7 +60,7 @@ void *master_map_flash_region(const struct registered_master *mast,
|
|||||||
const char *descr, uintptr_t phys_addr, size_t len);
|
const char *descr, uintptr_t phys_addr, size_t len);
|
||||||
void master_unmap_flash_region(const struct registered_master *mast,
|
void master_unmap_flash_region(const struct registered_master *mast,
|
||||||
void *virt_addr, size_t len);
|
void *virt_addr, size_t len);
|
||||||
/* NOTE: flashctx is not used in internal_delay. In this case, a context should be NULL. */
|
/* NOTE: flashctx is not used in default_delay. In this case, a context should be NULL. */
|
||||||
void programmer_delay(const struct flashrom_flashctx *flash, unsigned int usecs);
|
void programmer_delay(const struct flashrom_flashctx *flash, unsigned int usecs);
|
||||||
|
|
||||||
#define ARRAY_SIZE(a) (sizeof(a) / sizeof((a)[0]))
|
#define ARRAY_SIZE(a) (sizeof(a) / sizeof((a)[0]))
|
||||||
|
@ -211,7 +211,7 @@ extern const struct board_info laptops_known[];
|
|||||||
void myusec_delay(unsigned int usecs);
|
void myusec_delay(unsigned int usecs);
|
||||||
void myusec_calibrate_delay(void);
|
void myusec_calibrate_delay(void);
|
||||||
void internal_sleep(unsigned int usecs);
|
void internal_sleep(unsigned int usecs);
|
||||||
void internal_delay(unsigned int usecs);
|
void default_delay(unsigned int usecs);
|
||||||
|
|
||||||
#if CONFIG_INTERNAL == 1
|
#if CONFIG_INTERNAL == 1
|
||||||
/* board_enable.c */
|
/* board_enable.c */
|
||||||
|
@ -146,7 +146,7 @@ static int it8716f_spi_page_program(struct flashctx *flash, const uint8_t *buf,
|
|||||||
if((status & SPI_SR_WIP) == 0)
|
if((status & SPI_SR_WIP) == 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
internal_delay(1000);
|
default_delay(1000);
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -213,7 +213,7 @@ static int nicintel_ee_write_word_i210(uint8_t *eebar, unsigned int addr, uint16
|
|||||||
eewr |= BIT(EEWR_CMDV);
|
eewr |= BIT(EEWR_CMDV);
|
||||||
pci_mmio_writel(eewr, eebar + EEWR);
|
pci_mmio_writel(eewr, eebar + EEWR);
|
||||||
|
|
||||||
internal_delay(5);
|
default_delay(5);
|
||||||
int i;
|
int i;
|
||||||
for (i = 0; i < MAX_ATTEMPTS; i++)
|
for (i = 0; i < MAX_ATTEMPTS; i++)
|
||||||
if (pci_mmio_readl(eebar + EEWR) & BIT(EEWR_DONE))
|
if (pci_mmio_readl(eebar + EEWR) & BIT(EEWR_DONE))
|
||||||
@ -338,7 +338,7 @@ static int nicintel_ee_ready(uint8_t *eebar)
|
|||||||
nicintel_ee_bitbang(eebar, 0x00, &rdsr);
|
nicintel_ee_bitbang(eebar, 0x00, &rdsr);
|
||||||
|
|
||||||
nicintel_ee_bitset(eebar, EEC, EE_CS, 1);
|
nicintel_ee_bitset(eebar, EEC, EE_CS, 1);
|
||||||
internal_delay(1);
|
default_delay(1);
|
||||||
if (!(rdsr & SPI_SR_WIP)) {
|
if (!(rdsr & SPI_SR_WIP)) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -379,7 +379,7 @@ static int nicintel_ee_write_82580(struct flashctx *flash, const uint8_t *buf, u
|
|||||||
nicintel_ee_bitset(eebar, EEC, EE_CS, 0);
|
nicintel_ee_bitset(eebar, EEC, EE_CS, 0);
|
||||||
nicintel_ee_bitbang(eebar, JEDEC_WREN, NULL);
|
nicintel_ee_bitbang(eebar, JEDEC_WREN, NULL);
|
||||||
nicintel_ee_bitset(eebar, EEC, EE_CS, 1);
|
nicintel_ee_bitset(eebar, EEC, EE_CS, 1);
|
||||||
internal_delay(1);
|
default_delay(1);
|
||||||
|
|
||||||
/* data */
|
/* data */
|
||||||
nicintel_ee_bitset(eebar, EEC, EE_CS, 0);
|
nicintel_ee_bitset(eebar, EEC, EE_CS, 0);
|
||||||
@ -394,7 +394,7 @@ static int nicintel_ee_write_82580(struct flashctx *flash, const uint8_t *buf, u
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
nicintel_ee_bitset(eebar, EEC, EE_CS, 1);
|
nicintel_ee_bitset(eebar, EEC, EE_CS, 1);
|
||||||
internal_delay(1);
|
default_delay(1);
|
||||||
if (nicintel_ee_ready(eebar))
|
if (nicintel_ee_ready(eebar))
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
@ -244,7 +244,7 @@ static int pony_spi_init(const struct programmer_cfg *cfg)
|
|||||||
for (i = 1; i <= 10; i++) {
|
for (i = 1; i <= 10; i++) {
|
||||||
data_out = i & 1;
|
data_out = i & 1;
|
||||||
sp_set_pin(PIN_RTS, data_out);
|
sp_set_pin(PIN_RTS, data_out);
|
||||||
internal_delay(1000);
|
default_delay(1000);
|
||||||
|
|
||||||
/* If DSR does not change, we are not connected to what we think */
|
/* If DSR does not change, we are not connected to what we think */
|
||||||
if (data_out != sp_get_pin(PIN_DSR)) {
|
if (data_out != sp_get_pin(PIN_DSR)) {
|
||||||
|
@ -892,7 +892,7 @@ static int send_command_v1(const struct flashctx *flash,
|
|||||||
/* Reattempting will not result in a recovery. */
|
/* Reattempting will not result in a recovery. */
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
internal_delay(RETRY_INTERVAL_US);
|
default_delay(RETRY_INTERVAL_US);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -927,7 +927,7 @@ static int send_command_v1(const struct flashctx *flash,
|
|||||||
/* Reattempting will not result in a recovery. */
|
/* Reattempting will not result in a recovery. */
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
internal_delay(RETRY_INTERVAL_US);
|
default_delay(RETRY_INTERVAL_US);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -962,7 +962,7 @@ static int get_spi_config_v2(struct raiden_debug_spi_data *ctx_data)
|
|||||||
" config attempt = %d\n"
|
" config attempt = %d\n"
|
||||||
" status = 0x%05x\n",
|
" status = 0x%05x\n",
|
||||||
config_attempt + 1, status);
|
config_attempt + 1, status);
|
||||||
internal_delay(RETRY_INTERVAL_US);
|
default_delay(RETRY_INTERVAL_US);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -972,7 +972,7 @@ static int get_spi_config_v2(struct raiden_debug_spi_data *ctx_data)
|
|||||||
" config attempt = %d\n"
|
" config attempt = %d\n"
|
||||||
" status = 0x%05x\n",
|
" status = 0x%05x\n",
|
||||||
config_attempt + 1, status);
|
config_attempt + 1, status);
|
||||||
internal_delay(RETRY_INTERVAL_US);
|
default_delay(RETRY_INTERVAL_US);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1016,7 +1016,7 @@ static int get_spi_config_v2(struct raiden_debug_spi_data *ctx_data)
|
|||||||
config_attempt + 1,
|
config_attempt + 1,
|
||||||
rsp_config.packet_v2.packet_id,
|
rsp_config.packet_v2.packet_id,
|
||||||
rsp_config.packet_size);
|
rsp_config.packet_size);
|
||||||
internal_delay(RETRY_INTERVAL_US);
|
default_delay(RETRY_INTERVAL_US);
|
||||||
}
|
}
|
||||||
return USB_SPI_HOST_INIT_FAILURE;
|
return USB_SPI_HOST_INIT_FAILURE;
|
||||||
}
|
}
|
||||||
@ -1240,7 +1240,7 @@ static int send_command_v2(const struct flashctx *flash,
|
|||||||
/* Reattempting will not result in a recovery. */
|
/* Reattempting will not result in a recovery. */
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
internal_delay(RETRY_INTERVAL_US);
|
default_delay(RETRY_INTERVAL_US);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
for (read_attempt = 0; read_attempt < READ_RETRY_ATTEMPTS;
|
for (read_attempt = 0; read_attempt < READ_RETRY_ATTEMPTS;
|
||||||
@ -1277,7 +1277,7 @@ static int send_command_v2(const struct flashctx *flash,
|
|||||||
}
|
}
|
||||||
/* Device needs to reset its transmit index. */
|
/* Device needs to reset its transmit index. */
|
||||||
restart_response_v2(ctx_data);
|
restart_response_v2(ctx_data);
|
||||||
internal_delay(RETRY_INTERVAL_US);
|
default_delay(RETRY_INTERVAL_US);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
6
serial.c
6
serial.c
@ -403,7 +403,7 @@ int serialport_write(const unsigned char *buf, unsigned int writecnt)
|
|||||||
if (!tmp) {
|
if (!tmp) {
|
||||||
msg_pdbg2("Empty write\n");
|
msg_pdbg2("Empty write\n");
|
||||||
empty_writes--;
|
empty_writes--;
|
||||||
internal_delay(500);
|
default_delay(500);
|
||||||
if (empty_writes == 0) {
|
if (empty_writes == 0) {
|
||||||
msg_perr("Serial port is unresponsive!\n");
|
msg_perr("Serial port is unresponsive!\n");
|
||||||
return 1;
|
return 1;
|
||||||
@ -510,7 +510,7 @@ int serialport_read_nonblock(unsigned char *c, unsigned int readcnt, unsigned in
|
|||||||
ret = 0;
|
ret = 0;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
internal_delay(1000); /* 1ms units */
|
default_delay(1000); /* 1ms units */
|
||||||
}
|
}
|
||||||
if (really_read != NULL)
|
if (really_read != NULL)
|
||||||
*really_read = rd_bytes;
|
*really_read = rd_bytes;
|
||||||
@ -596,7 +596,7 @@ int serialport_write_nonblock(const unsigned char *buf, unsigned int writecnt, u
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
internal_delay(1000); /* 1ms units */
|
default_delay(1000); /* 1ms units */
|
||||||
}
|
}
|
||||||
if (really_wrote != NULL)
|
if (really_wrote != NULL)
|
||||||
*really_wrote = wr_bytes;
|
*really_wrote = wr_bytes;
|
||||||
|
@ -157,7 +157,7 @@ static int sp_synchronize(void)
|
|||||||
goto err_out;
|
goto err_out;
|
||||||
}
|
}
|
||||||
/* A second should be enough to get all the answers to the buffer */
|
/* A second should be enough to get all the answers to the buffer */
|
||||||
internal_delay(1000 * 1000);
|
default_delay(1000 * 1000);
|
||||||
sp_flush_incoming();
|
sp_flush_incoming();
|
||||||
|
|
||||||
/* Then try up to 8 times to send syncnop and get the correct special *
|
/* Then try up to 8 times to send syncnop and get the correct special *
|
||||||
@ -577,7 +577,7 @@ static void serprog_delay(const struct flashctx *flash, unsigned int usecs)
|
|||||||
msg_pspew("%s usecs=%d\n", __func__, usecs);
|
msg_pspew("%s usecs=%d\n", __func__, usecs);
|
||||||
if (!sp_check_commandavail(S_CMD_O_DELAY)) {
|
if (!sp_check_commandavail(S_CMD_O_DELAY)) {
|
||||||
msg_pdbg2("serprog_delay used, but programmer doesn't support delays natively - emulating\n");
|
msg_pdbg2("serprog_delay used, but programmer doesn't support delays natively - emulating\n");
|
||||||
internal_delay(usecs);
|
default_delay(usecs);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if ((sp_max_write_n) && (sp_write_n_bytes))
|
if ((sp_max_write_n) && (sp_write_n_bytes))
|
||||||
|
4
udelay.c
4
udelay.c
@ -235,7 +235,7 @@ void internal_sleep(unsigned int usecs)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Precise delay. */
|
/* Precise delay. */
|
||||||
void internal_delay(unsigned int usecs)
|
void default_delay(unsigned int usecs)
|
||||||
{
|
{
|
||||||
/* If the delay is >1 s, use internal_sleep because timing does not need to be so precise. */
|
/* If the delay is >1 s, use internal_sleep because timing does not need to be so precise. */
|
||||||
if (usecs > 1000000) {
|
if (usecs > 1000000) {
|
||||||
@ -255,7 +255,7 @@ void myusec_calibrate_delay(void)
|
|||||||
get_cpu_speed();
|
get_cpu_speed();
|
||||||
}
|
}
|
||||||
|
|
||||||
void internal_delay(unsigned int usecs)
|
void default_delay(unsigned int usecs)
|
||||||
{
|
{
|
||||||
udelay(usecs);
|
udelay(usecs);
|
||||||
}
|
}
|
||||||
|
@ -155,7 +155,7 @@ static int wbsio_spi_send_command(const struct flashctx *flash, unsigned int wri
|
|||||||
|
|
||||||
OUTB(writearr[0], data->spibase);
|
OUTB(writearr[0], data->spibase);
|
||||||
OUTB(mode, data->spibase + 1);
|
OUTB(mode, data->spibase + 1);
|
||||||
internal_delay(10);
|
default_delay(10);
|
||||||
|
|
||||||
if (!readcnt)
|
if (!readcnt)
|
||||||
return 0;
|
return 0;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user