NVMS库写/读/验证不匹配

⚠️
嗨,...感谢您来论坛。令人兴奋的消息!我们现在正在迁至我们的新论坛平台,将提供更好的功能,并包含在主对话框网站中。所有帖子和帐户都已迁移。我们现在只接受新论坛上的流量 - 请发布任何新线程https://www.dialog-seminile.com/support.。我们将在未来几天修复错误/优化搜索和标记。
13个帖子/ 0新
最后一篇
daisuke_suzuki.
离线
最后一次露面:3年1周前
加入:2015-09-16 08:36
NVMS库写/读/验证不匹配

嗨对话框。

我有个问题。
我使用NVMS库。
我重复猛烈地写入,读取和验证数据。
有时数据不匹配。

使用NVMS库是否有任何限制?

硬件是DA14681-01A9DEVKT-P开发套件 - PRO。
SDK版本是SDK_1.0.10.1072。
我尝试了Ves分区和直接访问分区。
两者都失败了。

关键词:
设备:
mt_dialog.
离线
最后一次露面:6个月3周前
职员
加入:2015-06-08 11:34
嗨daisuke_suzuki,

嗨daisuke_suzuki,

我不认为他们是任何限制,我不知道NVMS库中的任何错误,当你提到剧烈使用图书馆时,你究竟在做了什么?您是否在对话框Pro Dev套件或定制板上进行测试?如果您在自定义板上使用此操作,您是否使用了您在自定义板上拥有的闪存的正确闪存驱动程序?它有助于提及您在做什么,以便我检查我是否可以复制。

谢谢mt_dialog.

daisuke_suzuki.
离线
最后一次露面:3年1周前
加入:2015-09-16 08:36
嗨对话框。

嗨对话框。

>
>我不认为他们是任何限制,我不知道NVMS库中的任何错误,
>当你提到猛烈地使用图书馆时,你究竟在做了什么?
>

我已将测试项目附加到此回复。

>
>您是否在对话框Pro Dev套件上或在定制板上进行测试?
>如果您在自定义板上使用了您使用的闪存驱动程序,您可以在您的自定义板上使用闪光灯吗?
>

我使用Dialog Pro Dev套件板。

>
>有助于提及您在做什么,以便我检查我是否可以复制。
>

请按照以下步骤操作。

0.下载archive.zip。
1. unzip archive.zip。
2.进口项目。
3.构建BootLoader_Release。
4.构建devkit_release。
5.通过USB电缆连接电路板和PC。
6.写计划。
7.打开COM端口连接板。请使用teraterm。
8.按住载板的重置开关。
9.输入“测试10”。
10.检查输出。

如果您重复测试几次,则会失败。

[好的]
/ ************************************************ /
/ * devkit:释放(NVMS测试)* /
/ ************************************************ /

NVMS>测试10
count = 10。
测试[01] ......好的
测试[02] ...好的
测试[03] ......好的
测试[04] ......好的
测试[05] ......好的
测试[06] ...好吧
测试[07] ......好的
测试[08] ......好的
测试[09] ......好的
测试[10] ...好吧
NVMS>

[ng]
/ ************************************************ /
/ * devkit:释放(NVMS测试)* /
/ ************************************************ /

NVMS>测试10
count = 10。
测试[01] ......好的
测试[02] ...好的
测试[03] ......好的
测试[04] ......好的
测试[05] ......好的
测试[06] ...错误
索引不匹配[线= 138]
NVMS>

此测试程序是test_cmd函数。
请检查\ archive \ main \ src \ framework \ common \ shell \ command \ test \ test_cmd.c。

依恋:
mt_dialog.
离线
最后一次露面:6个月3周前
职员
加入:2015-06-08 11:34
嗨daisuke_suzuki,

嗨daisuke_suzuki,

从代码中,我看到您已经从SDK中获取了相当多的文件,并且您已经自定义了Enitre SDK以满足您的需求,并且还试图调试FW以检查您正在做的任何事情以及它是不可能的。几个评论中可能与您遇到的内容有关,是设备中没有分区表,我的意思是您正在运行和访问NVMS_GENERIC_PART但应在启动时创建的实际分区表,其根本不是在那里,我还无法看看是否使用直接访问闪存或ves,(虽然在分区表中声明为partition_flag_ves,但没有配置文件来检查项目的NVM的配置)。Flash的API是非常测试的,他们应该在他们应该工作。

