QSPI flash xip模式運行

背景:

在做一個項目,調研p-sram當ram用在cadence qspi接口下是否正常,首先用qspi-flash?xip模式驗證控制器是否支持flash的xip模式。

一、更改步驟:

1.1首先配置鏈接腳本

默認鏈接腳本


OUTPUT_FORMAT("elf32-littlearm", "elf32-littlearm", "elf32-littlearm")
OUTPUT_ARCH(arm)
ENTRY(_start)
SECTIONS
{. = 0xf4000000;. = ALIGN(4);.text : {_stext = .;*(.vectors)*(.text*)*(.rodata .rodata*)  /* read-only data (constants) */. = ALIGN(4);*(.glue*)_etext = . ;}__exidx_start = .;.ARM.exidx  : { *(.ARM.exidx* .gnu.linkonce.armexidx.*) }__exidx_end = .;. = ALIGN(8);_edummy = .;/* data sections */.data : {_sdata = .;__ld_real_data_start = .;*(.data*)_edata = .;}. = ALIGN(8);/* bss sections */_sbss = .;.bss (NOLOAD) : {*(.bss .bss.*). = ALIGN(4);}_ebss = .;/*stack sections 4K*/.stack (NOLOAD):{. = ALIGN(64);. = . + 0x400;__stack = .;}_end = .;.pagetable (NOLOAD):{. = ALIGN(16*1024);__pagetable_start = .;. = . + 0x00004000;}.dynsym : { *(.dynsym) }.dynbss : { *(.dynbss) }.dynstr : { *(.dynstr*) }.dynamic : { *(.dynamic*) }.hash : { *(.hash*) }.plt : { *(.plt*) }.interp : { *(.interp*) }.gnu : { *(.gnu*) }
}
_romsize = _edata - _stext;
_ramsize = _end - _stext;

xip鏈接腳本


OUTPUT_FORMAT("elf32-littlearm", "elf32-littlearm", "elf32-littlearm")
OUTPUT_ARCH(arm)
ENTRY(_start)
SECTIONS
{. = 0xe0000000;. = ALIGN(4);.text 0xe000000c : {_stext = .;*(.vectors)*(.text*)*(.rodata .rodata*)  /* read-only data (constants) */. = ALIGN(4);*(.glue*)_etext = . ;}__exidx_start = .;.ARM.exidx  : { *(.ARM.exidx* .gnu.linkonce.armexidx.*) }__exidx_end = .;. = ALIGN(8);_edummy = .;/* data sections */.data 0xf4000000 : AT ( _edummy ) {_sdata = .;__ld_real_data_start = .;*(.data*)_edata = .;}. = ALIGN(8);/* bss sections */_sbss = .;.bss (NOLOAD) : {*(.bss .bss.*). = ALIGN(4);}_ebss = .;/*stack sections 4K*/.stack (NOLOAD):{. = ALIGN(64);. = . + 0x1000;__stack = .;}_end = .;.pagetable (NOLOAD):{. = ALIGN(16*1024);__pagetable_start = .;. = . + 0x00004000;}.dynsym : { *(.dynsym) }.dynbss : { *(.dynbss) }.dynstr : { *(.dynstr*) }.dynamic : { *(.dynamic*) }.hash : { *(.hash*) }.plt : { *(.plt*) }.interp : { *(.interp*) }.gnu : { *(.gnu*) }
}
_romsize = _edata - _stext;
_ramsize = _end - _stext;

1.2更改控制器代碼:

#define QSPI_ENTER_XIP_MODE       ((1 << 7) + (1 << 11) + (0x3 << 12))void qspi_enter_xip_mode(uint32_t base)
{uint32_t value;volatile pstruct_qspi_reg_t addr = (pstruct_qspi_reg_t)base;value = addr->QSPI_CONFIGURATION;value |= QSPI_ENTER_XIP_MODE;addr->QSPI_CONFIGURATION = value;
}

二、使用:

直接跳過image的包頭后,PC直接在text段上運行。運行正常。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/902679.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/902679.shtml
英文地址,請注明出處:http://en.pswp.cn/news/902679.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【C++】 —— 筆試刷題day_23

