在开发时可能需要回读保护功能,在产品出厂后这个功能可以让你的代码更加安全,无法用SEGGER或者其余方式读取你的代码HEX文件,也就是禁用SWD下载接口。但是SWD锁住了,还想使用(从新下载代码)也是可以解锁的,但是注意,当你解锁时,会直接擦除Flash中的代码,也防止代码被强制读取。

开发准备:nrf52840或者nrf52832(原理一样)、SDK包例程或者程序一个

功能实现:

想要实现禁用SWD的功能,一种方式在程序中对UICR APPROTECT寄存器进行设置,就可以进行禁用,当然也可以启用,如果没有设置解除机制这个回调保护,那么SWD不再可访问芯片,需要访问既产擦除FLash。

一、禁用

1.1.1、在芯片手册中有对该寄存器有这样的描述:

由此可知,在该寄存器低8位写入0x00,即可启用SWD端口的读保护。默认为0xFF,不启用。

1.1.2、软件设置如下:先任意打开一个程序,在程序中添加如下代码

头文件添加:

#include "nrf_nvmc.h"

然后添加头文件和.c文件。

在添加如下程序

 int SWD_protect(void)
{
nrf_delay_ms(1000);
if (NRF_UICR->APPROTECT == 0xFFFFFFFF)
{
nrf_nvmc_write_word((uint32_t)&(NRF_UICR->APPROTECT), 0xFFFFFF00);
NVIC_SystemReset();
}
}

并在main()函数开始调用,程序运行后既不能在访问SWD接口,除非有相应的解除机制,解除保护。

1.1.3、下载程序后我们使用segger(j_flash)去读我们的芯片,当点击连接时,会有一下提示

显示设备已经被保护,无法连接,是否需要解除保护?说明设备已经被保护了,无法进行读取,当我们点击Yes后,会解除保护,但是Flash中的程序也被擦除了。

点击yes后读出来Flash如下,全为FF,说明程序已经擦除

1.2 第二种方式是直接更改HEX文件的相应位

由芯片手册,确定APPROTECT的地址为0x208,UICR的基址为0x10001000

首先需要准备一份HEX固件,这份固件最好是烧写到芯片中,然后利用j-flash读出后在0x10001208为把FF修改为00,就得到了一份禁用SWD的HEX文件,可以进行烧录。为什么不直接用keil编译的HEX做更改,因为该HEX是没有这个地址的。

如下是没有在程序中禁用下载相关代码的程序,我下载后可以用segger的j_flash连接,并读出程序,地址0x10001208为FF

直接更改该位的值为00,并回车保存然后从新下载程序

然后运行程序

会提示CPU 运行失败。

我们再次点击连接会有如下提示,说明禁用成功

2、解除禁用

如果程序中没有做处理去修改寄存器的值为FF,那么我们可以用两种方式去解除禁用,解除后程序会被擦除。

2.1、segger(j-flash)

这种方式只需要安装的有segger,根据芯片型号选择好后,点击连接,会弹出一个提示框,点击Yes即可。

2.2、利用官方工具nrfjprog进行

这种方式请确认你安装的有nrfjprog,安装方式请根据官方中文博客进行安装:连接如下: Nordic nRF51/nRF52开发环境搭建 - iini - 博客园 (cnblogs.com)

2.2.1、通Windows命令窗口,(win+R调出在其中输入cmd)

在打开的命令框中输入nrfjprog,并加回车后有如图所示界面,说明你正确安装了nrfjprog,并加入了环境变量

输入nrfjprog --recover回车有如下说明解除成功。

