【HC32L110】华大低功耗单片机启动文件详解

本文主要记录华大低功耗单片机 HC32L110 的 汇编启动过程,包括startup_hc32l110启动文件详细注释

目录

  • 1.启动文件的作用
  • 2.堆栈定义
    • 2.1 栈
    • 2.2堆
  • 3.向量表
  • 4.复位程序
  • 5.中断服务程序
  • 6.堆栈初始化
  • 启动过程详解
    • 7.1从0地址开始
    • 7.2在Reset_Handler中干了啥?
  • 8.启动过程总结
  • 9. startup.s 文件注释

1.启动文件的作用

启动文件为 startup_hc32l110.s,启动文件中完成了:

  • 堆和栈的初始化

    • 包括堆栈的大小,主栈指针 MSP 的初始值
  • 向量表定义

    • 定义各MSP的初值以及中断服务函数的入口地址
  • 中断服务程序

  • 设置系统时钟频率 (在复位中断服务程序Reset_handler中调用系统时钟频率初始化程序)

  • 中断寄存器初始化

  • 进入C的main函数

2.堆栈定义

2.1 栈

栈的作用是用于局部变量,函数调用,函数形参等的开销,栈的大小不能超过内部SRAM 的大小。当程序较大时,需要修改栈的大小,不然可能会出现的HardFault的错误。

  • EQU是伪指令,相当于C 中的 define
  • ARER 伪指令表示下面将开始定义一个代码段或者数据段
  • ARER 后面的关键字表示这个段的属性。段名为STACK,可以任意命名;NOINIT 表示不初始化;READWRITE 表示可读可写,ALIGN=3,表示按照 8 字节对齐。
  • SPACE 用于分配大小等于 Stack_Size连续内存空间,单位为字节。
  • __initial_sp表示栈顶地址。栈是由高向低生长的
; Stack Configuration
; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8>Stack_Size      EQU     0x00000100AREA    STACK, NOINIT, READWRITE, ALIGN=3   
Stack_Mem       SPACE   Stack_Size
__initial_sp; 定义栈大小为  0x100     256字节
; 定义一个数据段,8字节对齐,名称为 STACK ,数据段不初始化,仅仅保留内存单元,可读可写
; 分配一段大小为 Stack_Size 的连续内存空间,并初始化为0
; 表示栈顶指针地址

2.2堆

堆主要用来动态内存的分配,像 malloc()函数申请的内存就在堆中。

; Heap Configuration
;  Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>Heap_Size       EQU     0x00000400AREA    HEAP, NOINIT, READWRITE, ALIGN=3
__heap_base
Heap_Mem        SPACE   Heap_Size
__heap_limit; 定义堆大小为  0x400     1024字节
; 定义一个数据段,8字节对齐,名称为 HEAP ,数据段不初始化,仅仅保留内存单元,可读可写
; __heap_base放置在SPACE之前表示堆的起始地址。
; 分配一段大小为 Heap_Size 的连续内存空间,并初始化为0
; __heap_limit放置在SPACE之后表示堆的结束地址。PRESERVE8   ; 指示编译器8字节对齐THUMB       ; 指示编译器以后的指令为THUMB指令

3.向量表

向量表本质上是一个U32的数组,每个元素代表一种异常,中断向量表 存放的实际上是中断服务程序的入口地址。当异常(也即是中断事件)发生时,CPU 的中断系统会将相应的入口地址赋值给 PC 程序计数器,之后就开始执行中断服务程序。 在地址 0 (即 FLASH 地址 0)处必须包含一张向量表,用于初始时的异常分配。

  • EXPORT将标识符申明为可被外部引用
  • DCD 表示分配 1 个 4 字节的空间
; Vector Table Mapped to Address 0 at Reset
;中断向量表定义AREA    RESET, DATA, READONLY     ;定义只读数据段,名字是REST;EXPORT:在程序中声明一个全局的标号__Vectors,;该标号可在其他的文件中引用EXPORT  __Vectors                 ;表示向量表的起始地址EXPORT  __Vectors_End             ;表示向量表的结束地址EXPORT  __Vectors_Size            ;表示向量表的大小; 中断向量表
__Vectors       DCD     __initial_sp              ; Top of StackDCD     Reset_Handler             ; ResetDCD     NMI_Handler               ; NMIDCD     HardFault_Handler         ; Hard FaultDCD     0                         ; ReservedDCD     0                         ; ReservedDCD     0                         ; ReservedDCD     0                         ; ReservedDCD     0                         ; ReservedDCD     0                         ; ReservedDCD     0                         ; ReservedDCD     SVC_Handler               ; SVCallDCD     0                         ; ReservedDCD     0                         ; ReservedDCD     PendSV_Handler            ; PendSVDCD     SysTick_Handler           ; SysTick………………省略一部分__Vectors_End__Vectors_Size 	EQU     __Vectors_End - __Vectors

