作者归档:xtss86

转载——CH579(M0内核)中断向量表偏移处理

原文链接:https://blog.csdn.net/xxdx_admin/article/details/122369753

通常情况下,为了产品后续的升级,程序都会分为两部分Bootloader+App,因为有两个程序,所以需要对中断向量表进行处理,否则,当程序已经跳转到app中运行,当中断产生的时候,响应函数仍然是Bootloader的中断函数,而不是app的
在STM32F103 F3内核上是可以配置寄存器SCB->VTOR设置中断向量表偏移,CH579是M0内核,并不支持这样操作,中断向量表位置固定在(地址0x00000000)位置上

解决思路:

  1. 将中断向量表重映射到RAM(内存)
  2. 根据当前运行程序将FLASH中的向量表拷贝到RAM中

解决步骤

  1. 将地址0x00000000的中断向量表中的全部中断函数都设置为同一个函数,用于映射
  2. 编写映射函数
  3. 修改RAM配置信息
  4. 根据前当前运行的程序拷贝中断向量表到RAM

继续阅读

华大M0中断向量重映射

参考链接:
https://blog.csdn.net/pilihuo182175954/article/details/124856479
https://blog.csdn.net/qq_58099085/article/details/131813593
https://bbs.21ic.com/icview-3214976-1-1.html
https://blog.csdn.net/weixin_38848977/article/details/72523561
https://shatang.github.io/2020/08/12/M0%E7%9A%84%E4%B8%AD%E6%96%AD%E5%90%91%E9%87%8F%E8%A1%A8%E9%87%8D%E6%98%A0%E5%B0%84/

方法一,华大M0内核的CPU内核为M0+,支持中断向量偏移寄存器。根据华大官方IAP例程,修改SCB->VTOR寄存器即可

方法二、直接在Boot程序的中断向量函数跳转到APP的中断函数。参考链接1、2

方法三、参考STM32F0把中断向量表映射到内存上华大MCU不支持此方法

继续阅读

转载——stm32下了解全局变量、局部变量、堆、栈

原文链接:https://blog.csdn.net/uvyou/article/details/110497207

对分区的了解
在一个STM32程序代码中,从内存高地址到内存低地址,依次分布着栈区、堆区、全局区(静态区)、常量区、代码区,其中全局区中高地址分布着.bss段,低地址分布着.data段,其分布图如下: 继续阅读

转载——STM32 内存分配解析及变量的存储位置

原文链接:https://cloud.tencent.com/developer/article/1663070

内存映射

在一些桌面程序中,整个内存映射是通过虚拟内存来进行管理的,使用一种称为内存管理单元(MMU)的硬件结构来将程序的内存映射到物理RAM。在对于 RAM 紧缺的嵌入式系统中,是缺少 MMU 内存管理单元的。因此在一些嵌入式系统中,比如常用的 STM32 来讲,内存映射被划分为闪存段(也被称为Flash,用于存储代码和只读数据)和RAM段,用于存储读写数据。

STM32 的 Flash 和 RAM 地址范围

笔者标题所说的内存是指 STM32 的 Flash 和 RAM,下图是 ARM Cortex M3 的地址映射图:

从图中我们可以看到 RAM 地址是从 0x2000 0000 开始的,Flash地址是从 0x0800 0000 开始的,笔者将在下文中着重对这两部分进行剖析。

继续阅读

前天把VPS的CDN关闭改为了直连,昨天VPS的443端口就被封了。VPS上面有安装v2ray,版本比较旧;手机和电脑端的v2ray版本也比较旧,看来旧版的v2ray是根本不能使用了。

在网上有看到过naiveproxy hysteria和reality这几个协议,等有空的时候把这几个协议测试一下,顺便把不能打开chat-gpt网站的问题也一起解决。

