自定义闪存驱动程序DA14695

⚠️
嗨,...感谢您来论坛。令人兴奋的消息!我们现在正在迁至我们的新论坛平台,将提供更好的功能,并包含在主对话框网站中。所有帖子和帐户都已迁移。我们现在只接受新论坛上的流量 - 请发布任何新线程https://www.dialog-seminile.com/support.。我们将在未来几天修复错误/优化搜索和标记。
9个员额/ 0个新员额
最后一篇
aectaan
离线
最后一次露面:6个月3个星期前
加入:2019-10-02 07:06
自定义闪存驱动程序DA14695

嗨对话团队,

目前,我正在尝试根据DA14695培养我的定制板。当我在RAM模式(我的应用程序或来自SDK的任何应用程序中的应用程序时,一切都很好。但是当我试图将它加载到QSPI闪存时,我收到了这条消息

cli_programmer 1.26.
版权所有(c)2015-2019对话半导体雷竞技电竞平台

未指定引导程序文件,使用内部uartboot.bin

上传引导装载程序/应用程序可执行文件...
可执行文件上传。

写地址:0x00002000偏移量:00000000块大小:0x00002000

之后,它卡住了。我创建了Flash驱动程序,如您的教程中所述,重建UartBoot和CLI_Programmer为我的主机配置(DA1469X-00_RELEASE_STORATIC_LINUX)可以验证附加的驱动程序和.xml吗?

/***********************************************************************************************************************************************************中国组解放军军队军队军队军队军队军队军队军队军队军队军队军队军队军队军队军队军队军队军队的BSP中国军队军队军队军队军队军队的BSP P中国系统系统的一个系统的一个BSP P P P P P P P P P P P中国军队军队军队军队军队军队军队的系统的一个系统的一个中国系统的系统的一个存存务务务务务务务务务务务务务务务务系统。系统*********************************************************************上学上学上学上学上学上学上学上学上学上学上学上学上学中国组组解放军军军队军队军队军队军队军队军队军队军队军队军队军队军队军队军队军队军队军队军军军军军军军军军军军军军军军军军军军军军军军军************************************************************************************/#定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,包括,包括,包括“普通的QSPI。H”,包括,包括,包括,包括,包括“普通的QSPI。H”,定义,定义,定义,定义,定义,定义,定义,定义,定义,书写,写写(写)写(写)写)写(写)写(写)启用)易挥发的易易易挥发的0x50 0x50(易易挥发的0x50)的0x50;定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义AT25SL写(写)写(写)写(写)写)和禁用。禁用。禁用0x04。禁用。禁用。禁用。0x04。禁用。4 4。4。禁用。4。4。4。4。4。4。4。4。4。4。4。4。4。4。4。4。4。4。4。4。4_寄存器1 0x01#定义定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写,书写U擦除\程序\挂起0x75#定义AT25SL擦除程序恢复0x7A定义AT25SL深度断电0xB9定义AT25SL释放深度断电0xAB定义AT25SL读取设备ID 0x90定义AT25SL读取ID 0x9F定义AT25SL复位启用0x66定义AT25SL安全复位0x99定义AT25SL读取设备ID 0x90定义AT25SL读取ID 0x9F定义AT25SL复位安全退出定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,阅读,阅读,阅读,阅读,阅读,阅读,阅读,阅读,阅读,阅读,阅读,阅读,阅读,阅读,阅读,阅读,阅读,阅读,阅读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读,读u四元页面_程序0x33#定义定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,定义,测试,测试,设置,设置,设置,设置,设置,设置,设置,设置,设置,设置,设置,设置0x35#定义描述描述描述写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写写数据写写写写写写写读读读读读读读读读数据写写写写写写写写写数据写写写写写写写写数据写写写写数据写QPIQPI 0xQPI 0xQPI 0x0x0x0x0x0x00000QPI 0x0x0000000B B B。B。B。B。B。定义定义。定义。定义。定义。定义。定义。定义写写写写写写写写写写写写写写写写写写写写写写写写写状态写状态写状态写状态写状态写状态写状态写状态写状态写状态。写状态。状态。状态。状态。状态。状态。状态。状态。状态。状态。状态。_QPI 0xC7#定义定义:定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义,定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。定义。读设备设备。读设备。设备。ID。设备设备。ID。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。我方。简历。简历。简历。简历。你们们。简历。简历。简历。i 0xC1#定义定义:定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;定义;若若若若若若若你们们禁用。禁用。禁用。若若若你们们。禁用。若若若若你们们。若若若你们们。。我。我。我。我。禁用。去年去年去年去年去年。我。去年去年。去年。去年。去年。去年。去年。去年。去年。去年。去年。去年。去年。去年。去年。去年。去年。去年。去年。去年。去年。。去年。#定义AT25SL四元页面程序QPI 0x33/*定义一个25SL(U)状态2.U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U U定义AT25SL_通电_延时_US 10#if(dg_配置闪存_断电==1)/***\n简要说明从断电开始处理QSPI闪存激活的uCode.*/**未测试**延迟10usec*0x01//CMD\u NBYTES=0,CMD\u TX\u MD=0(单个),CMD\u VALID=1*0xA0//CMD\u WT\u CNT\u LS=160-->10000/62.5=160=10usec*0x00//CMD\u WT\u CNT\u MS=0*退出快速读取模式*0x09//CMD\u NBYTES=1,CMD\u TX\u MD=0(单个),CMD_VALID=1*0x00//CMD_WT_CNT_LS=0*0x00//CMD_WT_CNT_MS=0*0xFF//启用重置*(最多16个字)*/const uint32_t at25sl_ucode_wakeup[]={0x09000001 |((uint16)(at25sl_POWER up_up_DELAY_US*1000/62.5)&0xFFFF)<<8),0x00FF0000,}#elif(dg_configFLASH_POWER_DOWN==1)/***\n简要说明从断电开始处理QSPI闪存释放的uCode.//**未测试**0x09//CMD\u NBYTES=1,CMD\u TX\u MD=0(单个),CMD\u VALID=1*0x30//CMD\u WT\u CNT\u LS=3000/62.5=48//3usec*0x00//CMD u WT\u CNT\u MS=0*0xAB//Release Power Down*(最多16个字)*/const uint32在25sl\u-ucode唤醒时[={0xAB000009\124;((uint16\t)(at25sl-Release Power Down\u-Down\u-DELAY\ffu*1000/0x5)<62#else/***\简要说明从“连续读取模式”处理QSPI闪存退出的uCode.*/***未测试**0x25//CMD_NBYTES=4,CMD_TX_MD=2(四进制),CMD_VALID=1*0x00//CMD_WT_CNT_LS=0*0x00//CMD_WT_CNT_MS=0*0x55//0-1时钟(A23-16)*0x55//2-3时钟(A15-8)*0x55//4-5时钟(A7-0)*0x55//6-7时钟(M7-0):M5 4!='10'==>禁用“连续读取模式”*(最多16个字)*/const uint32_t at25sl_ucode_wakeup[]={0x55000025,0x00555555,};#endif static bool flash_at25sl_is_suspended(HW_QSPIC_ID id); static void flash_at25sl_initialize(HW_QSPIC_ID id); /** * \brief Enable volatile writes to Status Register bits * \details When this command is issued, any writes to any of the Status Registers of the Flash are * done as volatile writes. This command is valid only when the Write Status Register command * follows. * * \param[in] id QSPI controller id * * \note This function blocks until the Flash has processed the command. */ __STATIC_FORCEINLINE __UNUSED void flash_at25sl_wre_volatile(HW_QSPIC_ID id) { uint8_t cmd[] = { AT25SL_WRITE_ENABLE_FOR_VOLATILE }; flash_write(id, cmd, 1); /* Verify */ while (flash_is_busy(id)); } __STATIC_FORCEINLINE uint8_t flash_at25sl_read_status_register_2(HW_QSPIC_ID id) { __DBG_QSPI_VOLATILE__ uint8_t status; uint8_t cmd[] = { AT25SL_READ_STATUS_REGISTER2 }; flash_transact(id, cmd, 1, &status, 1); return status; } /** * \brief Write the Status Register 2 of the Flash * * \param[in] id QSPI controller id * \param[in] value The value to be written. * * \note This function blocks until the Flash has processed the command. No verification that the * value has been actually written is done though. It is up to the caller to decide whether * such verification is needed or not and execute it on its own. */ __STATIC_FORCEINLINE void flash_at25sl_write_status_register_2(HW_QSPIC_ID id, uint8_t value) { uint8_t cmd[] = { AT25SL_WRITE_STATUS_REGISTER2, value }; flash_write(id, cmd, 2); /* Wait for the Flash to process the command */ while (flash_is_busy(id)); } __STATIC_FORCEINLINE void flash_at25sl_enable_quad_mode(HW_QSPIC_ID id) { uint8_t status; status = flash_at25sl_read_status_register_2(id); if (!(status & AT25SL_STATUS2_QE_MASK)) { flash_write_enable(id); flash_at25sl_write_status_register_2(id, status | AT25SL_STATUS2_QE_MASK); } } __RETAINED_CODE static bool flash_at25sl_is_suspended(HW_QSPIC_ID id) { __DBG_QSPI_VOLATILE__ uint8_t status; status = flash_at25sl_read_status_register_2(id); return (status & AT25SL_STATUS2_SUS_MASK) != 0; } __RETAINED_CODE static void flash_at25sl_initialize(HW_QSPIC_ID id) { flash_at25sl_enable_quad_mode(id); } #endif /* _QSPI_ADESTO_H_ */ /** * \} * \} */
/ ** * \ addtogroup PLA_BSP_SYSTEM * \ {* \ addtogroup PLA_MEMORY * * \ {* / / ** **************************************************************************************** * * @file qspi_at25sl321.h * * @brief QSPI flash driver for the Adesto AT25SL321 * * Copyright (C) 2017-2019 Dialog Semiconductor. * This computer program includes Confidential, Proprietary Information * of Dialog Semiconductor. All Rights Reserved. * **************************************************************************************** */ #ifndef _QSPI_AT25SL321_H_ #define _QSPI_AT25SL321_H_ #ifndef ADESTO_ID #define ADESTO_ID 0x1F #endif // Device type using command 0x9F #define AT25SL321 0x15 #ifndef AT25SL321_32Mb_SIZE #define AT25SL321_32Mb_SIZE 0x16 #endif #include "qspi_common.h" #include "sdk_defs.h" #include "qspi_adesto.h" static void flash_at25sl321_sys_clock_cfg(HW_QSPIC_ID id, sys_clk_t sys_clk); static uint8_t flash_at25sl321_get_dummy_bytes(HW_QSPIC_ID id); static const qspi_flash_config_t flash_at25sl321_config = { .manufacturer_id = ADESTO_ID, .device_type = AT25SL321, .device_density = AT25SL321_32Mb_SIZE, .is_suspended = flash_at25sl_is_suspended, .initialize = flash_at25sl_initialize, .sys_clk_cfg = flash_at25sl321_sys_clock_cfg, .get_dummy_bytes = flash_at25sl321_get_dummy_bytes, .break_seq_size = HW_QSPI_BREAK_SEQ_SIZE_2B, .address_size = HW_QSPI_ADDR_SIZE_24, .page_program_opcode = AT25SL_PAGE_PROGRAM, .page_qpi_program_opcode = AT25SL_PAGE_PROGRAM_QPI, .quad_page_program_address = false, .fast_read_opcode = AT25SL_FAST_READ_QUAD_IO, .erase_opcode = AT25SL_BLOCK_ERASE_4KB, .erase_suspend_opcode = AT25SL_ERASE_PROGRAM_SUSPEND, .erase_resume_opcode = AT25SL_ERASE_PROGRAM_RESUME, .read_erase_progress_opcode = AT25SL_READ_STATUS_REGISTER1, .erase_in_progress_bit = FLASH_STATUS_BUSY_BIT, .erase_in_progress_bit_high_level = true, .send_once = 1, .extra_byte = 0xA0, .ucode_wakeup = {at25sl_ucode_wakeup, sizeof(at25sl_ucode_wakeup)}, .power_down_delay = AT25SL_POWER_DOWN_DELAY_US, .release_power_down_delay = AT25SL_RELEASE_POWER_DOWN_DELAY_US, .power_up_delay = AT25SL_POWER_UP_DELAY_US, .is_ram = false, .qpi_mode = false, .enter_qpi_opcode = AT25SL_ENABLE_QPI, .memory_size = MEMORY_SIZE_32Mb, }; __RETAINED_CODE static void flash_at25sl321_sys_clock_cfg(HW_QSPIC_ID id, sys_clk_t sys_clk) { } __RETAINED_CODE static uint8_t flash_at25sl321_get_dummy_bytes(HW_QSPIC_ID id) { return 1; } #endif /* _QSPI_W32Q32FW_H_ */ /** * \} * \} */
 <配置名称= “MX25U3235F”> 为0x400000   0xa8a500eb   0x00000066   0×01 0×40 0×07   <配置名称= “W25Q32FW”> 为0x400000   0xa82000eb   0x00000066   0X31 0×02 0×07   <配置名称=”GD25LE32 “> 为0x400000   0xa82000eb   0x00000066   0×01 0×00 0×02 0×07   <配置名称=” AT25SL321" >为0x400000   0xa8a000eb   0x00000066   0×01 0×00 0×02 0×07   
<?XML Version =“1.0”编码=“UTF-8”?>   da1469x-00    0x2000   0x2000   AT25SL321  为0x400000   0xa8a500eb   0x66  为0x1为0x0 0X2 0x7的  

设备:
PM_DIALOG.
离线
最后一次露面:1天18小时前
职员
加入:2018-02-08 11:03
嗨aectaan,

嗨aectaan,

非常感谢您在我们的公共蓝牙论坛上的问题以及使用我们的BLE解决方案。我已经在团队内部升级了你的问题,所以我会尽快恢复给你,因为我有任何更新。我可以问你是否有基于DA14695的产品?

谢谢,PM_DIALOG.

aectaan
离线
最后一次露面:6个月3个星期前
加入:2019-10-02 07:06
嗨PM_Dialog,

嗨PM_Dialog,

是的,我们评估了DA14695 USB套件,并决定使用DA14695和SLG46826开始我们的当前项目

PM_DIALOG.
离线
最后一次露面:1天18小时前
职员
加入:2018-02-08 11:03
嗨aectaan,

嗨aectaan,

谢谢你的最新消息。正如我在之前的评论中提到的,我已经在内部升级了你的问题。我会与你保持联系!

谢谢,PM_DIALOG.

PM_DIALOG.
离线
最后一次露面:1天18小时前
职员
加入:2018-02-08 11:03
嗨aectaan,

嗨aectaan,

这是正常的行为,您的应用程序从RAM正确运行,没有任何问题。雷竞技安卓下载原因是,当固件从RAM执行时,只要没有从/到Flash的数据事务,Flash就不会被使用。然而,当在错误初始化的Flash上使用Flash操作时,它很可能无法正常工作。请查看以下我的评论:

XML文件条目似乎是正确的,但我们不能保证它,因为我们现在不能测试它。通常,XML条目用于在Product Header中编写初始化所使用的Flash所需的适当信息,以便已经下载的固件将在引导时正确地重新初始化Flash。

2]我们发现JEDEC_ID读取信息配置错误。

预期的命令9FH预期的字节不正确。根据Flash数据表,第12页命令9FH返回制造商ID(0x1F),内存类型ID(0x42)和容量类型ID(0x16)。在文件at25sl321.h中,使用设备ID(0x15)而不是存储器类型ID(0x42)。这可能源于闪光制造商似乎喜欢对同样的措辞使用不同的措辞,经常对驾驶员开发商造成混淆。在每个字段旁边的Flash数据表中,提到了每个字节返回的指令。为此,应执行以下操作:

#define AT25SL321 0x15 +++ #define AT25SL321 0x42

每当在引导过程中使用FLASH_AUTODETECT时,DA1469x设备将向Flash发出Read JEDEC_ID 9Fh命令。如果返回的信息与驱动程序中定义的配置对象中使用的Flash值匹配,并且包含了驱动程序,那么Flash就会被识别并加载正确的配置。这样,Flash根据驱动程序的规格进行初始化。如果返回的信息与包含的驱动程序的任何信息都不匹配,则设备将无法启动或操作。

通常,UartBoot默认使用Flash_AutoDetect,因此它将无法初始化和操作闪存。

3]根据数据表。我们还注意到使用了不正确的电源延迟。

从上电到设备准备接收命令所需的时间为1-10ms。每次DA1469x设备上电以及每次Flash设备上电时都使用此延迟。例如,如果在睡眠期间,开发人员选择了Flash关机,当它醒来时,它将不得不重新启动(例如,如果在配置文件dg_configFLASH_POWER_OFF被定义并设置为1)。

它强烈推荐使用最大延迟只是安全。使用的值是驱动程序中的10个,但驱动程序期望稍微延迟μEC而不是MSEC。因此,根据我们的评论,我们认为#define at25sl_power_up_delay_us的正确值应该是10000。

--- #define at25sl_power_up_delay_us 10 +++ #define at25sl_power_up_delay_us 10000

flash_at25sl321_config结构中的。quad_page_program_address项应该设置为" true "。

地址是以Quad模式发送的,因此该字段的值应该为真以反映这一点。如果它被设置为“false”,那么它将尝试以单一模式发送地址,而不是导致写入错误的地址。

--- .quad_page_program_address =假,+++ .quad_page_program_address = TRUE,

5]在flash_at25sl321_get_dummy_bytes()函数中,返回值为1。根据数据表,它应该是2,除非在80 MHz下运行,而使用QPI模式,并设置了寄存器。我们怀疑返回值应该被改变,以使设备正常工作,以及值2。