4.复位程序

复位程序是系统上电后执行的第一个程序

; Reset Handler;利用PROC、ENDP这一对伪指令把程序段分为若干过程;使得程序结构明晰
Reset_Handler   PROC                                    ;过程开始EXPORT  Reset_Handler             [WEAK] ;weak 符号表示 该函数可以在外部重写IMPORT  SystemInit                       ; IMPORT表示函数是从外部带入的,代码中的系统初始化程序IMPORT  __main;reset NVIC if in rom debugLDR     R0, =0x20000000        ; 将ram 地址写入R0寄存器LDR     R2, =0x0			   ;将 flash 0地址写入R2寄存器MOVS    R1, #0                 ; for warning,  将立即数0 写入R1寄存器ADD     R1, PC,#0              ; for A1609W,   将PC初值+0 写入R1寄存器CMP     R1, R0				   ; 比较RAM首地址与 flash 首地址的值 BLS     RAMCODE                ; 若满足小于等于,则跳转; ram code base address. ADD     R2, R0,R2
RAMCODE; reset Vector table address.LDR     R0, =0xE000ED08       ; ?????????????STR     R2, [R0]LDR     R0, =SystemInit         ;执行初始化,BLX     R0LDR     R0, =__main             ;__main是C库函数 想要使用__main这个C库函数 必须勾选微库选项BX      R0ENDP

5.中断服务程序

我们平时要使用哪个中断,就需要编写相应的中断服务程序,只是启动文件把这些函数留出来了,但是内容都是空的,真正的中断复服务程序需要我们在外部的 C 文件里面重新实现,这里只是提前占了一个位置罢了。

B . 表示无线循环,类似于while(1)

6.堆栈初始化

堆栈初始化是由一个IF条件来实现的,MICROLIB的定义与否决定了堆栈的初始化方式。如果没有定义__MICROLIB , 则会使用双段存储器模式,

且声明了__user_initial_stackheap 具有全局属性,这需要开发者自己来初始化堆栈。

; User Initial Stack & Heap                      ;堆和栈的初始化IF      :DEF:__MICROLIB          ;如果定义了MICORLIB,使用微库EXPORT  __initial_sp            ; 赋予【栈顶地址】【堆起始地址】【堆结束地址】全局的属性EXPORT  __heap_base             ; 可在外部使用EXPORT  __heap_limitELSE      ;如果使用默认的C库IMPORT  __use_two_region_memory ;通知编译器要使用的标号在其他文件EXPORT  __user_initial_stackheap
__user_initial_stackheapLDR     R0, =  Heap_Mem                 ;保存堆始地址LDR     R1, =(Stack_Mem + Stack_Size)   ;保存栈的大小LDR     R2, = (Heap_Mem +  Heap_Size)   ;保存堆的大小LDR     R3, = Stack_Mem                 ;保存栈顶指针BX      LRALIGN                                   ;填充字节使地址对齐ENDIFEND

启动过程详解

7.1从0地址开始

ARM 内核单片机的启动方式都是如下图流程:

image-20240419151911263

通过以上分析可知,flash 的0 地址存储这中断向量表。

  • 单片机从 flash 的 0 地址取出数据赋给MSP指针,然后从 0+ 4 地址处取出值赋值给PC
  • 此时 SP = 栈顶地址 PC = Reset_Handler,程序从复位开始执行

image-20240419152505491

7.2在Reset_Handler中干了啥?

  • Reset_Handler仅仅执行了两个函数调用,一个是SystemInit,另一个__main,
  • SystemInit定义在system_hc32xxxx.c中,主要初始化了系统时钟系统:RCH,RCL,XTH,XTL,PLL,SystemClk,HCLK,PCLK等等.
  • __main函数由编译器生成,负责初始化栈、堆等,并在最后跳转到用户自定义的main()函数,来到C的世界

