chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

深入淺出,聊聊恒大造車那些事

汽車工程師 ? 來源:汽車工程師 ? 2020-09-02 10:50 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

恒大為什么造車,能不能造好車?這是業(yè)界兩年來存在的疑問。雖然我們知道疑問不一定是質(zhì)疑,也可能是關(guān)心、好奇、期待,但隨著恒馳首期六款車型的發(fā)布,恒大造車的決心或許已從“猶抱琵琶半遮面”,變成“彰明較著”。

我此前曾經(jīng)一路跟進恒大聯(lián)手四大汽車工程技術(shù)龍頭企業(yè)、購買新能源汽車3.0底盤架構(gòu)、全球十五大設(shè)計師合作、科尼塞克發(fā)布等動作,值此恒馳發(fā)布六款車型之際,我們深入淺出,聊聊恒大造車那些事。

人見人“哇”第一步:六車齊發(fā)

2020年8月3日中午,汽車圈平地一聲驚雷,恒大汽車同時發(fā)布六款車型。這一消息猶如深水炸彈,就此掀起市場巨浪。其受關(guān)注度和引起的討論,從數(shù)據(jù)角度來看已連日超過特斯拉十年來的峰值。而對恒馳來說,這只是其第一個真正意義上的“大動作”。

百度搜索指數(shù) 特斯拉十年峰值82797,恒馳峰值91015并且持續(xù)高揚

這次恒馳共發(fā)布六款車型,從恒馳1到恒馳6,覆蓋A-D全級別,及轎車、轎跑、SUV、MPV、跨界車等全系列車型。恒馳1作為一款D級轎車,軸距達到3150mm。

恒馳1 純電超豪華D級轎車

恒馳2 純電運動豪華B級轎跑

恒馳3 純電豪華大型C級SUV

關(guān)于幾款車型的定位介紹網(wǎng)上已有很多,我們就不再贅述。但從產(chǎn)品設(shè)計角度來看,許老板真的促成了與15位全球頂級設(shè)計師的合作,這些大師也曾設(shè)計過賓利歐陸GT、蘭博基尼Huracan、法拉利612 GT0等傳奇、經(jīng)典車型。本次亮相的六款車便出自Anders Warming、Michael Robinson、丸山公顧之手。

恒馳4 純電大7座豪華MPV

馳5 純電A級SUV

恒馳6 純電A級跨界SUV

恒大到底為何造車,能否造好車?

恒大為什么要造車,故事要從幾年前說起。而縱觀造車新勢力市場,他們又為什么造車?李斌的蔚來已經(jīng)上市,車型平均成交價近40萬,月銷量殺入豪華車型前10榜單。李想現(xiàn)在也很理想,雖然SEV車型夭折,但造車本就是“好事多磨”;理想ONE增程式電動車后來居上,助力理想汽車登錄納斯達克,股價也一路高飄。何小鵬的小鵬汽車雙車上陣,P7作為第一款真正意義上的新勢力性能車,開始熱銷。而這三位造車新勢力的創(chuàng)始人,此前多多少少都實現(xiàn)了“財富自由”,All in造車或許真的只是夢想。

遠在北美的特斯拉或許有別樣情懷,火星、飛船、未來科技——馬斯克是個沒人能琢磨透的人,但電動車市場實實在在的在特斯拉的推動之下正無限擴大。同時,特斯拉的市值一路高飄,近3000億美金的市值讓傳統(tǒng)汽車廠商龍頭豐田大眾都望塵莫及。達到這個成績,特斯拉主要靠四款車:Model X、Model S、Model 3、Model Y。

而同時推出六款不同車型的恒大(恒大健康HK0708),近日來股價也是居高不下,市值一度突破3000億港元。高舉高打的恒大汽車,用一眾造車新勢力無法企及的資金實力和投入來大刀闊斧,沖擊萬億市值可能只是時間問題……

資金充裕,顯然是造車的必要條件。從傳統(tǒng)汽車主機廠的路來看,市場占有率、研發(fā)投入、車型發(fā)布量、品牌知名度、產(chǎn)品質(zhì)量與口碑、銷量等都是他們賴以生存和發(fā)展的基石。

即使是保時捷和奔馳寶馬,也曾經(jīng)歷過質(zhì)疑、輕視,更不用說“新兵”恒大。但當時間來到2020年,汽車圈的生存法則已不如當年簡單,技術(shù)壁壘、專利控制等仍然是制約我國汽車工業(yè)發(fā)展的重要因素。

而利用“彎道超車”,大力發(fā)展新能源汽車就是中國汽車工業(yè)發(fā)展的其中一條路?!翱缃缯摺焙愦螅谶@個節(jié)點利用資金優(yōu)勢購入核心技術(shù)和資源,也利用多年的項目整合管理經(jīng)驗來進行汽車領(lǐng)域的創(chuàng)新,則又一次打破了外界的質(zhì)疑。

許老板為什么造車?他或許有多元化恒大集團的目的,有支持中國汽車工業(yè)的想法,有看好新能源汽車市場的前提,又或者還有持續(xù)“實業(yè)報國”的心。

