<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 學(xué)習方法與實(shí)踐 > 關(guān)于學(xué)習verilog

關(guān)于學(xué)習verilog

——
作者: 時(shí)間:2007-02-27 來(lái)源: 收藏

規范很重要

  工作過(guò)的朋友肯定知道,公司里是很強調規范的,特別是對于大的設計(無(wú)論軟件
還是硬件),不按照規范走幾乎是不可實(shí)現的。邏輯設計也是這樣:如果不按規范做的
話(huà),過(guò)一個(gè)月后調試時(shí)發(fā)現有錯,回頭再看自己寫(xiě)的代碼,估計很多信號功能都忘了,
更不要說(shuō)檢錯了;如果一個(gè)項目做了一半一個(gè)人走了,接班的估計得從頭開(kāi)始設計;如
果需要在原來(lái)的版本基礎上增加新功能,很可能也得從頭來(lái)過(guò),很難做到設計的可重用
性。

 


在邏輯方面,我覺(jué)得比較重要的規范有這些:
  1.設計必須文檔化。要將設計思路,詳細實(shí)現等寫(xiě)入文檔,然后經(jīng)過(guò)嚴格評審通過(guò)
后才能進(jìn)行下一步的工作。這樣做乍看起來(lái)很花時(shí)間,但是從整個(gè)項目過(guò)程來(lái)看,絕對
要比一上來(lái)就寫(xiě)代碼要節約時(shí)間,且這種做法可以使項目處于可控、可實(shí)現的狀態(tài)。

  2.代碼規范。
  a.設計要參數化。比如一開(kāi)始的設計時(shí)鐘周期是30ns,復位周期是5個(gè)時(shí)鐘周期,我
們可以這么寫(xiě):
     parameter CLK_PERIOD = 30;
     parameter RST_MUL_TIME = 5;
     parameter RST_TIME = RST_MUL_TIME * CLK_PERIOD;
     ...
     rst_n = 1'b0;
     # RST_TIME rst_n = 1'b1;
     ...
     # CLK_PERIOD/2 clk <= ~clk;
  如果在另一個(gè)設計中的時(shí)鐘是40ns,復位周期不變,我們只需對CLK_PERIOD進(jìn)行重
新例化就行了,從而使得代碼更加易于重用。

  b.信號命名要規范化。
  1) 信號名一律小寫(xiě),參數用大寫(xiě)。
  2) 對于低電平有效的信號結尾要用_n標記,如rst_n。
  3) 端口信號排列要統一,一個(gè)信號只占一行,最好按輸入輸出及從哪個(gè)模塊來(lái)到哪
個(gè)模塊去的關(guān)系排列,這樣在后期仿真驗證找錯時(shí)后 方便很多。如:
   module a(
        //input
        clk,
        rst_n,  //globle signal
        wren,
        rden,
        avalon_din, //related to avalon bus
        sdi,     //related to serial port input
        //output
        data_ready,
        avalon_dout, //related to avalon bus
        ...
       );
   4) 一個(gè)模塊盡量只用一個(gè)時(shí)鐘,這里的一個(gè)模塊是指一個(gè)module或者是一個(gè)en
tity。在多時(shí)鐘域的設計中涉及到跨時(shí)鐘域的設計中最好有專(zhuān)門(mén)一個(gè)模塊做時(shí)鐘域的隔
離。這樣做可以讓綜合器綜合出更優(yōu)的結果。
   5) 盡量在底層模塊上做邏輯,在高層盡量做例化,頂層模塊只能做例化,禁止
出現任何膠連邏輯(glue logic),哪怕僅僅是對某個(gè)信號取反。理由同上。
   6) 在FPGA的設計上禁止用純組合邏輯產(chǎn)生latch,帶D觸發(fā)器的latch的是允許的
,比如配置寄存器就是這種類(lèi)型。
   7) 一般來(lái)說(shuō),進(jìn)入FPGA的信號必須先同步,以提高系統工作頻率(板級)。
    所有模塊的輸出都要寄存器化,以提高工作頻率,這對設計做到時(shí)序收斂也
是極有好處的。
   9) 除非是低功耗設計,不然不要用門(mén)控時(shí)鐘--這會(huì )增加設計的不穩定性,在要
用到門(mén)控時(shí)鐘的地方,也要將門(mén)控信號用時(shí)鐘的下降沿 打一拍再輸出與時(shí)鐘相與。
        clk_gate_en   --------          ----
       -----------------|D   Q |------------------|   gate_clk
_out
                |    |     ---------|   )--------