请尝试建议的更改,并让我知道它是否正在工作。欢迎您的反馈!

谢谢,PM_DIALOG.

aectaan
离线
最后一次露面:6个月3个星期前
加入:2019-10-02 07:06
谢谢你,PM_Dialog!

谢谢你,PM_Dialog!

您的建议非常有助于:将它们应用于我的司机后,我就是能够删除闪存。之后,我发现并修复了我的司机中的另一个错误。现在,它有效!

问候,Egor。

PM_DIALOG.
离线
最后一次露面:1天18小时前
职员
加入:2018-02-08 11:03
嗨Egor,

嗨Egor,

谢谢你接受我的回答,很高兴你能让它工作。有没有可能分享你对你的驱动做了哪些其他修改?另外,除了擦除程序之外,你有没有尝试从Flash执行固件?

任何其他投入/评论/会非常欢迎!

谢谢,PM_DIALOG.

aectaan
离线
最后一次露面:6个月3个星期前
加入:2019-10-02 07:06
是的,我试图执行

是的,我试过用flash执行固件,没问题。

我连着.ZIP与整顿的qspi_at25sl321.h和flash_configurations.xml。我希望,这将是为其他客户很有帮助。

谢谢,Egor.

PM_DIALOG.
离线
最后一次露面:1天18小时前
职员
加入:2018-02-08 11:03
嗨Egor,

嗨Egor,

感谢你的投入。如果您有任何其他问题,请提出新的论坛门票。

谢谢,PM_DIALOG.