8.启动过程总结

  • ;先在RAM中分配系统使用的栈,RAM的起始地址为0x2000_0000
  • ;然后在RAM中分配变量使用的堆
  • ;然后在CODE区(flash)分配中断向量表,flash的起始地址为0x0000_0000,该中断向量表就从这个起始地址开始分配
  • ;分配完成后,再定义和实现相应的中断函数,
  • ;所有的中断函数全部带有[weak]特性,即弱定义,如果编译器发现在别处文件中定义了同名函数,在链接时用别处的地址进行链接。
  • ;中断函数仅仅实现了Reset_Handler,其他要么是死循环,要么仅仅定义了函数名称
  • ;HC32被设置为从内部FLASH启动时(这也是最常见的一种情况),当HC32遇到复位信号后,
  • ;从0x0000_0000处取出栈顶地址存放于MSP寄存器,从0x0000_0004处取出复位中断服务入口地址放入PC寄存器,
  • ;继而执行复位中断服务程序Reset_Handler
  • ;Reset_Handler仅仅执行了两个函数调用,一个是SystemInit,另一个__main,
  • ;SystemInit定义在system_hc32xxxx.c中,主要初始化了HC的时钟系统:RCH,RCL,XTH,XTL,PLL,SystemClk,HCLK,PCLK等等.
  • ;__main函数由编译器生成,负责初始化栈、堆等,并在最后跳转到用户自定义的main()函数,来到C的世界

9. startup.s 文件注释