-
            ------o|>    |     |    |   /
        clk  |    --------      |     ----
       ------------------------------------
   10)禁止用計數器分頻后的信號做其它模塊的時(shí)鐘,而要用改成時(shí)鐘使能的方式
,否則這種時(shí)鐘滿(mǎn)天飛的方式對設計的可靠性極為不利,也大大增加了靜態(tài)時(shí)序分析的
復雜性。如FPGA的輸入時(shí)鐘是25M的,現在系統內部要通過(guò)RS232與PC通信,要以rs232_
1xclk的速率發(fā)送數據。
    不要這樣做:
    always (posedge rs232_1xclk or negedge rst_n)
    begin
      ...
    end
    而要這樣做:
    always (posedge clk_25m or negedge rst_n)
    begin
      ...
      else if ( rs232_1xclk == 1'b1 )
      ...
    end
   11)狀態(tài)機要寫(xiě)成3段式的(這是最標準的寫(xiě)法),即
     ...
     always @(posedge clk or negedge rst_n)
     ...
       current_state <= next_state;
     ...
     always @ (current_state ...)
     ...
     case(current_state)
        ...
        s1:
         if ...
          next_state = s2;
        ...
     ...
     always @(posedge clk or negedge rst_n)
     ...
       else
        a <= 1'b0;
        c <= 1'b0;
        c <= 1'b0;      //賦默認值
         case(current_state)
           s1:
             a <= 1'b0;  //由于上面賦了默認值,這里就不用再對b
、c賦值了(b、c在該狀態(tài)為0,不會(huì )產(chǎn)生鎖存器,下同)
           s2:
             b <= 1'b1;
           s3:
             c <= 1'b1;
           default:
           ...
    ...

   3.ALTERA參考設計準則
    1) Ensure Clock, Preset, and Clear configurations are free of glitch
es.
    2) Never use Clocks consisting of more than one level of combinatori
al logic.
    3) Carefully calculate setup times and hold times for multi-Clock sy
stems.
    4) Synchronize signals between flipflops in multi-Clock systems when
the setup and hold time requirements cannot be met.
    5) Ensure that Preset and Clear signals do not contain race conditio
ns.
    6) Ensure that no other internal race conditions exist.
    7) Register all glitch-sensitive outputs.
    Synchronize all asynchronous inputs.
    9) Never rely on delay chains for pin-to-pin or internal delays.
    10)Do not rely on Power-On Reset. Use a master Reset pin to clear al
l flipflops.
    11)Remove any stuck states from state machines or synchronous logic.


時(shí)序是設計出來(lái)的
  我的boss有在華為及峻龍工作的背景,自然就給我們講了一些華為及altera做邏輯
的一些東西,而我們的項目規范,也基本上是按華為的那一套去做。在工作這幾個(gè)月中
,給我感觸最深的是華為的那句話(huà):時(shí)序是設計出來(lái)的,不是仿出來(lái)的,更不是湊出來(lái)
的。

  在我們公司,每一個(gè)項目都有很?chē)栏竦脑u審,只有評審通過(guò)了,才能做下一步的工
作。以做邏輯為例,并不是一上來(lái)就開(kāi)始寫(xiě)代碼,而是要先寫(xiě)總體設計方案和邏輯詳細
設計方案,要等這些方案評審通過(guò),認為可行了,才能進(jìn)行編碼,一般來(lái)說(shuō)這部分工作
所占的時(shí)間要遠大于編碼的時(shí)間。

  總體方案主要是涉及模塊劃分,一級模塊和二級模塊的接口信號和時(shí)序(我們要求
把接口信號的時(shí)序波形描述出來(lái))以及將來(lái)如何測試設計。在這一級方案中,要保證在
今后的設計中時(shí)序要收斂到一級模塊(最后是在二級模塊中)。什么意思呢?我們在做
詳細設計的時(shí)候,對于一些信號的時(shí)序肯定會(huì )做一些調整的,但是這種時(shí)序的調整最多
只能波及到本一級模塊,而不能影響到整個(gè)設計。記得以前在學(xué)校做設計的時(shí)候,由于
不懂得設計時(shí)序,經(jīng)常因為有一處信號的時(shí)序不滿(mǎn)足,結果不得不將其它模塊信號的時(shí)
序也改一下,搞得人很郁悶。

  在邏輯詳細設計方案這一級的時(shí)候,我們已經(jīng)將各級模塊的接口時(shí)序都設計出來(lái)了