一、 打怪 題目解析 我們現在要去刷毛球怪&#xff0c;我的攻擊和血量是h和a、毛球怪的攻擊和血量是H和A&#xff1b; 我們和毛球怪的對決是輪流攻擊(我們先手)&#xff0c;當血量小于等于0時死亡&#xff1b; 現在我們要求在自己存活的條件下&#xff0c;最多能夠殺死幾只毛球…

對話模型和補全模型區別

對話模型和補全模型區別 什么是對話模型、補全模型 什么是 Completion 最基本地說,文本模型是一個經過訓練的大型數學模型,旨在完成一項單一任務:預測下一個 token 或字符。這個過程被稱為 completion,在您的旅程中您會經常遇到這個術語。 例如,當使用 completion 文本…

dirsearch 使用教程:詳細指南與配置解析

dirsearch 是一款強大的開源命令行工具&#xff0c;用于對 Web 服務器進行目錄和文件暴力破解。它通過掃描目標網站&#xff0c;嘗試發現隱藏的目錄、文件或潛在的敏感資源&#xff0c;廣泛應用于滲透測試和安全審計。dirsearch 提供豐富的選項和靈活的配置文件支持&#xff0c…

跟著deepseek學golang--認識golang

文章目錄 一、Golang核心優勢1. 極簡部署方式生產案例??&#xff1a;依賴管理??&#xff1a;容器實踐??&#xff1a; 2. 靜態類型系統??類型安全示例??&#xff1a;性能優勢??&#xff1a;??代碼重構??&#xff1a; 3. 語言級并發支持??GMP調度模型實例??&…

Web常見攻擊方式及防御措施

一、常見Web攻擊方式 1. 跨站腳本攻擊(XSS) 攻擊原理&#xff1a;攻擊者向網頁注入惡意腳本&#xff0c;在用戶瀏覽器執行 存儲型XSS&#xff1a;惡意腳本存儲在服務器&#xff08;如評論區&#xff09; 反射型XSS&#xff1a;惡意腳本通過URL參數反射給用戶 DOM型XSS&…

CGAL 網格內部生成隨機點

文章目錄 一、簡介二、實現代碼三、實現效果參考資料一、簡介 這里實現一種基于點的射線法來判斷一個點是否一個多面提的內部,通過不停的生成隨機點,以達到我們想要的效果,思路其實相對簡單,但是很實用。具體內容如下: 1. 首先,我們需要構建隨機方向的射線(半無限射線)…

tigase源碼學習雜記-組件化設計

前言 tigase官方號稱高度抽象和組件化。這篇文章就記錄一下我研究組件化的相關設計 概述 我的理解tigase高度組件化是所有的關鍵的功能的類&#xff0c;它都稱之為組件&#xff0c;即只要繼承于BasicComponent&#xff0c;它都可以成為組件&#xff0c;BasicComponent類實現…

【Redis】 Redis中常見的數據類型(二)

文章目錄 前言一、 List 列表1. List 列表簡介2.命令3. 阻塞版本命令4. 內部編碼5. 使用場景 二、Set 集合1. Set簡單介紹2. 普通命令3 . 集合間操作4. 內部編碼5. 使用場景 三、Zset 有序集合1.Zset 有序集合簡介2. 普通命令3. 集合間操作4. 內部編碼5. 使用場景 結語 前言 在…

OpenAI為何覬覦Chrome?AI時代瀏覽器爭奪戰背后的深層邏輯

目錄 引言&#xff1a;一場蓄謀已久的"蛇吞象"計劃 一、Chrome&#xff1a;數字世界的"黃金入口" 1.1 用戶規模對比&#xff1a;ChatGPT與Chrome的懸殊差距 1.2 Chrome的生態價值遠超瀏覽器本身 二、OpenAI的"入口焦慮"與戰略布局 2.1 AI時…

二分小專題

P1102 A-B 數對 P1102 A-B 數對 暴力枚舉還是很好做的&#xff0c;直接上雙層循環OK 二分思路:查找邊界情況&#xff0c;找出最大下標和最小下標&#xff0c;兩者相減1即為答案所求 廢話不多說&#xff0c;上代碼 //暴力O(n^3) 72pts // #include<bits/stdc.h> // usin…