;/******************************************************************************
;* Copyright (C) 2017, Xiaohua Semiconductor Co.,Ltd All rights reserved.
;*
;* This software is owned and published by:
;* Xiaohua Semiconductor Co.,Ltd ("XHSC").
;*
;* BY DOWNLOADING, INSTALLING OR USING THIS SOFTWARE, YOU AGREE TO BE BOUND
;* BY ALL THE TERMS AND CONDITIONS OF THIS AGREEMENT.
;*
;* This software contains source code for use with XHSC
;* components. This software is licensed by XHSC to be adapted only
;* for use in systems utilizing XHSC components. XHSC shall not be
;* responsible for misuse or illegal use of this software for devices not
;* supported herein. XHSC is providing this software "AS IS" and will
;* not be responsible for issues arising from incorrect user implementation
;* of the software.
;*
;* Disclaimer:
;* XHSC MAKES NO WARRANTY, EXPRESS OR IMPLIED, ARISING BY LAW OR OTHERWISE,
;* REGARDING THE SOFTWARE (INCLUDING ANY ACOOMPANYING WRITTEN MATERIALS),
;* ITS PERFORMANCE OR SUITABILITY FOR YOUR INTENDED USE, INCLUDING,
;* WITHOUT LIMITATION, THE IMPLIED WARRANTY OF MERCHANTABILITY, THE IMPLIED
;* WARRANTY OF FITNESS FOR A PARTICULAR PURPOSE OR USE, AND THE IMPLIED
;* WARRANTY OF NONINFRINGEMENT.
;* XHSC SHALL HAVE NO LIABILITY (WHETHER IN CONTRACT, WARRANTY, TORT,
;* NEGLIGENCE OR OTHERWISE) FOR ANY DAMAGES WHATSOEVER (INCLUDING, WITHOUT
;* LIMITATION, DAMAGES FOR LOSS OF BUSINESS PROFITS, BUSINESS INTERRUPTION,
;* LOSS OF BUSINESS INFORMATION, OR OTHER PECUNIARY LOSS) ARISING FROM USE OR
;* INABILITY TO USE THE SOFTWARE, INCLUDING, WITHOUT LIMITATION, ANY DIRECT,
;* INDIRECT, INCIDENTAL, SPECIAL OR CONSEQUENTIAL DAMAGES OR LOSS OF DATA,
;* SAVINGS OR PROFITS,
;* EVEN IF Disclaimer HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
;* YOU ASSUME ALL RESPONSIBILITIES FOR SELECTION OF THE SOFTWARE TO ACHIEVE YOUR
;* INTENDED RESULTS, AND FOR THE INSTALLATION OF, USE OF, AND RESULTS OBTAINED
;* FROM, THE SOFTWARE.
;*
;* This software may be replicated in part or whole for the licensed use,
;* with the restriction that this Disclaimer and Copyright notice must be
;* included with each copy of this software, whether used in part or whole,
;* at all times.
;*/
;/*****************************************************************************/;/*****************************************************************************/
;/*  Startup for ARM                                                          */
;/*  Version     V1.2                                                         */
;/*  Date        2016-06-02                                                   */
;/*  Target-mcu  {MCU_SERIES}                                                 */
;/*****************************************************************************/; Stack Configuration
; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8>Stack_Size      EQU     0x00000100AREA    STACK, NOINIT, READWRITE, ALIGN=3   
Stack_Mem       SPACE   Stack_Size
__initial_sp; 定义栈大小为  0x100     256字节
; 定义一个数据段,8字节对齐,名称为 STACK ,数据段不初始化,仅仅保留内存单元,可读可写
; 分配一段大小为 Stack_Size 的连续内存空间,并初始化为0
; 表示栈顶指针地址; Heap Configuration
;  Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>Heap_Size       EQU     0x00000400AREA    HEAP, NOINIT, READWRITE, ALIGN=3
__heap_base
Heap_Mem        SPACE   Heap_Size
__heap_limit; 定义堆大小为  0x400     1024字节
; 定义一个数据段,8字节对齐,名称为 HEAP ,数据段不初始化,仅仅保留内存单元,可读可写
; __heap_base放置在SPACE之前表示堆的起始地址。
; 分配一段大小为 Heap_Size 的连续内存空间,并初始化为0
; __heap_limit放置在SPACE之后表示堆的结束地址。PRESERVE8   ; 指示编译器8字节对齐THUMB       ; 指示编译器以后的指令为THUMB指令; Vector Table Mapped to Address 0 at Reset
;中断向量表定义AREA    RESET, DATA, READONLY     ;定义只读数据段,名字是REST;EXPORT:在程序中声明一个全局的标号__Vectors,;该标号可在其他的文件中引用EXPORT  __Vectors                 ;表示向量表的起始地址EXPORT  __Vectors_End             ;表示向量表的结束地址EXPORT  __Vectors_Size            ;表示向量表的大小; 中断向量表
__Vectors       DCD     __initial_sp              ; Top of StackDCD     Reset_Handler             ; ResetDCD     NMI_Handler               ; NMIDCD     HardFault_Handler         ; Hard FaultDCD     0                         ; ReservedDCD     0                         ; ReservedDCD     0                         ; ReservedDCD     0                         ; ReservedDCD     0                         ; ReservedDCD     0                         ; ReservedDCD     0                         ; ReservedDCD     SVC_Handler               ; SVCallDCD     0                         ; ReservedDCD     0                         ; ReservedDCD     PendSV_Handler            ; PendSVDCD     SysTick_Handler           ; SysTickDCD     IRQ000_Handler            ; DCD     IRQ001_Handler            ; DCD     IRQ002_Handler            ; DCD     IRQ003_Handler            ; DCD     IRQ004_Handler            ; DCD     IRQ005_Handler            ; DCD     IRQ006_Handler            ; DCD     IRQ007_Handler            ; DCD     IRQ008_Handler            ; DCD     IRQ009_Handler            ; DCD     IRQ010_Handler            ; DCD     IRQ011_Handler            ; DCD     IRQ012_Handler            ; DCD     IRQ013_Handler            ; DCD     IRQ014_Handler            ; DCD     IRQ015_Handler            ; DCD     IRQ016_Handler            ; DCD     IRQ017_Handler            ; DCD     IRQ018_Handler            ; DCD     IRQ019_Handler            ; DCD     IRQ020_Handler            ; DCD     IRQ021_Handler            ; DCD     IRQ022_Handler            ; DCD     IRQ023_Handler            ; DCD     IRQ024_Handler            ; DCD     IRQ025_Handler            ; DCD     IRQ026_Handler            ; DCD     IRQ027_Handler            ; DCD     IRQ028_Handler            ; DCD     IRQ029_Handler            ; DCD     IRQ030_Handler            ; DCD     IRQ031_Handler            ; __Vectors_End__Vectors_Size 	EQU     __Vectors_End - __VectorsAREA    |.text|, CODE, READONLY         ;代码段定义,只读; Reset Handler;利用PROC、ENDP这一对伪指令把程序段分为若干过程;使得程序结构明晰
Reset_Handler   PROC                                    ;过程开始EXPORT  Reset_Handler             [WEAK] ;weak 符号表示 该函数可以在外部重写IMPORT  SystemInit                       ; IMPORT表示函数是从外部带入的,代码中的系统初始化程序IMPORT  __main;reset NVIC if in rom debugLDR     R0, =0x20000000LDR     R2, =0x0MOVS    R1, #0                 ; for warning, ADD     R1, PC,#0              ; for A1609W, CMP     R1, R0BLS     RAMCODE; ram code base address. ADD     R2, R0,R2
RAMCODE; reset Vector table address.LDR     R0, =0xE000ED08 STR     R2, [R0]LDR     R0, =SystemInitBLX     R0LDR     R0, =__main             ;__main是C库函数 想要使用__main这个C库函数 必须勾选微库选项BX      R0ENDP; Dummy Exception Handlers (infinite loops which can be modified); B       .  表示原地跳转(即无限循环),等同于while(1);
NMI_Handler     PROCEXPORT  NMI_Handler               [WEAK]B       .                                       ENDP  
HardFault_Handler\PROCEXPORT  HardFault_Handler         [WEAK]B       .ENDP
SVC_Handler     PROCEXPORT  SVC_Handler               [WEAK]B       .ENDP
PendSV_Handler  PROCEXPORT  PendSV_Handler            [WEAK]B       .ENDP
SysTick_Handler PROCEXPORT  SysTick_Handler           [WEAK]B       .ENDPDefault_Handler PROCEXPORT  IRQ000_Handler               [WEAK]EXPORT  IRQ001_Handler               [WEAK]EXPORT  IRQ002_Handler               [WEAK]EXPORT  IRQ003_Handler               [WEAK]EXPORT  IRQ004_Handler               [WEAK]EXPORT  IRQ005_Handler               [WEAK]EXPORT  IRQ006_Handler               [WEAK]EXPORT  IRQ007_Handler               [WEAK]EXPORT  IRQ008_Handler               [WEAK]EXPORT  IRQ009_Handler               [WEAK]EXPORT  IRQ010_Handler               [WEAK]EXPORT  IRQ011_Handler               [WEAK]EXPORT  IRQ012_Handler               [WEAK]EXPORT  IRQ013_Handler               [WEAK]EXPORT  IRQ014_Handler               [WEAK]EXPORT  IRQ015_Handler               [WEAK]EXPORT  IRQ016_Handler               [WEAK]EXPORT  IRQ017_Handler               [WEAK]EXPORT  IRQ018_Handler               [WEAK]EXPORT  IRQ019_Handler               [WEAK]EXPORT  IRQ020_Handler               [WEAK]EXPORT  IRQ021_Handler               [WEAK]EXPORT  IRQ022_Handler               [WEAK]EXPORT  IRQ023_Handler               [WEAK]EXPORT  IRQ024_Handler               [WEAK]EXPORT  IRQ025_Handler               [WEAK]EXPORT  IRQ026_Handler               [WEAK]EXPORT  IRQ027_Handler               [WEAK]EXPORT  IRQ028_Handler               [WEAK]EXPORT  IRQ029_Handler               [WEAK]EXPORT  IRQ030_Handler               [WEAK]EXPORT  IRQ031_Handler               [WEAK]IRQ000_Handler
IRQ001_Handler
IRQ002_Handler
IRQ003_Handler
IRQ004_Handler
IRQ005_Handler
IRQ006_Handler
IRQ007_Handler
IRQ008_Handler
IRQ009_Handler
IRQ010_Handler
IRQ011_Handler
IRQ012_Handler
IRQ013_Handler
IRQ014_Handler
IRQ015_Handler
IRQ016_Handler
IRQ017_Handler
IRQ018_Handler
IRQ019_Handler
IRQ020_Handler
IRQ021_Handler
IRQ022_Handler
IRQ023_Handler
IRQ024_Handler
IRQ025_Handler
IRQ026_Handler
IRQ027_Handler
IRQ028_Handler
IRQ029_Handler
IRQ030_Handler
IRQ031_HandlerB .ENDPALIGN             ;填充字节使地址对齐; User Initial Stack & Heap                      ;堆和栈的初始化IF      :DEF:__MICROLIB          ;如果定义了MICORLIB,使用微库EXPORT  __initial_sp            ; 赋予【栈顶地址】【堆起始地址】【堆结束地址】全局的属性EXPORT  __heap_base             ; 可在外部使用EXPORT  __heap_limitELSE      ;如果使用默认的C库IMPORT  __use_two_region_memory ;通知编译器要使用的标号在其他文件EXPORT  __user_initial_stackheap
__user_initial_stackheapLDR     R0, =  Heap_Mem                 ;保存堆始地址LDR     R1, =(Stack_Mem + Stack_Size)   ;保存栈的大小LDR     R2, = (Heap_Mem +  Heap_Size)   ;保存堆的大小LDR     R3, = Stack_Mem                 ;保存栈顶指针BX      LRALIGN                                   ;填充字节使地址对齐ENDIFEND

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/797.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

