USB的編碼方式
這樣的編碼方式會(huì)遇到一個(gè)很嚴(yán)重的問題:若重復(fù)相同的“1”信號(hào)一直進(jìn)入時(shí),就會(huì)造成數(shù)據(jù)長時(shí)間無法轉(zhuǎn)換,逐漸地累積而導(dǎo)致“塞車”的狀況,使得讀取的時(shí)序就會(huì)發(fā)生嚴(yán)重的錯(cuò)誤。因此,在NRZI編碼之間,還需執(zhí)行所謂的位填塞(bits-tuffing)的工作。如圖4(a)所示,若原始的串行數(shù)據(jù)中含有連續(xù)6個(gè)“1”位,就須執(zhí)行位填塞的工作。此工作如圖4(b)所示,就在其后填塞一個(gè)“0”位。但相對(duì)地在NRZI編碼的過程中,對(duì)這連續(xù)的6個(gè)“1”執(zhí)行,如圖4(c)所示。
圖4 NRZI譯碼的過程
因此在發(fā)送端進(jìn)行數(shù)據(jù)傳輸之前,須先執(zhí)行位填塞和NRZi編碼的工作。相對(duì)的,在接收端進(jìn)行數(shù)據(jù)接收之前,就必須先執(zhí)行NRZI譯碼,然后再做位反填塞(unbit-tuffing)的工作。這一部分的電路會(huì)通過USB芯片中的SIE(串行接口引擎)來實(shí)現(xiàn)。
評(píng)論