谢谢mt_dialog.

daisuke_suzuki.
离线
最后一次露面:3年1周前
加入:2015-09-16 08:36
嗨对话框。

嗨对话框。

>
>从代码中,我看到您已经从SDK和SDK中获取了很多文件
>您已定制Enitre SDK以满足您的需求,
>也试图调试FW以检查您正在做的任何事项,也是不可能的。
>

毕竟,你确认了吗或好吗?

>
>一些评论可能与您所在的内容有关,
>设备中没有分区表,
>我的意思是您正在运行和访问NVMS_GENERIC_PART但实际分区表
>应该在启动时创建,它根本不在那里,我也无法看看你是否正在使用直接
>访问Flash或Ves,(虽然在分区表中,Generic_part被声明为partition_flag_ves,
>没有配置文件来检查项目的NVMS的配置)。
>

我认为分区表的设置是以下文件。

\ archive \ main \ src \ framework \ common \ sdk \ bsp \ config \ 1m \ suota \ partition_table.h

正确的?

什么是不存在的配置文件?

告诉我来自da1468x_da15xxx_sdk_1.0.10.1072的相对路径。

>
>闪光灯的API是非常测试的,他们应该在他们应该工作。
>

告诉我你正在做什么样的测试。
请告诉我测试代码。

mt_dialog.
离线
最后一次露面:6个月3周前
职员
加入:2015-06-08 11:34
嗨daisuke_suzuki,

嗨daisuke_suzuki,

对不起,我不会通过提到你的意思“毕竟你确认了NG或OK?”

是的,分区表的设置位于该文件中,在启动时,设备应在初始化组件期间创建分区表,但在您的FW中我尝试从智能代码片工具读取分区表,以便检查读取并写出并没有创建分区表。

关于它不存在的配置文件,主要项目中的自定义_config_qspi.h文件在哪里?

关于测试,SDK在发布之前通过重大测试,您可以使用AD_NVMS_WRITE()和AD_NVMS_READ()函数来获取任何参考示例并写入闪光灯。我还在SDK示例中运行Test_Wrv()函数(调用的test_wrv(count)硬编码在10和20中的计数值),并且设备每次都有成功完成,并且我也可以看到闪存中写入分区的数据。

谢谢mt_dialog.

daisuke_suzuki.
离线
最后一次露面:3年1周前
加入:2015-09-16 08:36
>

>
>对不起,我不承认你的意思是提到“毕竟你确认了NG或OK?”
>

我想知道你是否跑了我的测试。

你有测试吗?

测试结果如何?ng?好?

我想知道这个问题是否只发生了我的硬件。

如果您还没有这样做,请在使用附带的项目上运行我的测试。

>
>是的
>分区表的设置位于该文件中,在启动时,设备应创建分区表
>在初始化组件期间,但在您的FW中我尝试从智能片段工具读取分区表时,
>为了检查读写,没有创建分区表。
>

我检查了智能片段工具。

在此工具中,分区表的地址设置为0x7f000。(我不知道这个地址为什么是常量。)

因此,我将分区表的地址从0x89000更改为0x7f000。

此工具能够读取分区表。

但是,我的测试在改变后的项目上失败了。

附上更改项目。

在附加项目中,我提出了以下修改。

·在程序中添加Get_pt命令读取分区表。
·更改Test_Wrv()以在发生错误时增加信息输出。
·更改分区表
·删除不必要的SDK更改

>
>关于它不存在的配置文件,主要项目中的custom_config_qspi.h文件在哪里?
>

当然,我的项目中没有custom_config_qspi.h。

在此文件中确定的代码已被移动到devkit_config.h。

所以我删除了custom_config_qspi.h。

>
>我还在SDK示例中运行test_wrv()函数(调用test_wrv(count)硬编码在10和20中的计数值)和
>设备每次都有成功完成,我也可以看到闪存中写入分区的数据。
>

好的!!伟大的!!

Test_Wrv()函数每次在项目中都有成功完成。

对?

我想将您的项目与我的项目进行比较。

请给我你的项目。

mt_dialog.
离线
最后一次露面:6个月3周前
职员
加入:2015-06-08 11:34
嗨daisuke_suzuki,

嗨daisuke_suzuki,

我运行了上一个项目,您已附加,测试失败,如您所提到的,但这是由于项目未创建分区表以及大多数可能分区,以便读取和写入闪存。