PyTorch|保存及加载模型、nn.Sequential、ModuleList和ModuleDict

系列文章目录 PyTorch|Dataset与DataLoader使用、构建自定义数据集 PyTorch|搭建分类网络实例、nn.Module源码学习 pytorch|autograd使用、训练模型 文章目录 系列文章目录一、保存及加载模型&#xff08;一&#xff09;保存及加载模型的权重&#xff08;二&#xff09;保存及…

探究欧拉恒等式的美学与数学威力

正如老子所述&#xff0c;“道生一&#xff0c;一生二&#xff0c;二生三&#xff0c;三生万物”&#xff0c;数学作为人类认知自然法则的语言&#xff0c;其数系的不断发展象征着对世界理解的深化。从自然数经由分数、无理数至复数&#xff0c;复数虽看似反直觉&#xff0c;却…

MATLAB实现蚁群算法优化柔性车间调度(ACO-fjsp)

蚁群算法优化车间调度的步骤可以分为以下几个主要阶段&#xff1a; 1.初始化阶段&#xff1a; 设置算法参数&#xff0c;如信息素浓度、启发式因子等。这些参数将影响蚂蚁在选择路径时的决策过程。 确定车间调度的具体问题规模&#xff0c;包括工件数量、机器数量以及每个工件…

AI:162-如何使用Python进行图像识别与处理深度学习与卷积神经网络的应用