nordic——nrf52系列SWD设置回读保护的更多相关文章

  1. nRF52系列来袭,Nordic的低功耗蓝牙方案大有可为

      坐落在北欧的挪威不像他的邻居芬兰那样,可以先后依靠NOKIA和愤怒的小鸟在世界科技界享有盛名.在一般人看来,挪威除了一个逐渐式微的Opera浏览器以外,并没有更多拿得出手的科技企业.而事实证明这只 ...

  2. nRF52系列——nRF52832来袭

    nRF52系列——nRF52832来袭 Nordic凭借着在无线技术的数十年深耕,推出第一个μBlue芯片-- nRF8001.其低功耗等特性在当时吸引了无数厂商的目光,并将这产品应用到多个领域,再之 ...

  3. STM32-对芯片启动读保护,实现加密(详解)

    STM32可以对存储在flash上的程序进行读保护. 启动读保护后,用户就不能再读写程序了. 所以,在烧写程序之前,需要程序调用关闭读保护.关闭读保护后,会自动清空flash上的程序 头文件位于:#i ...

  4. NRF52840相对于之前的NRF52系列、NRF51系列增加了什么功能

    现在广大客户的蓝牙采用NORDIC越来越多了,NORDIC一直在不断进行技术改进更好的满足市场需求 推出了新款NRF52840.NRF52840更为先进些,支持的功能也多点,比如IEEE802.15. ...

  5. SSM保姆级从创建项目到使用,包括事务和设置回滚

    1. 简介 Spring 和 Mybaits整合 2. 创建项目 负责将代理类记性扫描,扫描的是Mapper接口所在的包,这个是mybatis提供的,所以会去找SqlSessionFactory 2. ...

  6. Maven入门系列(二)--设置中央仓库的方法

    原文地址:http://www.codeweblog.com/maven入门系列-二-设置中央仓库的方法/ Maven仓库放在我的文档里好吗?当然不好,重装一次电脑,意味着一切jar都要重新下载和发布 ...

  7. 17.Quartus 怎么回读CPLD里面的东西

    可以使用Quartus® II Programmer的“Examine”特性回读编程目标文件(.POF)是CPLD不是FPGA 先用auto检测加没加加密位,然后执行ex,然后save,Examine ...

  8. CDN设置回源host的意义

    CDN设置回源host的意义 如果CDN后端用户的的源站web服务上没有绑定加速域名,只绑定了其他域名,未限制域名访问(比如通过服务器IP可以访问到默认网站),可以在CDN控制台填写回源host,这样 ...

  9. centos7.6+samba+设置可读可写不可删权限

    samba原文 https://www.cnblogs.com/muscleape/p/6385583.html 设置可读可写不可删权限原文: https://blog.51cto.com/guanh ...

随机推荐

  1. bash脚本里的-h是什么意思?

    问题描述 我在看脚本的时候,看到了下面代码 其中的-h "$PRG"我一时没明白是在判断什么东西.然后翻阅了一下菜鸟教程和其他教程,都没有说. 问题解决 -h其实是在判断这个文件是 ...

  2. 面试突击75:SpringBoot 有几种读取配置文件的方法?

    Spring Boot 中读取配置文件有以下 5 种方法: 使用 @Value 读取配置文件. 使用 @ConfigurationProperties 读取配置文件. 使用 Environment 读 ...

  3. Python逆向爬虫之pyquery,非常详细

    系列目录 Python逆向爬虫之pyquery pyquery是一个类似jquery的python库,它实现能够在xml文档中进行jQuery查询,pyquery使用lxml解析器进行快速在xml和h ...

  4. iommu系列之---概念解释篇

    本文会对iommu中的一些容易引起疑惑的概念进行阐述,内核版本为4.19. 先上简写: DMAR - DMA remapping DRHD - DMA Remapping Hardware Unit ...

  5. idea中无法在@Test 之下使用Scanner

    //如何解决idea中无法在 @Test 之下使用Scanner@Testpublic void testInsert(){ Scanner scanner = new Scanner(System. ...

  6. C#基础_析构函数

    C#析构函数 1. 析构函数的定义与注意的问题 析构函数用于释放被占用的系统资源. 析构函数的名字由符号"-"加类名组成. 使用析构函数时,应该注意下面的问题: ?只能在类中使用析 ...

  7. 「题解报告」P2154 虔诚的墓主人

    P2154 虔诚的墓主人 题解 原题传送门 题意 在 \(n\times m\) 一个方格上给你 \(w\) 个点,求方格里每个点正上下左右各选 \(k\) 个点的方案数. \(1 \le N, M ...

  8. CodeForces - 1625C

    Problem - 1625C - Codeforces 题意: 一条马路,有n个限速牌,表示的是从这个限速牌开始到下一个限速牌或者到马路尾的这段距离的速度,你可以拆除其中k个限速牌,问最少的时间是多 ...

  9. 第八十九篇:Vue 重学插槽slot

    好家伙, 1.什么是插槽? 插槽是vue为组件的封装者提供的能力.允许开发者在封装组件时, 把不确定的,希望由用户指定的部分定义为插槽   我们依然可以把它理解为一个占位符 1.1.插槽的基本用法 试 ...

  10. LibreCAD常用命令

    目录 常见命令 常见命令 .text_center { text-align: center } \3cp>.text_left { } 动作命令 命令 绘制直线 相对坐标系 @长度<角度 ...