下面是2015年中興硬件筆試題目,供相關(guān)求職者參考。
一.選擇判斷題:
1.ChipScope 是哪個(gè)FPGA廠家的在線調(diào)試技術(shù)(Xilinx,Altera的是SignalTap)
2.FPGA設(shè)計(jì)中既可以用于靜態(tài)驗(yàn)證又可以用于動(dòng)態(tài)仿真的是(斷言,類似于C語(yǔ)言里的asse,靜態(tài)驗(yàn)證類似于程序在編譯階段就能發(fā)現(xiàn)錯(cuò)誤,動(dòng)態(tài)仿真是仿真階段發(fā)現(xiàn)錯(cuò)誤)
3.WCDMA 的碼片速率是:3.84Mcps(居然蒙對(duì)了)
4.下面對(duì)ARM寄存器的描述錯(cuò)誤的是(A,PC指向當(dāng)前執(zhí)行指令的下兩條指令PC+8)
5. 單片機(jī)最小系統(tǒng)板的硬件調(diào)試順序(好像是選B,檢查焊接->檢查電源是否短路->程序是否能正確燒寫->復(fù)位電平->時(shí)鐘電路是否起振->調(diào)試外圍電路)
6.高速PCB設(shè)計(jì)中應(yīng)盡量保證地平面的(完整性)
7.源端端接與末端端接的作用(末端端接消除一次反射,源端端接消除第二次反射)
8.信號(hào)完整性包括(反射.地彈.振鈴.串?dāng)_)
9.重新上電后不需要重新配置的是(Altera 的MAXII,是CPLD)
10.根據(jù)信息量選擇最佳DSP速率(200MIPS)
11.cpu向外圍芯片寄存器A寫入0x8F,讀出 0x0F,不可能的原因是(個(gè)人認(rèn)為“寄存器最高位不可讀”選項(xiàng)是錯(cuò)誤的,不可讀的話讀出來(lái)應(yīng)該是1,個(gè)人感覺(jué))
12.LCD的種類包括(反射型,全透型和半透型 )。
13. 大小為128的RAM可能是(128是bit還是byte?)
14.EMC的三要素包括(干擾源.耦合路徑.敏感設(shè)備)
15.6層板比較好的層疊是(信號(hào)-地-信號(hào)-電源-地-信號(hào))
16.C語(yǔ)言中用到CPU寄存器的變量有(函數(shù)參數(shù).函數(shù)返回值)
17.戴維南定理包括(節(jié)點(diǎn)電壓法和回路電流法)
18.阻抗匹配方式(源端串聯(lián)匹配.終端并聯(lián)匹配.RC匹配.二極管匹配)
19.51單片機(jī)的總線包括(數(shù)據(jù)總線.地址總線.控制總線)
20.兩個(gè)16位有符號(hào)數(shù)相乘,結(jié)果最少用多少位數(shù)來(lái)保存?
21.16位有符號(hào)數(shù)進(jìn)行4次乘加,結(jié)果最少用多少位數(shù)來(lái)保存?(沒(méi)看懂)
22.setup time的概念
23.ARM存儲(chǔ)保護(hù)機(jī)制
二.問(wèn)答題
1.FPGA 選型時(shí)要考慮哪些方面?(容量.速度.片內(nèi)資源.功耗.成本.配置方式.開(kāi)發(fā)工具等等)
2.什么是競(jìng)爭(zhēng)冒險(xiǎn)?怎么產(chǎn)生的?如何消除?
在組合邏輯中,由于門的輸入信號(hào)通路中經(jīng)過(guò)了不同的延時(shí),導(dǎo)致到達(dá)該門的時(shí)間不一致叫競(jìng)爭(zhēng)。產(chǎn)生毛刺叫冒險(xiǎn)。如果布爾式中有相反的信號(hào)則可能產(chǎn)生競(jìng)爭(zhēng)和冒險(xiǎn)現(xiàn)象。解決方法:一是添加布爾式的消去項(xiàng),二是在芯片外部加電容。
3.EMC從哪些方面設(shè)計(jì)?
a.結(jié)構(gòu),屏蔽與接地b. 電纜.連接器與接口電路c.濾波與抑制d.旁路和去耦e.PCB設(shè)計(jì)f.器件.軟件4.用模擬電路設(shè)計(jì)加法器三.設(shè)計(jì)題1.C5000系列DSP的最小系統(tǒng)框圖并說(shuō)明硬件調(diào)試流程(用來(lái)地址解碼的CPLD.flash,sdram,電源,復(fù)位,時(shí)鐘,jtag)
2.用HDL寫4.5分頻電路。源程序如下: LIBRARY IEEE;
USE IEEE.STD_LOGIC_1164.ALL;
USE IEEE.STD_LOGIC_UNSIGNED.ALL; USE IEEE.STD_LOGIC_ARITH.ALL;
ENTITY DIVISION_4_5 IS
PORT(CLK : IN STD_LOGIC;
Q : BUFFER STD_LOGIC); END
ARCHITECTURE behav OF DIVISION_4_5 IS
CONSTANT PRESET:STD_LOGIC_VECTOR(2 DOWNTO 0):="101"; SIGNAL COUNT:STD_LOGIC_VECTOR(2 DOWNTO 0); SIGNAL P1,P2:STD_LOGIC; BEGIN
P1<=CLK XOR P2;
PROCESS(P1) BEGIN
IF RISING_EDGE(P1) THEN IF(COUNT="000") THEN
COUNT<=PRESET-1; Q<='1';
ELSE
COUNT<=COUNT-1; Q<='0'; END IF; END IF;
END PROCESS MODN_COUNTER;
PROCESS(Q) BEGIN
IF RISING_EDGE (Q)THEN P2<=NOT P2; END IF; END PROCESS END behav;