許老板能不能造好車?如果這是開家五星級酒店,我們可以認定的是作為廚子的恒馳已經(jīng)獲得了最大的門店流量、最好的食材供應(yīng)、最優(yōu)秀的打荷師傅等等,而在這個前提下,恒馳的出品怎么會不值得我們?nèi)テ诖完P(guān)注呢?

恒大恐怕不是市場鯰魚,而是鯊魚

去年,我在跟進恒大動態(tài)時曾經(jīng)分析恒大造車闖入的是紅海還是藍海。傳統(tǒng)車市確實早已是槍林彈雨,血流成河,慘不忍睹。在疫情的襲擊下,整體車市仍不樂觀,紅海一如既往硝煙彌漫。

但接近一年后我們再看新能源汽車市場,這片海這片天依舊是東風吹戰(zhàn)鼓擂。特斯拉一直被評論為是新能源汽車市場的“鯰魚”,在特斯拉的攪動之下傳統(tǒng)車企加快建設(shè)步伐,造車新勢力也迅速優(yōu)勝劣汰持續(xù)進化。不同于特斯拉,有強大實力資金做后盾的恒馳,日后或?qū)⒊蔀樾履茉雌囀袌瞿酥琳麄€汽車市場的“鯊魚”。

隨著首期六款車型的發(fā)布,我們也大可抱以開放的態(tài)度,看看恒大產(chǎn)品實車將給我們帶來怎么樣的持續(xù)感官。畢竟對于新事物的誕生來說,最可怕的永遠不是質(zhì)疑,最大的敵人,永遠是自己。

就在這兩天,恒大位于上海、廣州的汽車生產(chǎn)基地也首度曝光。有幾個亮點:
1、兩大基地進入安裝調(diào)試狀態(tài)了,用了2545臺機器人,全面達產(chǎn)后能做到每分鐘生產(chǎn)1輛車。
2、用的配備都是頂貴的:德國舒勒、德國庫卡和日本發(fā)那科、德國杜爾。
3、“三到五年內(nèi)把恒大汽車打造成為世界規(guī)模最大、實力最強的新能源汽車集團”,恒大這個目標沒有變。

恒馳,能重塑新能源汽車產(chǎn)業(yè)格局嗎?這六款車最后會有怎么樣的產(chǎn)品和市場表現(xiàn)?恒大后續(xù)還會推出什么重磅車型?我們不知道,但未來值得期待。

加電,我們邊走邊看。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 新能源汽車
    +關(guān)注

    關(guān)注

    141

    文章

    11000

    瀏覽量

    102706
  • 汽車工業(yè)
    +關(guān)注

    關(guān)注

    2

    文章

    142

    瀏覽量

    30180

原文標題:深度|恒大為什么造車,能不能造好車?