我所做的就是采取SDK 1.0.12(SDK确实在写作过程中有一个错误,这是用新的SDK 1.0.12)和BLE_APP项目纠正,在该项目中,我颁发了以下更改:

  1. 将下面的代码放在下面的代码,用于在BLE_ADV_DEMO_TASK中BLE_GAP_ADV_START()之前测试您的测试:
    1. for(i = 0; i <20; i ++){
      test_setup();
      test_wrv(i + 1);
      test_tear_down();
      }
  2. 有上述功能从您所附的项目中复制,并且在错误的情况下,我还附上了一些断言。
  3. 通过config_retarget和config_retarget_uart hw_uart2启用了打印
  4. 禁用看门狗。

FW为指定的测试成功运行。

如果您想在SDK 1.0.10上测试应用程序修补程序,您只需从SDK 1.0.12中获取以下函数并将其应用于旧的SDK。

  1. 将* qspi_pending_ops初始化为null:privileged_data static qspi_ops * qspi_pending_ops = null;
  2. 用来自SDK 1.0.12的相应函数替换pm_execute_active_wfi(),pm_process_completed_qspi_opi_opi_opirations()和pm_register_qspi_operations()。

谢谢mt_dialog.

daisuke_suzuki.
离线
最后一次露面:3年1周前
加入:2015-09-16 08:36
嗨mt_dialog.

嗨mt_dialog.

>
>我运行了上一个项目,您已附加,测试失败,如上所述,
>但这是由于该项目没有创建分区表和
>大多数可能是分区,以便读取和写入闪光灯。
>

等一下。

你在思考如下,不是吗?

“分区表未在此项目中进行。”

你认为这不是以下原因的原因是以下的原因?

“我无法使用智能片段工具读取分区表。”

在最后的回复中,我告诉过以下了。

您无法使用Smart Spippets工具读取分区表的原因是
因为该工具以固定值(0x07f000)读取分区表的地址。

这不是项目中未在项目中进行分区表的原因。

你明白?
是错的吗?

测试也会在您的环境中失败,因此我认为硬件不是这个问题的原因。

我相信这个问题是由NVMS库中的错误引起的。
(也许我认为闪存驱动程序的实现存在问题。)

你怎么看待这件事?

>
>我所做的就是采取SDK 1.0.12
>(SDK确实在写入过程中有一个错误,并通过新的SDK 1.0.12纠正了这一点)
> BLE_APP项目,在该项目中,我发出以下更改:
>
> 1。将下面的代码放在下面的代码,用于在BLE_ADV_DEMO_TASK中BLE_GAP_ADV_START()之前测试您的测试:
> for(i = 0; i <20; i ++){
> test_setup();
> test_wrv(i + 1);
> test_tear_down();
>}
>
> 2。有上述功能从您所附的项目中复制,并且在错误的情况下,我还附上了一些断言。
> 3。通过config_retarget和config_retarget_uart hw_uart2启用了打印
> 4。禁用看门狗。
>
> FW为指定的测试成功运行。
>

你明白我的意思吗?

我告诉过你“请给我你的项目。”
我不询问如何制作项目。
你为什么不附上这个项目?

如果我这样做,我可能会犯错误。
如果附上一个项目,则没有错误。

>
>如果您想在SDK 1.0.10上测试应用补丁
>您可以简单地从SDK 1.0.12获取以下功能,并将其应用于旧的SDK。
>
> 1。将* qspi_pending_ops初始化为null:privileged_data static qspi_ops * qspi_pending_ops = null;
> 2。用来自SDK 1.0.12的相应函数替换pm_execute_active_wfi(),pm_process_completed_qspi_opi_opi_opirations()和pm_register_qspi_operations()。
>

你是说“因为SDK 1.0.10中有一个错误,适用补丁。”?

daisuke_suzuki.
离线
最后一次露面:3年1周前
加入:2015-09-16 08:36
嗨mt_dialog.

嗨mt_dialog.

我读取发行说明(da1468x_da15xxx_sdk_release_notes_v_1_0_12_1078.pdf),闪存驱动程序中有一个错误。

1072.01
将DG_CONFIGDISABLE_BACKGROUND_FLASH_OPS更改为1可能导致故障
在96MHz的编程Winbond闪存设备

>
>闪光灯的API是非常测试的,他们应该在他们应该工作。
>