,各級模塊內部是怎么實(shí)現的也基本上確定下來(lái)了。

  由于做到這一點(diǎn),在編碼的時(shí)候自然就很快了,最重要的是這樣做后可以讓設計會(huì )
一直處于可控的狀態(tài),不會(huì )因為某一處的錯誤引起整個(gè)設計從頭進(jìn)行。



如何提高電路工作頻率

  對于設計者來(lái)說(shuō),我們當然希望我們設計的電路的工作頻率(在這里如無(wú)特別說(shuō)明
,工作頻率指FPGA片內的工作頻率)盡量高。我們也經(jīng)常聽(tīng)說(shuō)用資源換速度,用流水的
方式可以提高工作頻率,這確實(shí)是一個(gè)很重要的方法,今天我想進(jìn)一步去分析該如何提
高電路的工作頻率。

  我們先來(lái)分析下是什么影響了電路的工作頻率。

  我們電路的工作頻率主要與寄存器到寄存器之間的信號傳播時(shí)延及clock skew有關(guān)
。在FPGA內部如果時(shí)鐘走長(cháng)線(xiàn)的話(huà),clock skew很小,基本上可以忽略, 在這里為了簡(jiǎn)
單起見(jiàn),我們只考慮信號的傳播時(shí)延的因素。

  信號的傳播時(shí)延包括寄存器的開(kāi)關(guān)時(shí)延、走線(xiàn)時(shí)延、經(jīng)過(guò)組合邏輯的時(shí)延(這樣劃
分或許不是很準確,不過(guò)對分析問(wèn)題來(lái)說(shuō)應該是沒(méi)有可以的),要提高電路的工作頻率
,我們就要在這三個(gè)時(shí)延中做文章,使其盡可能的小。

  我們先來(lái)看開(kāi)關(guān)時(shí)延,這個(gè)時(shí)延是由器件物理特性決定的,我們沒(méi)有辦法去改變,
所以我們只能通過(guò)改變走線(xiàn)方式和減少組合邏輯的方法來(lái)提高工作頻率。

  1.通過(guò)改變走線(xiàn)的方式減少時(shí)延。
  以altera的器件為例,我們在quartus里面的timing closure floorplan可以看到有
很多條條塊塊,我們可以將條條塊塊按行和按列分,每一個(gè)條塊代表1個(gè)LAB,每個(gè)LAB里
有8個(gè)或者是10個(gè)LE。它們的走線(xiàn)時(shí)延的關(guān)系如下:同一個(gè)LAB中(最快) < 同列或者同
行 < 不同行且不同列。
  我們通過(guò)給綜合器加適當的約束(不可貪心,一般以加5%裕量較為合適,比如電路
工作在100Mhz,則加約束加到105Mhz就可以了,貪心效果反而不好,且極大增加綜合時(shí)
間)可以將相關(guān)的邏輯在布線(xiàn)時(shí)盡量布的靠近一點(diǎn),從而減少走線(xiàn)的時(shí)延。(注:約束
的實(shí)現不完全是通過(guò)改進(jìn)布局布線(xiàn)方式去提高工作頻率,還有其它的改進(jìn)措施)

  2.通過(guò)減少組合邏輯的減少時(shí)延。
  上面我們講了可以通過(guò)加約束來(lái)提高工作頻率,但是我們在做設計之初可萬(wàn)萬(wàn)不可
將提高工作頻率的美好愿望寄托在加約束上,我們要通過(guò)合理的設計去避免出現大的組
合邏輯,從而提高電路的工作頻率,這才能增強設計的可移植性,才可以使得我們的設
計在移植到另一同等速度級別的芯片時(shí)還能使用。
  我們知道,目前大部分FPGA都基于4輸入LUT的,如果一個(gè)輸出對應的判斷條件大于
四輸入的話(huà)就要由多個(gè)LUT級聯(lián)才能完成,這樣就引入一級組合邏輯時(shí)延,我們要減少組
合邏輯,無(wú)非就是要輸入條件盡可能的少,,這樣就可以級聯(lián)的LUT更少,從而減少了組
合邏輯引起的時(shí)延。
  我們平時(shí)聽(tīng)說(shuō)的流水就是一種通過(guò)切割大的組合邏輯(在其中插入一級或多級D觸發(fā)
器,從而使寄存器與寄存器之間的組合邏輯減少)來(lái)提高工作頻率的方法。比如一個(gè)32
位的計數器,該計數器的進(jìn)位鏈很長(cháng),必然會(huì )降低工作頻率,我們可以將其分割成4位和
8位的計數,每當4位的計數器計到15后觸發(fā)一次8位的計數器,這樣就實(shí)現了計數器的切
割,也提高了工作頻率。
  在狀態(tài)機中,一般也要將大的計數器移到狀態(tài)機外,因為計數器這東西一般是經(jīng)常