本文收录于专栏&#xff1a;精通AI实战千例专栏合集 从基础到实践&#xff0c;深入学习。无论你是初学者还是经验丰富的老手&#xff0c;对于本专栏案例和项目实践都有参考学习意义。 每一个案例都附带关键代码&#xff0c;详细讲解供大家学习&#xff0c;希望可以帮到大家。正…

OpenHarmony GIF图像渲染库—ohos-gif-drawable

简介 本项目是OpenHarmony系统的一款GIF图像渲染库&#xff0c;基于Canvas进行绘制&#xff0c;主要能力如下: 支持播放GIF图片。支持控制GIF播放/暂停。支持重置GIF播放动画。支持调节GIF播放速率。支持监听GIF所有帧显示完成后的回调。支持设置显示大小。支持7种不同的展示…

面试题:Redis如何防止缓存穿透 + 布隆过滤器原理

题目来源 招银网络-技术-1面 题目描述 缓存穿透是什么&#xff1f;如何防止缓存穿透布隆过滤器的原理是什么&#xff1f; 我的回答 缓存穿透是什么&#xff1f; 攻击者大量请求缓存和数据库中都不存在的key。如何防止缓存穿透 可以使用布隆过滤器布隆过滤器的原理是什么&a…

AI容器化部署开发尝试 (一)(Pycharm连接docker,并部署django测试)

注意&#xff1a;从 Docker 19.03 开始&#xff0c;Docker 引入了对 NVIDIA GPU 的原生支持&#xff0c;因此若AI要调用GPU算力的话docker版本也是有要求的&#xff0c;后面博客测试。 当然本篇博客还没设计到GPU的调用&#xff0c;主要Pycharm加Anaconda的方案用习惯了&#…

缓存的使用及常见问题的解决方案

用户通过浏览器向我们发送请求&#xff0c;这个时候浏览器就会建立一个缓存&#xff0c;主要缓存一些静态资源&#xff08;js、css、图片&#xff09;&#xff0c;这样做可以降低之后访问的网络延迟。然后我们可以在Tomcat里面添加一些应用缓存&#xff0c;将一些从数据库查询到…

Flask:URL与视图的映射

默认端口号80、443 blog_id 限制数据类型的话&#xff08;int&#xff09; 除此之外别的数据类型也可以&#xff0c;或者多个&#xff08;用any&#xff09; /book/list?page6

【笔记】ASP.NET Core Web API之Token验证