???

你不知道这个错误吗?

我的测试将DG_CONFIGDISABLE_BACKGROUND_FLASH_OPS设置为0,但系统时钟设置为96MHz。

我的测试失败了我的环境和环境。

如果dg_configdisable_background_flash_ops为零,它是否正常工作?

如果没有任何调查,请不要回答。

mt_dialog.
离线
最后一次露面:6个月3周前
职员
加入:2015-06-08 11:34
嗨daisuke_suzuki,

嗨daisuke_suzuki,

我经营并测试了你所附的第一个项目,并且项目失败了,我提到我找不到该项目的分区表,这一事实可能是您遇到的问题的最可能原因(这是我注意的第一件事,所以这就是我推荐的),也为了测试你的测试代码我在SDK示例中应用了以下Mod(我发布了)才能验证测试我能够运行您在项目中实现的测试(这是在SDK 1.0.12上完成的,因为您没有分区表看起来逻辑解释)。

我还测试了您上传的附加项目,您已经应用于您所应用的更正,以便具有正确的分区表,所需的项目也失败。因此,为了找到您使用SDK 1.0.10的情况下可能出错的事实。引起我的注意,记住SDK 1.0.10上有一个错误,有时由于中断写入可能会失败。所以我所做的是从SDK 1.0.12应用SDK 1.0.10上的修复程序(正如我所建议的那样,你试一试,所以是的,我知道自从我提出如何在SDK 1.0.10上修复它以来的错误)。所以在我的侧面,我将修复程序应用于SDK 1.0.10上以前提到的,并在SDK 1.0.12上运行相同的东西,以验证您的测试至少在SDK演示中是否成功运行。并且演示确实成功运行,在重置设备时执行测试,直到现在现在,SDK上都没有失败。

我完全明白你对提供项目的说法但是,Mods非常简单,我假设您可以尝试它们,无论如何,在附件中,您将使用应用于SDK 1.0.12上的补丁,构建项目,并将其下载到套件上。我还通过修复并运行一些测试,并且您的项目应该运行,并且在没有错误的时间内运行测试10和100的测试。

再次有关DG_CONFIGDISABLE_BACKGRING_BORASH_OPS,SDK应该始终在运行闪存擦除时设置为0的DG_CONFIGDISABLE_BACKGRIND_FLASH_OPS,因为运行闪存擦除时,将被遗漏(设备将在指示时执行擦除),因此建议使用它来运行
dg_configdisable_background_flash_ops设置为0,这不是一个错误,但系统的限制。和我跑的测试有了
dg_configdisable_background_flash_ops设置为0,如SDK演示。

我还提到你已经非常讨厌并替换了一些SDK文件并通过这样做,通过执行此操作来定制项目,我无法遵循设置
你对你的项目有了,需要花费大部分时间来调试和检查可能出错的时间,所以我只能对你的项目提出建议
附上了,没有调试它
或者跟随您的测试正常在做什么,我希望这很清楚,你理解这一点。我们不建议在SDK上建议这样的繁重修改的原因是因为它难以调试,当您希望将FW更新到最新的SDK时,您还会有问题,您还有项目中的SDK副本何时修改SDK的一个文件,它不会影响您在项目中拥有的其他SDK文件。因此,基于上面的我认为已经运行了很多测试并相当调查了这个问题,您还需要测试它,而不是附加自定义代码并等待解决方案。所以请检查上传的项目,并告诉我它是否在您身边运行。

谢谢mt_dialog.

daisuke_suzuki.
离线
最后一次露面:3年1周前
加入:2015-09-16 08:36
谢谢你附上

感谢您附加项目。

我在附加的项目中运行了“测试10”10次。

没有发生错误。

到目前为止,我从未连续10次成功。

通过此代码修复,我认为问题未解决问题。

但我认为说“我看不到问题发生了这个问题并不是一个错误。

我很感激你的回应。

谢谢mt_dialog。

mt_dialog.
离线
最后一次露面:6个月3周前
职员
加入:2015-06-08 11:34
我修补了你的补丁

我在代码上修补的是什么(并且还演示了如何在上一篇文章中应用补丁)是一个识别和验证的修复,也应用于SDK 1.0.12(这是最新的SDK),所以我非常有信心这是导致您的代码上的问题的问题。

如果上述帖子有助于,请将答案标记为验证。

谢谢mt_dialog.