是大于4輸入的,如果再和其它條件一起做為狀態(tài)的跳變判據的話(huà),必然會(huì )增加LUT的級
聯(lián),從而增大組合邏輯。以一個(gè)6輸入的計數器為例,我們原希望當計數器計到111100后
狀態(tài)跳變,現在我們將計數器放到狀態(tài)機外,當計數器計到111011后產(chǎn)生個(gè)enable信號
去觸發(fā)狀態(tài)跳變,這樣就將組合邏輯減少了。

  上面說(shuō)的都是可以通過(guò)流水的方式切割組合邏輯的情況,但是有些情況下我們是很
難去切割組合邏輯的,在這些情況下我們又該怎么做呢?

  狀態(tài)機就是這么一個(gè)例子,我們不能通過(guò)往狀態(tài)譯碼組合邏輯中加入流水。如果我
們的設計中有一個(gè)幾十個(gè)狀態(tài)的狀態(tài)機,它的狀態(tài)譯碼邏輯將非常之巨大,毫無(wú)疑問(wèn),
這極有可能是設計中的關(guān)鍵路徑。那我們該怎么做呢?還是老思路,減少組合邏輯。我
們可以對狀態(tài)的輸出進(jìn)行分析,對它們進(jìn)行重新分類(lèi),并根據這個(gè)重新定義成一組組小
狀態(tài)機,通過(guò)對輸入進(jìn)行選擇(case語(yǔ)句)并去觸發(fā)相應的小狀態(tài)機,從而實(shí)現了將大的
狀態(tài)機切割成小的狀態(tài)機。在A(yíng)TA6的規范中(硬盤(pán)的標準),輸入的命令大概有20十種
,每一個(gè)命令又對應很多種狀態(tài),如果用一個(gè)大的狀態(tài)機(狀態(tài)套狀態(tài))去做那是不可
想象的,我們可以通過(guò)case語(yǔ)句去對命令進(jìn)行譯碼,并觸發(fā)相應的狀態(tài)機,這樣做下來(lái)
這一個(gè)模塊的頻率就可以跑得比較高了。

  總結:提高工作頻率的本質(zhì)就是要減少寄存器到寄存器的時(shí)延,最有效的方法就是
避免出現大的組合邏輯,也就是要盡量去滿(mǎn)足四輸入的條件,減少LUT級聯(lián)的數量。我們
可以通過(guò)加約束、流水、切割狀態(tài)的方法提高工作頻率。

===================================================================================
做邏輯的難點(diǎn)在于系統結構設計和仿真驗證
  剛去公司的時(shí)候BOSS就和我講,做邏輯的難點(diǎn)不在于RTL級代碼的設計,而在于系統
結構設計和仿真驗證方面。目前國內對可綜合的設計強調的比較多,而對系統結構設計
和仿真驗證方面似乎還沒(méi)有什么資料,這或許也從一個(gè)側面反映了國內目前的設計水平
還比較低下吧。

  以前在學(xué)校的時(shí)候,總是覺(jué)得將RTL級代碼做好就行了,仿真驗證只是形式而已,所
以對HDL的行為描述方面的語(yǔ)法不屑一顧,對testbench也一直不愿意去學(xué)--因為覺(jué)得畫(huà)
波形圖方便;對于系統結構設計更是一點(diǎn)都不懂了。

  到了公司接觸了些東西才發(fā)現完全不是這樣。

  其實(shí)在國外,花在仿真驗證上的時(shí)間和人力大概是花在RTL級代碼上的兩倍,現在仿
真驗證才是百萬(wàn)門(mén)級芯片設計的關(guān)鍵路徑。仿真驗證的難點(diǎn)主要在于怎么建模才能完全
和準確地去驗證設計的正確性(主要是提高代碼覆蓋),在這過(guò)程中,驗證速度也是很
重要的。

  驗證說(shuō)白了也就是怎么產(chǎn)生足夠覆蓋率的激勵源,然后怎么去檢測錯誤。我個(gè)人認
