Tuesday, October 14, 2025

stm32 external loader에서 qspi사용하는 메모리에서 256바이트만 써지고 나머지가 안써질때

stm32_sfdp_driver.c파일에서

EXTMEM_DRIVER_NOR_SFDP_StatusTypeDef EXTMEM_DRIVER_NOR_SFDP_Write(EXTMEM_DRIVER_NOR_SFDP_ObjectTypeDef *SFDPObject, uint32_t Address, const uint8_t* Data, uint32_t Size)

{

EXTMEM_DRIVER_NOR_SFDP_StatusTypeDef retr;

uint32_t size_write;

uint32_t local_size = Size;

uint32_t local_Address = Address;

uint32_t local_Data = (uint32_t)Data;

uint32_t misalignment = 0u;


SFDPObject->sfpd_private.PageSize = 0x100; // 이거 추가


....

}



오류가 나는 경우는 프로그램 페이지 크기가 제대로 안들어가는거 같다.




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



Saturday, August 2, 2025

STM32 시리즈 SPI로 SD카드 읽고 쓰는 소스중에서 


 https://github.com/eziya/STM32_SPI_SDCARD/

가 있다.


이 소스중에 

 https://github.com/eziya/STM32_SPI_SDCARD/blob/master/STM32F4_HAL_SPI_SDCARD/Src/fatfs_sd.c




while(len--); 구문은 오류임.


실제로는 len 보다 1 만큼 많이 실행되어 메모리 침범 오류를 만듭니다.


/* receive data block */

static bool SD_RxDataBlock(BYTE *buff, UINT len)

{

uint8_t token;


/* timeout 200ms */

Timer1 = 200;


/* loop until receive a response or timeout */

do {

token = SPI_RxByte();

} while((token == 0xFF) && Timer1);


/* invalid response */

if(token != 0xFE) return FALSE;


/* receive data */

do {

SPI_RxBytePtr(buff++);

len--;


} while(len--);


/* discard CRC */

SPI_RxByte();

SPI_RxByte();


return TRUE;

}


이것은 아래처럼 수정해야함.



/* receive data block */

static bool SD_RxDataBlock(BYTE *buff, UINT len)

{

uint8_t token;


/* timeout 200ms */

Timer1 = 200;


/* loop until receive a response or timeout */

do {

token = SPI_RxByte();

} while((token == 0xFF) && Timer1);


/* invalid response */

if(token != 0xFE) return FALSE;


/* receive data */

do {

SPI_RxBytePtr(buff++);

len--;


} while(len !=0);


/* discard CRC */

SPI_RxByte();

SPI_RxByte();


return TRUE;

}



len-- 대신 --len을 써도 된다.

그러지 말고 명확하게 하기 위해서 --는 먼저 하고 비교문을 확실히 넣는것이 낫다.