Thursday, October 9, 2025

STM32CubeProgrammer error when Erase full chip External Flash.

Version 2.17 is no error

Version 2.20 - error


STM32CubeProgrammer 2.17 is stable.


STM32CubeProgrammer를 위한 External loader에서 Write한것이 첫바이트가 사라질때

STM32CubeMX 최신버전 (6.15)이상에서 External Loader를 만들면 기본적인 기능을 모두 만들어준다.

그런데 QSPI용 Nor flash  메모리 MX25L6433F를 사용하도록 세팅해보니 내가 Write한 내용의 첫바이트가 사라지는 현상이 있었다.


원인을 찾아보니 Flash write,read명령 중에 dummy cycle가 필요한 경우도 있지만 없는 경우도 있음에도 불구하고

dummy cycle이 8로 지정되어있음을 확인했고, 그것을 0으로 변경하니 잘 돌아갔다.


문제의 코드는 이러하다


Muddlewares/ST/STM32_ExtMem_Manager/stm32_sal_xspi.c 

HAL_StatusTypeDef SAL_XSPI_MemoryConfig(SAL_XSPI_ObjectTypeDef *SalXspi, SAL_XSPI_MemParamTypeTypeDef ParametersType, void *ParamVal)

{

HAL_StatusTypeDef retr = HAL_OK;

XSPI_RegularCmdTypeDef s_commandbase = SalXspi->Commandbase;


switch (ParametersType) {

case PARAM_PHY_LINK:{

SalXspi->PhyLink = *((SAL_XSPI_PhysicalLinkTypeDef *)ParamVal);

DEBUG_PARAM_BEGIN(); DEBUG_PARAM_DATA("::PARAM_PHY_LINK::");DEBUG_PARAM_DATA(STR_PHY_LINK(SalXspi->PhyLink));

switch (SalXspi->PhyLink)

{

case PHY_LINK_1S1D1D:

case PHY_LINK_1S2S2S:

case PHY_LINK_1S1S2S:

case PHY_LINK_1S1S1S: {

s_commandbase.InstructionMode = HAL_XSPI_INSTRUCTION_1_LINE;

s_commandbase.InstructionWidth = HAL_XSPI_INSTRUCTION_8_BITS;

s_commandbase.InstructionDTRMode = HAL_XSPI_INSTRUCTION_DTR_DISABLE;

s_commandbase.AddressMode = HAL_XSPI_ADDRESS_1_LINE;

s_commandbase.AddressWidth = HAL_XSPI_ADDRESS_24_BITS;

s_commandbase.AddressDTRMode = HAL_XSPI_ADDRESS_DTR_DISABLE;

s_commandbase.DataMode = HAL_XSPI_DATA_1_LINE;

s_commandbase.DataDTRMode = HAL_XSPI_DATA_DTR_DISABLE;

s_commandbase.DummyCycles = 8; // 0으로 변경해야함

s_commandbase.DQSMode = HAL_XSPI_DQS_DISABLE;

break;

}


이하 생략



위에서 DummyCycles를 0으로 수정하면 잘 돌아간다.




-----------------------------------

Problem : STM32CubeMx generated External loader miss first byte write/read with QSPI Flash memory

Solution : Change DummyCycles to 0