為,在仿真驗證中,最基本就是要做到驗證的自動(dòng)化。這也是為什么我們要寫(xiě)testbenc
h的原因。在我現在的一個(gè)設計中,每次跑仿真都要一個(gè)小時(shí)左右(這其實(shí)算小設計)。
由于畫(huà)波形圖無(wú)法做到驗證自動(dòng)化,如果用通過(guò)畫(huà)波形圖來(lái)仿真的話(huà),一是畫(huà)波形會(huì )畫(huà)
死(特別是對于算法復雜的、輸入呈統計分布的設計),二是看波形圖要看死,三是檢
錯率幾乎為零。

  那么怎么做到自動(dòng)化呢?我個(gè)人的水平還很有限,只能簡(jiǎn)單地談下BFM(bus funct
ion model,總線(xiàn)功能模型)。

  以做一個(gè)MAC的core為例(背板是PCI總線(xiàn)),那么我們需要一個(gè)MAC_BFM和PCI_BFM
及PCI_BM(PCI behavior model)。MAC_BFM的主要功能是產(chǎn)生以太網(wǎng)幀(激勵源),隨
機的長(cháng)度和幀頭,內容也是隨機的,在發(fā)送的同時(shí)也將其復制一份到PCI_BM中;PCI_BFM
的功能則是仿PCI總線(xiàn)的行為,比如被測收到了一個(gè)正確幀后會(huì )向PCI總線(xiàn)發(fā)送一個(gè)
請求,PCI_BFM則會(huì )去響應它,并將數據收進(jìn)來(lái);PCI_BM的主要功能是將MAC_BFM發(fā)送出
來(lái)的東西與PCI_BFM接收到的東西做比較,由于它具有了MAC_BFM的發(fā)送信息和PCI_BFM的
接收信息,只要設計合理,它總是可以自動(dòng)地、完全地去測試被測是否工作正常,
從而實(shí)現自動(dòng)檢測。

  華為在仿真驗證方面估計在國內來(lái)說(shuō)是做的比較好的,他們已建立起了比較好的驗
證平臺,大部分與通信有關(guān)的BFM都做好了,聽(tīng)我朋友說(shuō),現在他們只需要將被測放
在測試平臺中,并配置好參數,就可以自動(dòng)地檢測被測功能的正確與否。

  在功能仿真做完后,由于我們做在是FPGA的設計,在設計時(shí)已經(jīng)基本保證RTL級代碼
在綜合結果和功能仿真結果的一致性,只要綜合布局布線(xiàn)后的靜態(tài)時(shí)序報告沒(méi)有違反時(shí)
序約束的警告,就可以下到板子上去調試了。事實(shí)上,在華為中興,他們做FPGA的設計
時(shí)也是不做時(shí)序仿真的,因為做時(shí)序仿真很花時(shí)間,且效果也不見(jiàn)得比看靜態(tài)時(shí)序分析
報告好。

  當然了,如果是ASIC的設計話(huà),它們的仿真驗證的工作量要大一些,在涉及到多時(shí)
鐘域的設計時(shí),一般還是做后仿的。不過(guò)在做后仿之前,也一般會(huì )先用形式驗證工具和
通過(guò)靜態(tài)時(shí)序分序報告去查看有沒(méi)有違反設計要求的地方,這樣做了之后,后仿的工作
量可以小很多。

  在HDL語(yǔ)言方面,國內語(yǔ)言很多人都在爭論VHDL和哪個(gè)好,其實(shí)我個(gè)人認為
這并沒(méi)有多大的意義,外面的大公司基本上都是用在做RTL級的代碼,所以還是
建議大家盡量學(xué)。在仿真方面,由于VHDL在行為級建模方面弱于verilog,用VH
DL做仿真模型的很少,當然也不是說(shuō)verilog就好,其實(shí)verilog在復雜的行為級建模方
面的能力也是有限的,比如目前它還不支持數組。在一些復雜的算法設計中,需要高級
語(yǔ)言做抽象才能描述出行為級模型。在國外,仿真建模很多都是用System C和E語(yǔ)言,用
verilog的都算是很落后的了,國內華為的驗證平臺好像是用System C寫(xiě)。

  在系統結構設計方面,由于我做的設計還不夠大,還談不上什么經(jīng)驗,只是覺(jué)得必
須要具備一些計算機系統結構的知識才行。劃分的首要依據是功能,之后是選擇合適的
總線(xiàn)結構、存儲結構和處理器架構,通過(guò)系統結構劃分要使各部分功能模塊清晰,易于
實(shí)現。這一部分我想過(guò)段時(shí)間有一點(diǎn)體會(huì )了再和大家分享,就先不誤導大家了。

塵埃粒子計數器相關(guān)文章:塵埃粒子計數器原理


關(guān)鍵詞: verilog

評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>