esp32_spiflash.c: Keep the index of the other CPU between SPI Flash
operations. Signed-off-by: Abdelatif Guettouche <abdelatif.guettouche@espressif.com>
This commit is contained in:
parent
eeb68bda3d
commit
f54a929001
@ -161,6 +161,9 @@ struct spiflash_map_req
|
|||||||
struct spiflash_cachestate_s
|
struct spiflash_cachestate_s
|
||||||
{
|
{
|
||||||
int cpu;
|
int cpu;
|
||||||
|
#ifdef CONFIG_SMP
|
||||||
|
int other;
|
||||||
|
#endif
|
||||||
irqstate_t flags;
|
irqstate_t flags;
|
||||||
uint32_t val[2];
|
uint32_t val[2];
|
||||||
};
|
};
|
||||||
@ -405,26 +408,23 @@ static inline void spi_reset_regbits(struct esp32_spiflash_s *priv,
|
|||||||
static inline void IRAM_ATTR
|
static inline void IRAM_ATTR
|
||||||
esp32_spiflash_opstart(struct spiflash_cachestate_s *state)
|
esp32_spiflash_opstart(struct spiflash_cachestate_s *state)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_SMP
|
|
||||||
int other;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
state->flags = enter_critical_section();
|
state->flags = enter_critical_section();
|
||||||
|
|
||||||
state->cpu = up_cpu_index();
|
state->cpu = up_cpu_index();
|
||||||
#ifdef CONFIG_SMP
|
#ifdef CONFIG_SMP
|
||||||
other = state->cpu ? 0 : 1;
|
state->other = state->cpu ? 0 : 1;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
DEBUGASSERT(state->cpu == 0 || state->cpu == 1);
|
DEBUGASSERT(state->cpu == 0 || state->cpu == 1);
|
||||||
#ifdef CONFIG_SMP
|
#ifdef CONFIG_SMP
|
||||||
DEBUGASSERT(other == 0 || other == 1);
|
DEBUGASSERT(state->other == 0 || state->other == 1);
|
||||||
up_cpu_pause(other);
|
DEBUGASSERT(state->other != state->cpu);
|
||||||
|
up_cpu_pause(state->other);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
spi_disable_cache(state->cpu, &state->val[state->cpu]);
|
spi_disable_cache(state->cpu, &state->val[state->cpu]);
|
||||||
#ifdef CONFIG_SMP
|
#ifdef CONFIG_SMP
|
||||||
spi_disable_cache(other, &state->val[other]);
|
spi_disable_cache(state->other, &state->val[state->other]);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -439,23 +439,16 @@ static inline void IRAM_ATTR
|
|||||||
static inline void IRAM_ATTR
|
static inline void IRAM_ATTR
|
||||||
esp32_spiflash_opdone(const struct spiflash_cachestate_s *state)
|
esp32_spiflash_opdone(const struct spiflash_cachestate_s *state)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_SMP
|
|
||||||
int other;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef CONFIG_SMP
|
|
||||||
other = state->cpu ? 0 : 1;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
DEBUGASSERT(state->cpu == 0 || state->cpu == 1);
|
DEBUGASSERT(state->cpu == 0 || state->cpu == 1);
|
||||||
#ifdef CONFIG_SMP
|
#ifdef CONFIG_SMP
|
||||||
DEBUGASSERT(other == 0 || other == 1);
|
DEBUGASSERT(state->other == 0 || state->other == 1);
|
||||||
|
DEBUGASSERT(state->other != state->cpu);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
spi_enable_cache(state->cpu, state->val[state->cpu]);
|
spi_enable_cache(state->cpu, state->val[state->cpu]);
|
||||||
#ifdef CONFIG_SMP
|
#ifdef CONFIG_SMP
|
||||||
spi_enable_cache(other, state->val[other]);
|
spi_enable_cache(state->other, state->val[state->other]);
|
||||||
up_cpu_resume(other);
|
up_cpu_resume(state->other);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
leave_critical_section(state->flags);
|
leave_critical_section(state->flags);
|
||||||
|
Loading…
Reference in New Issue
Block a user