java延遲map, 自定義延遲map, 過期清理map,map能力擴展。如何設置map數據過期,改造map適配數據過期

1. 功能&#xff1a; map 線程安全&#xff0c;能夠對存入的數據設置過期&#xff0c;或者自定義刪除 2. aliyun代碼看到的一個對象正好符合上述需求 出處是aliyun sdk core jar包的一個類。感興趣可以去下載下jar查看 下面是源碼&#xff1a; package com.aliyuncs.policy.…

國芯思辰|可編程線性霍爾傳感器AH820替換HAL825用于汽車渦輪增壓

渦輪增壓技術是提高發動機的進氣能力的技術&#xff0c;霍爾傳感器可以達到監測渦輪轉速的作用。在渦輪增壓器的軸上安裝一個永磁體&#xff0c;當渦輪旋轉時&#xff0c;永磁體也隨之轉動&#xff0c;產生周期性變化的磁場。霍爾傳感器靠近永磁體安裝&#xff0c;能夠檢測到磁…

(轉)正則化等最優化方法介紹

參考&#xff1a; http://blog.csdn.net/pipisorry/article/details/52108040 附帶 損失函數&#xff1b;經驗風險&#xff1b;正則化&#xff1b;結構風險 損失函數&#xff08;loss function&#xff09;是用來估量你模型的預測值f(x)與真實值Y的不一致程度&#xff0c;它是…

多維時序 | LightGBM多變量時序預測(Matlab完整源碼和數據,適合基礎小白研究)

多維時序 | LightGBM多變量時序預測&#xff08;Matlab完整源碼和數據&#xff0c;適合基礎小白研究&#xff09; 目錄 多維時序 | LightGBM多變量時序預測&#xff08;Matlab完整源碼和數據&#xff0c;適合基礎小白研究&#xff09;效果一覽基本介紹程序設計參考資料 效果一覽…

【解決】Android Gradle Sync 報錯 Could not read workspace metadata

異常信息 Caused by: java.io.UncheckedIOException:Could not read workspace metadata from C:\Users\xxx\.gradle\caches\transforms-4\69955912123c68eecd096b71c66ee211\metadata.bin 異常原因 看字面意思是不能讀取metadata文件&#xff0c;原因可能是因為緩存目錄異常…

Java面試實戰:電商場景下的Spring Cloud微服務架構與緩存技術剖析

第一輪提問 面試官: 謝飛機&#xff0c;我們先從基礎問題開始。請問你知道Spring Boot和Spring Cloud的區別嗎&#xff1f; 謝飛機: 當然知道&#xff01;Spring Boot主要用于快速構建獨立運行的Spring應用&#xff0c;而Spring Cloud則是在Spring Boot的基礎上實現分布式系統…

Express 路由使用、請求報文參數獲取、路由參數提取

Express 路由使用、請求報文參數獲取、路由參數提取 &#x1f6e3;? 一、Express 路由基本用法 const express require(express); const app express();// 基本 GET 路由 app.get(/, (req, res) > {res.send(Hello GET!); });// POST 路由 app.post(/submit, (req, res)…

【前端】手寫代碼輸出題易錯點匯總

兩天更新完。 const promise new Promise((resolve, reject) > {console.log(1);console.log(2); }); promise.then(() > {console.log(3); }); console.log(4); //1 //2 //4promise.then 是微任務&#xff0c;它會在所有的宏任務執行完之后才會執行&#xff0c;同時需…

基于深度學習和單目測距的前車防撞及車道偏離預警系統

隨著人工智能與計算機視覺技術的飛速發展,高級駕駛輔助系統(ADAS)已成為現代汽車智能化的關鍵標志。它不僅能有效提升行車安全,還能為自動駕駛時代的全面到來奠定堅實基礎。本文深入剖析一套功能完備、基于深度學習模型的 ADAS 系統的架構與核心實現,帶您領略智能駕駛背后…

JWT(JSON Web Token)用戶認證

1、頒發token <!--JWT依賴--><dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt</artifactId><version>0.9.1</version></dependency><dependency><groupId>javax.xml.bind</groupId>…