在实际开发中经常需要对外提供接口以便客户获取数据&#xff0c;由于数据属于私密信息&#xff0c;并不能随意供其他人访问&#xff0c;所以就需要验证客户身份。那么如何才能验证客户的身份呢&#xff1f;一个简单的小例子&#xff0c;简述ASP.NET Core Web API开发过程中&…

Git学习笔记(三)Git分支

Git分支是Git中非常重要的一个概念&#xff0c;无论是个人开发还是多人协作中&#xff0c;分支都起着至关重要的作用。几乎所有的版本控制系统都以某种形式支持分支。 使用分支意味着你可以把你的工作从开发主线上分离 开来进行重大的Bug修改、开发新的功能&#xff0c;以免影响…

Linux驱动开发笔记(零)驱动基础知识及准备

文章目录 前言一、Liunx、MCU和FPGA编程的区别二、Linux内核模块1. 什么是内核模块2. 内核模块的代码架构3. 头文件4. 模块参数5. makefile说明 三、 驱动程序设计思路1. 基本步骤2. 设备号3. 数据结构3.1 file_operations3.2 file3.3 inode3.4 哈希表3.5 cdev结构体3.6 kobj_m…

[Linux][进程信号][一][信号基础][如何产生信号]详细解读

目录 0.前言预备1.系统定义的信号列表2.核心转储 -- Core Dump 1.信号基础1.信号概念2.信号处理方式概览3.理解信号如何被保存4.信号发送的本质 2.如何产生信号&#xff1f;1.终端按键产生信号2.系统调用接口1.kill()2.raise()3.abort()4.如何理解&#xff1f; 3.由软件条件产生…

C# 图像旋转一定角度后,对应坐标怎么计算?

原理分析 要计算图像内坐标在旋转一定角度后的新坐标&#xff0c;可以使用二维空间中的点旋转公式。假设图像的中心点&#xff08;即旋转中心&#xff09;为 (Cx, Cy)&#xff0c;通常对于正方形图像而言&#xff0c;中心点坐标为 (Width / 2, Height / 2)。给定原坐标点 (X, …

开发与产品的战争之自动播放视频

开发与产品的战争之自动播放视频 起因 产品提了个需求&#xff0c;对于网站上的宣传视频&#xff0c;进入页面就自动播放。但是基于我对chromium内核的一些浅薄了解&#xff0c;我当时就给拒绝了: “浏览器不允许”。&#xff08;后续我们浏览器默认都是chromium内核的&#…

【深度学习】Vision Transformer

一、Vision Transformer Vision Transformer (ViT)将Transformer应用在了CV领域。在学习它之前&#xff0c;需要了解ResNet、LayerNorm、Multi-Head Self-Attention。 ViT的结构图如下&#xff1a; 如图所示&#xff0c;ViT主要包括Embedding、Encoder、Head三大部分。Class …

OpenHarmony鸿蒙南向开发案例:【智能燃气检测设备】

样例简介 本文档介绍了安全厨房案例中的相关智能燃气检测设备&#xff0c;本安全厨房案例利用轻量级软总线能力&#xff0c;将两块欧智通V200Z-R/BES2600开发板模拟的智能燃气检测设备和燃气告警设备组合成。当燃气数值告警时&#xff0c;无需其它操作&#xff0c;直接通知软总…

VOS3000加装登陆服务器安全防护系统有用吗

VOS3000是一款专业的软交换系统&#xff0c;它主要用于中小规模的VoIP运营业务&#xff0c;包括运营费率设定、套餐管理&#xff0c;账户管理、业终端管理、网关管理、数据查询、卡类管理、号码管理、系统管理等功能1。而关于加装登陆服务器安全防护系统是否有用&#xff0c;这…

2.4 Web容器配置:Tomcat

2.4 Web容器配置 2.4.1Tomcat配置1.常规配置2. HTTPS配置 *********** 2.4.1Tomcat配置 1.常规配置 在SpringBoot项目中&#xff0c;可以内置Tomcat、Jetly、Undertow、Netty等容器。 当开发者添加了spring-boot-starter-web依赖之后&#xff0c;默认会使用Tomcat作为Web容器…

基于Springboot+Vue的Java项目-网上点餐系统开发实战(附演示视频+源码+LW)

大家好&#xff01;我是程序员一帆&#xff0c;感谢您阅读本文&#xff0c;欢迎一键三连哦。 &#x1f49e;当前专栏&#xff1a;Java毕业设计 精彩专栏推荐&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; &#x1f380; Python毕业设计 &am…