文章出處:【微信號:e700_org,微信公眾號:汽車工程師】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    深入淺出解析:為什么高精度測量要選擇12bit示波器?

    示波器是電子工程師的核心工具,能夠直觀觀察信號特性。本文通過對比實驗,分析12bit和8bit示波器在信號捕捉和波形還原方面的關(guān)鍵差異,解釋為何高精度測量工作中,12bit示波器能提供更可靠的測量結(jié)果。8bit與12bit:數(shù)字背后的真相什么是示波器的“bit數(shù)”時?簡單來說,這是示波器ADC(模數(shù)轉(zhuǎn)換器)的分辨能力,決定了儀器能夠識別的最小電壓變化。這個看
    的頭像 發(fā)表于 05-22 11:40 ?274次閱讀
    <b class='flag-5'>深入淺出</b>解析:為什么高精度測量要選擇12bit示波器?

    門老師教你快速看懂電子電路圖

    本文從最基本的電容電阻開講,包含模電數(shù)電,以及部分電氣知識點,深入淺出。 資料介紹: 全文共分7課,以老師授課和師生交流的形式系統(tǒng)地介紹了電子電路識圖方面的基本知識和技能,包括電路圖的基本概念和要素
    發(fā)表于 05-16 15:17

    程序設(shè)計與數(shù)據(jù)結(jié)構(gòu)

    的地址)出發(fā),采用推導的方式,深入淺出的分析了廣大C程序員學習和開發(fā)中遇到的難點。 2. 從方法論的高度對C語言在數(shù)據(jù)結(jié)構(gòu)和算法方面的應(yīng)用進行了深入講解和闡述。 3. 講解了絕大多數(shù)C程序員開發(fā)
    發(fā)表于 05-13 16:45

    全面解析新概念模擬電路(建議下載!)

    全文共五冊,近50萬字,一樣的風趣幽默,一樣的social化語言,深入淺出地將枯燥深奧的模電知識講得簡單易學。 《新概念模擬電路》內(nèi)容包含了《晶體管》、《負反饋和運算放大器》、《運放電路的頻率特性
    發(fā)表于 04-16 13:37

    深入淺出解析低功耗藍牙協(xié)議棧

    深入Bluetooth LE協(xié)議棧各個組成部分之前,我們先看一下Bluetooth LE協(xié)議棧整體架構(gòu)。 如上圖所述,要實現(xiàn)一個Bluetooth LE應(yīng)用,首先需要一個支持Bluetooth
    的頭像 發(fā)表于 04-09 14:49 ?524次閱讀
    <b class='flag-5'>深入淺出</b>解析低功耗藍牙協(xié)議棧

    2025 中國華東智能家居創(chuàng)新技術(shù)研討會現(xiàn)場直擊,高精度算法如何改變生活?--其利天下

    在此次展會上,我司技術(shù)總監(jiān)馮建武先生帶來了《智能家居的 “心臟” 革命:高精度電機驅(qū)動算法如何重塑未來生活》的演講,深入淺出地闡述了我司目前在無刷馬達自適應(yīng)算法、FOC控制算法等技術(shù)上的優(yōu)勢,以及在智能家居領(lǐng)域上的發(fā)展戰(zhàn)略。
    的頭像 發(fā)表于 03-30 11:11 ?488次閱讀
    2025 中國華東智能家居創(chuàng)新技術(shù)研討會現(xiàn)場直擊,高精度算法如何改變生活?--其利天下

    《零基礎(chǔ)開發(fā)AI Agent——手把手教你用扣子做智能體》

    《零基礎(chǔ)開發(fā)AI Agent——手把手教你用扣子做智能體》是一本為普通人量身打造的AI開發(fā)指南。它不僅深入淺出地講解了Agent的概念和發(fā)展,還通過詳細的工具介紹和實戰(zhàn)案例,幫助讀者快速掌握
    發(fā)表于 03-18 12:03

    光伏電站智能運維系統(tǒng)解決電站運維的那些頭疼

    光伏電站智能運維系統(tǒng)解決電站運維的那些頭疼 在廣袤的戈壁灘上,一排排深藍色的光伏板像沉默的巨人,將陽光轉(zhuǎn)化為清潔電力。但您知道嗎?這些看似躺著就能賺錢的設(shè)備,其實需要像照顧孩子一樣細心呵護。傳統(tǒng)運
    的頭像 發(fā)表于 02-27 16:12 ?326次閱讀
    光伏電站智能運維系統(tǒng)解決電站運維的<b class='flag-5'>那些</b>頭疼<b class='flag-5'>事</b>

    深居AutoCAD二次開發(fā)

    深居AutoCAD二次開發(fā),net版
    發(fā)表于 01-06 14:12 ?9次下載

    一文掌握基礎(chǔ)電路,嵌入式開發(fā)深入淺出

    1. 電路知識 1.1.?驅(qū)動能力 IC是數(shù)字邏輯芯片,其輸出的是邏輯電平。邏輯電平0表示輸出電壓低于閾值電壓,邏輯1表示輸出電壓高于閾值電壓。負載則是被驅(qū)動的電路或元件,負載大小則指負載的電阻大小。 驅(qū)動能力主要表現(xiàn)在幾個方面: 負載能力:負載過大表現(xiàn)為外部負載的阻值過小,在電壓不變的情況下,過小的阻值會導致電流過大,可能會燒壞器件。負載過小,表現(xiàn)為外部負載的阻值達大,在電壓不變的情況下,過大的阻值會導致電流過小,信
    的頭像 發(fā)表于 12-03 10:36 ?944次閱讀
    一文掌握基礎(chǔ)電路,嵌入式開發(fā)<b class='flag-5'>深入淺出</b>

    深入淺出RISC-V調(diào)試

    一、JTAG簡介 目前RISC-V官方支持的調(diào)試方式是JTAG(Joint Test Action Group),而ARM支持的調(diào)試方式有JTAG和SWD(Serial Wire Debug)這兩種。 JTAG是一種國際標準的調(diào)試方式(IEEE1149.1),而SWD是ARM開發(fā)的。標準JTAG采用四線方式,分別是TCK、TMS、TDI和TDO,有一個可選的TRST引腳。 ● TCK:測試時鐘輸入。 ● TMS:測試模式選擇。 ● TDI:測試數(shù)據(jù)輸入。 ● TDO:測試數(shù)據(jù)輸出。 在調(diào)試時需要用到一個工具,比如JLink或者CMSIS-DAP,對于這個工具,在這里稱為JTAG主機(JTAG host),而嵌入在芯片內(nèi)部的JTAG稱為JTAG從機(JTAG slave),需要注意的是上面這些信號的輸入輸出方向是對于JTAG從機來說的。下文中如無特別說明,JTAG都是指JTAG從機。 一個JTAG主機可以同時對多個JTAG從機進行調(diào)試,這通過JTAG掃描鏈(JTAG Scan Chain)完成,如圖1所示。 圖1 一個JTAG主機連接多個JTAG從機 JTAG內(nèi)部有一個TAP(Test Access Port)控制器(或者說狀態(tài)機),通過TCK和TMS信號來改變狀態(tài)機的狀態(tài)。這個狀態(tài)機的核心是兩路SCAN,分別是IR SCAN和DR SCAN,TAP狀態(tài)機如圖2所示。 圖2 TAP狀態(tài)機 箭頭上的0或1表示的是TMS信號的電平。JTAG在每一個TCK信號的上升沿采樣TMS信號和TDI信號,決定狀態(tài)機的狀態(tài)是否發(fā)生變化,在每一個TCK信號的下降沿輸出TDO信號??梢钥吹?,無論TAP目前處于哪一個狀態(tài),只要TMS保持高電平并持續(xù)5個TCK時鐘,則TAP一定會回到Test-Logic-Reset狀態(tài)。 JTAG內(nèi)部有一個IR(instruction register)寄存器和多個DR(data register)寄存器,IR寄存器決定要訪問的是哪一個DR寄存器。DR寄存器有IDCODE、BYPASS等。在Test-Logic-Reset狀態(tài)下IR寄存器默認選擇的是IDCODE這個DR寄存器。 JTAG主機通過IR SCAN設(shè)置IR寄存器的值,然后通過DR SCAN來讀、寫相應(yīng)的DR寄存器。 二、RISC-V調(diào)試Spec 調(diào)試模塊在CPU芯片設(shè)計里是最為不起眼的,但又是最為復雜的模塊之一,大部分開源的處理器IP都沒有調(diào)試模塊。 下面的內(nèi)容基于RISC-V debug spec 0.13版本。 目前RISC-V的官方調(diào)試上位機是openocd,調(diào)試工具可以是JLink或者CMSIS-DAP,RISC-V調(diào)試系統(tǒng)框架如圖3所示。 圖3 RISC-V調(diào)試系統(tǒng)框架 可以看到主要分為3個部分,分別是Debug Host,可以理解為PC;Debug Hardware,可以理解為JLink或者CMSIS-DAP這樣的調(diào)試工具;第三部分就是嵌入在芯片內(nèi)部的調(diào)試模塊。在調(diào)試模塊內(nèi)部,與調(diào)試工具直接交互的是DTM模塊,DTM模塊通過DMI接口與DM模塊交互。 1>DTM模塊 在DTM模塊里實現(xiàn)了一個TAP控制器(狀態(tài)機),其中IR寄存器的長度最少為5位,當TAP控制器復位時,IR的值默認為5\'b00001,即選擇的是IDCODE寄存器。DTM模塊的寄存器(DR寄存器)定義如圖4所示。 圖4 DTM寄存器 其中紅色框起來的寄存器是必須要實現(xiàn)的。下面簡單介紹一下這幾個寄存器。 ① IDCODE寄存器(0x01) 當TAP狀態(tài)機復位時,IR寄存器的值默認為0x01,即選擇的是IDCODE寄存器。IDCODE寄存器的每一位含義如圖5所示。IDCODE是只讀寄存器。 圖5 IDCODE寄存器 ● Version:只讀,版本號,可為任意值。 ● PartNumber:只讀,可為任意值。 ● Manufld:只讀,廠商號,遵循JEP106標準分配,實際中可為任意值,只要不與已分配的廠商號沖突即可。 ② DTM控制和狀態(tài)寄存器(dtmcs,0x10) dtmcs寄存器的每一位含義如圖6所示。 圖6 dtmcs寄存器 ● dmihardreset:DTM模塊硬復位,寫1有效。 ● dmireset:清除出錯,寫1有效。 ● idle:只讀,JTAG 主機在Run-Test-Idle狀態(tài)停留的時鐘周期數(shù),0表示不需要進入Run-Test-Idle狀態(tài),1表示進入Run-Test-Idle狀態(tài)后可以馬上進入下一個狀態(tài),以此類推。 ● dmistat:只讀,上一次操作的狀態(tài)。0表示無出錯,1或者2表示操作出錯,3表示操作還未完成。 ● abits:只讀,dmi寄存器中address域的大小(位數(shù))。 ● version:只讀,實現(xiàn)所對應(yīng)的spec版本,0表示0.11版本,1表示0.13版本。 ③ DM模塊接口訪問寄存器(dmi,0x11) dmi寄存器的每一位含義如圖7所示。 圖7 dmi寄存器 ● address:可讀可寫,DM寄存器的長度(位數(shù))。 ● data:可讀可寫,往DM寄存器讀、寫的數(shù)據(jù),固定為32位。 ● op:可讀可寫,讀或者寫這個域時有不同的含義。當寫這個域時,寫0表示忽略address和data的值,相當于nop操作;寫1表示從address指定的寄存器讀數(shù)據(jù);寫2表示把data的數(shù)據(jù)寫到address指定的寄存器。寫3為保留值。當讀這個域時,0表示上一個操作正確完成;1為保留值;2表示上一個操作失敗,這個狀態(tài)是會被記住的,因此需要往dtmcs寄存器的dmireset域?qū)?才能清除這個狀態(tài)。3表示上一個操作還未完成。 在Update-DR狀態(tài)時,DTM開始執(zhí)行op指定的操作。在Capture-DR狀態(tài)時,DTM更新data域。 ④ BYPASS寄存器(0x1f) 只讀,長度為1,值固定為0。 2>DM模塊 從圖3可知,DM模塊訪問RISC-V Core有兩種方式,一種是通過abstract command,另一種是通過system bus。abstract command方式是必須要實現(xiàn)的,system bus的方式是可選的。 DM模塊的寄存器都為32位,定義如圖8所示。 圖8 DM寄存器 下面介紹一下紅色框起來這幾個重要的寄存器。 ① data寄存器(data0-data11,0x04-0x0f) 這12個寄存器是用于abstract command的數(shù)據(jù)寄存器,長度為32位,可讀可寫。 ② DM控制寄存器(dmcontrol,0x10) dmcontrol寄存器的每一位含義如圖9所示。 圖9 dmcontrol寄存器 ● haltreq:只寫,寫1表示halt(暫停)當前hart(hart表示CPU核,存在多核的情況)。 ● resumereq:只能寫1,寫1表示resume(恢復)當前hart,即go。 ● hartreset:可讀可寫,寫1表示復位DM模塊,寫0表示撤銷復位,這是一個可選的位。 ● ackhavereset:只能寫1,寫1表示清除當前hart的havereset狀態(tài)。 ● hasel:可讀可寫,0表示當前只有一個已經(jīng)被選擇了的hart,1表示當前可能有多個已經(jīng)被選擇了的hart。 ● hartsello:可讀可寫,當前選擇的hart的低10位。1位表示一個hart。 ● hartselhi:可讀可寫,當前選擇的hart的高10位。1位表示一個hart。如果只有一個hart,那么hasel的值為0,hartsello的值為1,hartselhi的值為0。 ● setresethaltreq:只能寫1,寫1表示當前選擇的hart復位后處于harted狀態(tài)。 ● clrresethaltreq:只能寫1,寫1表示清除setresethaltreq的值。 ● ndmreset:可讀可寫,寫1表示復位整個系統(tǒng),寫0表示撤銷復位。 ● dmactive:可讀可寫,寫0表示復位DM模塊,寫1表示讓DM模塊正常工作。正常調(diào)試時,此位必須為1。 ③ DM狀態(tài)寄存器(dmstatus,0x11) dmstatus寄存器是一個只讀寄存器,每一位含義如圖10所示。 圖10 dmstatus寄存器 ● impebreak:1表示執(zhí)行完progbuf的指令后自動插入一條ebreak指令,這樣就可以節(jié)省一個progbuf。當progbufsize的值為1時,此值必須為1。 ● allhavereset:1表示當前選擇的hart已經(jīng)復位。 ● anyhavereset:1表示當前選擇的hart至少有一個已經(jīng)復位。 ● allresumeack:1表示當前選擇的所有hart已經(jīng)應(yīng)答上一次的resume請求。 ● anyresumeack:1表示當前選擇的hart至少有一個已經(jīng)應(yīng)答上一次的resume請求。 ● allnonexistent:1表示當前選擇的hart不存在于當前平臺。 ● anynonexistent:1表示至少有一個選擇了的hart不存在于當前平臺。 ● allunavail:1表示當前選擇的hart都不可用。 ● anyunavail:1表示至少有一個選擇了的hart不可用。 ● allrunning:1表示當前選擇的hart都處于running狀態(tài)。 ● anyrunning:1表示至少有一個選擇了的hart處于running狀態(tài)。 ● allhalted:1表示當前選擇的hart都處于halted狀態(tài)。 ● anyhalted:1表示至少有一個選擇了的hart處于halted狀態(tài)。 ● authenticated:0表示使用DM模塊之前需要進行認證,1表示已經(jīng)通過認證。 ● authbusy:0表示可以進行正常的認證,1表示認證處于忙狀態(tài)。 ● hasresethaltreq:1表示DM模塊支持復位后處于halted狀態(tài),0表示不支持。 ● confstrptrvalid:1表示confstrptr0~3寄存器保存了配置字符串的地址。 ● version:0表示DM模塊不存在,1表示DM模塊的版本為0.11,2表示DM模塊的版本為0.13。 ④ abstract控制和狀態(tài)寄存器(abstractcs,0x16) abstractcs寄存器定義如圖11所示。 圖11 abstractcs寄存器 ● progbufsize:只讀,program buffer的個數(shù),取值范圍為0~16,每一個的大小為32位。 ● busy:只讀,1表示abstract命令正在執(zhí)行,當寫command寄存器后該位應(yīng)該馬上被置位直到命令執(zhí)行完成。 ● cmderr:可讀、只能寫1,cmderr的值僅當busy位為0時有效。0表示無錯誤,1表示正在操作command、abstractcs、data或者progbuf寄存器,2表示不支持當前命令,3表示執(zhí)行命令時出現(xiàn)異常,4表示由于當前hart不可用,或者不是處于halted/running狀態(tài)而不能被執(zhí)行,5表示由于總線出錯(對齊、訪問大小、超時)導致的錯誤,7表示其他錯誤。寫1清零cmderr。 ● datacount:只讀,所實現(xiàn)的data寄存器的個數(shù)。 ⑤ abstract命令寄存器(command,0x17) 當寫這個寄存器時,相應(yīng)的操作就會被執(zhí)行。command寄存器只能寫,定義如圖12所示。 圖12 command寄存器 ● cmdtype:只寫,命令類型,0為表示訪問寄存器,1表示快速訪問,2表示訪問內(nèi)存。 ● control:只寫,不同的命令類型有不同的含義,說明如下。 當cmdtype為0時,control定義如圖13所示。 圖13 訪問寄存器 ● cmdtype:值為0。 ● aarsize:2表示訪問寄存器的最低32位,3表示訪問寄存器的最低64位,4表示訪問寄存器的最低128位。如果大于實際寄存器的大小則此次訪問是失敗的。 ● aarpostincrement:1表示成功訪問寄存器后自動增加regno的值。 ● postexec:1表示執(zhí)行progbuf里的內(nèi)容(指令)。 ● transfer:0表示不執(zhí)行write指定的操作,1表示執(zhí)行write指定的操作。 ● write:0表示從指定的寄存器拷貝數(shù)據(jù)到arg0指定的data寄存器。1表示從arg0指定的data寄存器拷貝數(shù)據(jù)到指定的寄存器。 ● regno:要訪問的寄存器。 綜上,可知: Ⅰ. 當write=0,transfer=1時,從regno指定的寄存器拷貝數(shù)據(jù)到arg0對應(yīng)的data寄存器。 Ⅱ. 當write=1,transfer=1時,從arg0對應(yīng)的data寄存器拷貝數(shù)據(jù)到regno指定的寄存器。 Ⅲ. 當aarpostincrement=1時,將regno的值加1。 Ⅳ. 當postexec=1時,執(zhí)行progbuf寄存器里的指令。 arg對應(yīng)的data寄存器如圖14所示。 圖14 arg對應(yīng)的data寄存器 即當訪問的寄存器位數(shù)為32位時,arg0對應(yīng)data0寄存器,arg1對應(yīng)data1寄存器,arg2對應(yīng)data2寄存器。 當cmdtype為1時,control定義如圖15所示。 圖15 快速訪問 ● cmdtyte:值為1。 此命令會執(zhí)行以下操作: 1)halt住當前hart。 2)執(zhí)行progbuf寄存器里的指令。 3)resume當前hart。 當cmdtype為2時,control定義如圖16所示。 圖16 訪問內(nèi)存 ● cmdtype:值為2。 ● aamvirtual:0表示訪問的是物理地址,1表示訪問的是虛擬地址。 ● aamsize:0表示訪問內(nèi)存的低8位,1表示訪問內(nèi)存的低16位,2表示訪問內(nèi)存的低32位,3表示訪問內(nèi)存的低64位,4表示訪問內(nèi)存的低128位。 ● aampostincrement:1表示訪問成功后,將arg1對應(yīng)的data寄存器的值加上aamsize對應(yīng)的字節(jié)數(shù)。 ● write:0表示從arg1指定的地址拷貝數(shù)據(jù)到arg0指定的data寄存器,1表示從arg0指定的data寄存器拷貝數(shù)據(jù)到arg1指定的地址。 ● target-specific:保留。 綜上,可知: Ⅰ. 當write=0時,從arg1指定的地址拷貝數(shù)據(jù)到arg0指定的data寄存器。 Ⅱ. 當write=1時,從arg0指定的data寄存器拷貝數(shù)據(jù)到arg1指定的地址。 Ⅲ. 當aampostincrement=1時,增加arg1對應(yīng)的data寄存器的值。 ⑥ 系統(tǒng)總線訪問控制和狀態(tài)寄存器(sbcs,0x38) sbcs寄存器定義如圖17所示。 圖17 sbcs寄存器 ● sbversion:只讀,0表示system bus是2018.1.1之前的版本,1表示當前debug spec的版本,即0.13版本。 ● sbbusyerror:只讀,寫1清零,當debugger要進行system bus訪問操作時,如果上一次的system bus訪問還在進行中,此時會置位該位。 ● sbbusy:只讀,1表示system bus正在忙。在進行system bus訪問前必須確保該位為0。 ● sbreadonaddr:可讀可寫,1表示每次往sbaddress0寄存器寫數(shù)據(jù)時,將會自動觸發(fā)system bus從新的地址讀取數(shù)據(jù)。 ● sbaccess:可讀可寫,訪問的數(shù)據(jù)寬度,0表示8位,1表示16位,2表示32位,3表示64位,4表示128位。 ● sbautoincrement:可讀可寫,1表示每次system bus訪問后自動將sbaddress的值加上sbaccess的大小(字節(jié))。 ● sbreadondata:可讀可寫,1表示每次從sbdata0寄存器讀數(shù)據(jù)后將自動觸發(fā)system bus從新的地址讀取數(shù)據(jù)。 ● sberror:可讀,寫1清零,0表示無錯誤,1表示超時,2表示訪問地址錯誤,3表示地址對齊錯誤,4表示訪問大小錯誤,7表示其他錯誤。 ● sbasize:只讀,system bus地址寬度(位數(shù)),0表示不支持system bus訪問。 ● sbaccess128:只讀,1表示system bus支持128位訪問。 ● sbaccess64:只讀,1表示system bus支持64位訪問。 ● sbaccess32:只讀,1表示system bus支持32位訪問。 ● sbaccess16:只讀,1表示system bus支持16位訪問。 ● sbaccess8:只讀,1表示system bus支持8位訪問。 ⑦ 系統(tǒng)總線地址0寄存器(sbaddress0,0x39) 可讀可寫,如果sbcs寄存器中的sbasize的值為0,那么此寄存器可以不用實現(xiàn)。 當寫該寄存器時,會執(zhí)行以下流程: Ⅰ. 設(shè)置sbcs.sbbusy的值為1。 Ⅱ. 從新的sbaddress地址讀取數(shù)據(jù)。 Ⅲ. 如果讀取成功并且sbcs.sbautoincrement的值為1,則增加sbaddress的值。 Ⅳ. 設(shè)置sbcs.sbbusy的值為0。 ⑧ 系統(tǒng)總線數(shù)據(jù)0寄存器(sbdata0,0x3c) 可讀可寫,如果sbcs寄存器中的所有sbaccessxx的值都為0,那么此寄存器可以不用實現(xiàn)。 當寫該寄存器時,會執(zhí)行以下流程: Ⅰ. 設(shè)置sbcs.sbbusy的值為1。 Ⅱ. 將sbdata的值寫到sbaddress指定的地址。 Ⅲ. 如果寫成功并且sbcs.sbautoincrement的值為1,則增加sbaddress的值。 Ⅳ. 設(shè)置sbcs.sbbusy的值為0。 當讀該寄存器時,會執(zhí)行以下流程: Ⅰ. 準備返回讀取的數(shù)據(jù)。 Ⅱ. 設(shè)置sbcs.sbbusy的值為1。 Ⅲ. 如果sbcs.sbautoincrement的值為1,則增加sbaddress的值。 Ⅳ. 如果sbcs.sbreadondata的值為1,則開始下一次讀操作。 Ⅴ. 設(shè)置sbcs.sbbusy的值為0。 三、RISC-V調(diào)試上位機分析 RISC-V官方支持的調(diào)試器上位機是openocd。openocd是地表最強大(沒有之一)的開源調(diào)試上位機,支持各種target(ARM(M、A系列)、FPGA、RISC-V等),支持各種調(diào)試器(Jlink、CMSIS-DAP、FTDI等),支持JTAG和SWD接口。 這里不打算詳細分析整個openocd的實現(xiàn),只是重點關(guān)注針對RISC-V平臺的初始化、讀寫寄存器和讀寫內(nèi)存這幾個流程。 1>openocd啟動過程 openocd啟動時需要通過-f參數(shù)制定一個cfg文件,比如: openocd.exe -f riscv.cfg riscv.cfg文件的內(nèi)容如下: adapter_khz1000 reset_config srst_only adapter_nsrst_assert_width 100 interface cmsis-dap transport select jtag set _CHIPNAME riscv jtag newtap $_CHIPNAME cpu -irlen 5 -expected-id 0x1e200a6d set _TARGETNAME $_CHIPNAME.cpu target create $_TARGETNAME riscv -chain-position $_TARGETNAME ■ 第一行設(shè)置TCK的時鐘為1000KHz。 ■ 第二行表示不支持通過TRST引腳復位,只支持TMS為高電平并持續(xù)5個TCK時鐘這種方式的復位。 ■ 第三行是復位持續(xù)的延時。 ■ 第四行指定調(diào)試器為CMSIS-DAP。 ■ 第五行指定調(diào)試接口為JTAG。 ■ 第六行指定調(diào)試的target類型為riscv。 ■ 第七行指定生成一個IR寄存器長度為5位、IDCODE為0x1e200a6d的JTAG TAP。 ■ 第八、九行指定生成一個riscv target。 openocd啟動時的主要流程如圖18所示。 圖18 openocd啟動流程 下面重點關(guān)注一下examine target這個流程。 這里的target是指riscv,對于riscv,首先會讀取dtmcontrol這個寄存器,因為openocd支持0.11和0.13版本的DTM,通過這個寄存器可以知道當前調(diào)試的DTM是哪一個版本。這里選擇0.13版本來分析。通過讀取dtmcontrol,還可以知道idle、abits這些參數(shù)。接下來會將dmcontrol這個寄存器的dmactive域?qū)?后再寫1來復位DM模塊。接下來再讀取dmstatus,判斷version域是否為2。接下來還會讀取sbcs和abstractcs寄存器,最后就是初始化每一個hart的寄存器。 2>read register過程 讀寄存器時,先構(gòu)建command寄存器的內(nèi)容,首先將cmdtype的值設(shè)為0,aarsize的值設(shè)為2(寄存器的寬度為32位),transfer的值設(shè)為1,regno的值設(shè)為要讀的寄存器的number,其他值設(shè)為0,然后寫到command寄存器里。然后一直讀取abstractcs寄存器,直到abstractcs寄存器的busy位為0或者超時。然后再判斷abstractcs寄存器的cmderr的值是否為0,如果不為0則表示此次讀取寄存器失敗,如果為0則繼續(xù)讀取data0寄存器,這樣就可以得到想要讀的寄存器的值。 3>write register過程 寫寄存器時,先將需要寫的值寫到data0寄存器,然后構(gòu)建command寄存器的內(nèi)容,首先將cmdtype的值設(shè)為0,aarsize的值設(shè)為2(寄存器的寬度為32位),transfer的值設(shè)為1,write的值設(shè)為1,regno的值設(shè)為要寫的寄存器的number,其他值設(shè)為0,然后寫到command寄存器里。然后一直讀取abstractcs寄存器,直到abstractcs寄存器的busy位為0或者超時。然后再判斷abstractcs寄存器的cmderr的值是否為0,如果不為0則表示此次寫寄存器失敗,如果為0則表示寫寄存器成功。 4>read memory過程 如果progbufsize的值大于等于2,則會優(yōu)先使用通過執(zhí)行指令的方式來讀取內(nèi)存。這里不分析這種方式,而是分析使用system bus的方式。通過前面的分析可知,system bus有兩個版本V0和V1,這里以V1版本來說明。 先將sbcs寄存器的sbreadonaddr的值設(shè)為1,sbaccess的值設(shè)為2(32位),然后將要讀內(nèi)存的地址寫入sbaddress0寄存器。接著讀sbdata0寄存器,最后讀sbcs寄存器,如果其中的sbbusy、sberror和sbbusyerror都為0,則從sbdata0讀取到的內(nèi)容就是要讀的內(nèi)存的值。 5>write memory過程 和read memory類似,同樣以V1版本來說明。 先將要寫的內(nèi)存地址寫到sbaddress0寄存器,然后將要寫的數(shù)據(jù)寫到data0寄存器,最后讀sbcs寄存器,如果其中的sbbusy、sberror和sbbusyerror都為0,則此次寫內(nèi)存成功。 四、RISC-V JTAG的實現(xiàn) 通過在STM32F103C8T6上實現(xiàn)(模擬)RISC-V調(diào)試標準,進一步加深對RISC-V JTAG調(diào)試的理解。 使用STM32的四個GPIO作為JTAG信號的四根線,其中TCK所在的引腳設(shè)為外部中斷,即上升沿和下降沿觸發(fā)方式,實現(xiàn)了可以通過openocd以RISC-V的調(diào)試標準來訪問STM32的寄存器和內(nèi)存。程序流程如圖19所示。 圖19 JTAG實現(xiàn)的程序流程 五、參考資料 1、在STM32上模擬RISC-V JTAG的實現(xiàn):stm32_riscv_jtag_slave 2、一個從零開始寫的易懂的RISC-V處理器核:tinyriscv
    發(fā)表于 11-28 22:00

    京準時鐘科普:關(guān)于北斗衛(wèi)星同步時鐘的那些?

    京準時鐘科普:關(guān)于北斗衛(wèi)星同步時鐘的那些?
    的頭像 發(fā)表于 10-29 09:28 ?746次閱讀
    京準時鐘科普:關(guān)于北斗衛(wèi)星同步時鐘的<b class='flag-5'>那些</b><b class='flag-5'>事</b>?

    【「時間序列與機器學習」閱讀體驗】+ 簡單建議

    這本書以其系統(tǒng)性的框架和深入淺出的講解,為讀者繪制了一幅時間序列分析與機器學習融合應(yīng)用的宏偉藍圖。作者不僅扎實地構(gòu)建了時間序列分析的基礎(chǔ)知識,更巧妙地展示了機器學習如何在這一領(lǐng)域發(fā)揮巨大潛力,使得
    發(fā)表于 08-12 11:21

    深入淺出系列之代碼可讀性

    原創(chuàng)聲明:該文章是個人在項目中親歷后的經(jīng)驗總結(jié)和分享,如有搬運需求請注明出處。 這是“深入淺出系列”文章的第一篇,主要記錄和分享程序設(shè)計的一些思想和方法論,如果讀者覺得所有受用,還請“一鍵三連
    的頭像 發(fā)表于 08-09 16:00 ?527次閱讀

    芯片設(shè)計流片、驗證、成本的那些

    前言我們聊聊芯片設(shè)計、流片、驗證、制造、成本的那些;流片對于芯片設(shè)計來說就是參加一次大考。流片的重要性就在于能夠檢驗芯片設(shè)計是否成功,是芯片制造的關(guān)鍵環(huán)節(jié),也就是將設(shè)計好的方案交給芯片制造廠生產(chǎn)
    的頭像 發(fā)表于 08-09 08:11 ?3006次閱讀
    芯片設(shè)計流片、驗證、成本的<b class='flag-5'>那些</b><b class='flag-5'>事</b>