我之前VPS一直是打开CDN,使用了一两年,虽然速度慢但是稳定。况且之前我也怀疑GFW是根据流量封锁而不是协议,所以一直不想把直连打开。这次之所以关闭CDN是由于前几天科学上网的速度慢到离谱,只有把上网的电信卡切换到移动卡才能勉强用一下(后面发现电信卡上网慢是由于CDN把入口IP分配到伦敦,移动卡CDN的入口IP在洛杉矶)。实在受不了这个龟速才在VPS上添加了域名自动更新功能,然后禁用CDN改为直连,没想到这么快就被封了。

这次端口被封,不知道又要等几个月才能解封?

10月16补充:更新了V2ray版本后换了一个端口直连,IP直接被墙了!!!不想再在这上面浪费时间,换到机场了。

这几天查阅GFW的相关知识,有可能是开始全局模式时访问国内网站时被识别到,因此v2ray的出站要把国内的域名和IP转发到warp上。

11月21补充:今天查看IP已经解封了。由于上面的这次封锁,我已经改用机场,此VPS闲置不再使用。

转载——ESXI 和 OpenWrt 避坑指南

原文链接:https://www.yeslu.cn/archives/bd3ebe3.html

软硬件

ESXI 配置

修改 ESXI 主机名称

本节参考: https://kb.vmware.com/s/article/1010821?lang=zh_CN

  1. ssh 连入 ESXI;
  2. 运行 esxcfg-advcfg -s HOSTNAME /Misc/hostname,其中,大写 HOSTNAME 改写为你需要修改的主机名;
  3. 重启 ESXI。

 

ESXI 坑

继续阅读

更换路由器为小米AX3600

把360 T7路由器更换为小米AX3600。更换T7路由器不是因为无线信号的原因,在家里使用这两个路由器,信号上面感觉不到有什么差异。更换路由器的原因有以下几个:

1.T7不支持静态IP地址分配

2.小米路由器支持手机APP远程管理。T7不支持好像可以用小翼管家APP进行远程管理

3.小米路由器支持AIoT功能。对这个功能比较好奇,想试一下

4.小米路由器支持自定义host。T7上面貌似没有这个功能T7也支持自定义host,并且直接可以设置。小米路由器需要下载手机APP,在APP里面设置

5.好奇小米这个路由器对米家生态系统有没有作用

6.T7不支持手动添加MAC地址过滤,必须等设备连接上之后才可以进行限制上网

AX3600 N1旁路由设置备忘

一、旁路路设置

1.AX3600正常拨号上网,打开DHCP

2.N1关闭DHCP,设置N1网关和DNS为AX3600 IP。关闭IPV6相关设置

3.关闭桥接

4.防火墙规则添加
iptables -t nat -I POSTROUTING -o eth0 -j MASQUERADE

二、Zerotier设置

设置ZeroTier ID,并打开NAT选项

 

ESXI Openwrt旁路由配置

ESXI安装Openwrt,设置为旁路由模式,之前用其它无线路由器都可以正常上网的。我把路由器更换为小米AX3600,电脑网关设置为旁路由IP,就不能正常上网。此时只能正常登录Openwrt的地址,小米路由器的IP也登录不上。

参考https://www.right.com.cn/forum/thread-3615208-1-1.html,把eth0的桥接关闭之后,同时防火墙规则添加“iptables -t nat -I POSTROUTING -o eth0 -j MASQUERADE”,电脑网关指定旁路由IP就可以正常上网了,而且上网速度比之前打开桥接时要快很多。之前打开桥接模式,上网速度非常慢,加载图片要等待很久才能加载出来,完全影响了正常使用。以至于我仅仅是把Openwrt当做DDNS工具和Zerotier组网使用,没有拿它用来科学上网。

我记得之前用N1做软路由器的时候一直是使用桥接模式,没有这个问题。我在办公室用D525双网口小主机做软路由,桥接模式也是打开的。不知道现在遇到的这个问题是AX3600的原因,还是虚拟机Openwrt的原因。