⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 chap.1.introduction.ps

📁 嵌入开发笔记 用ps阅读器打开
💻 PS
📖 第 1 页 / 共 2 页
字号:
%!PS-Adobe-1.0%%Creator: hitchcock:tomc (Tom Casavant)%%Title: stdin (ditroff)%%CreationDate: Thu Oct 27 08:58:21 1994%%EndComments% lib/psdit.pro -- prolog for psdit (ditroff) files% Copyright (c) 1984, 1985 Adobe Systems Incorporated. All Rights Reserved.% last edit: shore Sat Nov 23 20:28:03 1985% RCSID: %Header: psdit.pro,v 2.1 85/11/24 12:19:43 shore Rel %% Psfig RCSID $Header: psdit.pro,v 1.5 88/01/04 17:48:22 trevor Exp $/$DITroff 180 dict def $DITroff begin/DocumentInitState [ matrix currentmatrix currentlinewidth currentlinecapcurrentlinejoin currentdash currentgray currentmiterlimit ] cvx def%% Psfig additions/startFig {	/SavedState save def	userdict maxlength dict begin	currentpoint transform	DocumentInitState setmiterlimit setgray setdash setlinejoin setlinecap		setlinewidth setmatrix	itransform moveto	/ury exch def	/urx exch def	/lly exch def	/llx exch def	/y exch 72 mul resolution div def	/x exch 72 mul resolution div def		currentpoint /cy exch def /cx exch def	/sx x urx llx sub div def 	% scaling for x	/sy y ury lly sub div def	% scaling for y	sx sy scale			% scale by (sx,sy)	cx sx div llx sub	cy sy div ury sub translate		/DefFigCTM matrix currentmatrix def	/initmatrix {		DefFigCTM setmatrix	} def	/defaultmatrix {		DefFigCTM exch copy	} def	/initgraphics {		DocumentInitState setmiterlimit setgray setdash 			setlinejoin setlinecap setlinewidth setmatrix		DefFigCTM setmatrix	} def	/showpage {		initgraphics	} def} def% Args are llx lly urx ury (in figure coordinates)/clipFig {	currentpoint 6 2 roll	newpath 4 copy	4 2 roll moveto	6 -1 roll exch lineto	exch lineto	exch lineto	closepath clip	newpath	moveto} def% doclip, if called, will always be just after a `startfig'/doclip { llx lly urx ury clipFig } def/endFig {	end SavedState restore} def/globalstart {	% Push details about the enviornment on the stack.	fontnum fontsize fontslant fontheight 	% firstpage 	mh my resolution slotno currentpoint 	pagesave restore gsave } def/globalend {	grestore moveto	/slotno exch def /resolution exch def /my exch def	/mh exch def 	% /firstpage exch def	/fontheight exch def	/fontslant exch def /fontsize exch def /fontnum exch def	F	/pagesave save def} def%% end XMOD additions/fontnum 1 def /fontsize 10 def /fontheight 10 def /fontslant 0 def/xi {0 72 11 mul translate 72 resolution div dup neg scale 0 0 moveto  /fontnum 1 def /fontsize 10 def /fontheight 10 def /fontslant 0 def F  /pagesave save def}def/xiL {72 8.25 mul 72 11 mul translate -90 rotate  72 resolution div dup neg scale 0 0 moveto  /fontnum 1 def /fontsize 10 def /fontheight 10 def /fontslant 0 def F  /pagesave save def}def/PB{save /psv exch def currentpoint translate   resolution 72 div dup neg scale 0 0 moveto}def/PE{psv restore}def/arctoobig 90 def /arctoosmall .05 def/m1 matrix def /m2 matrix def /m3 matrix def /oldmat matrix def/tan{dup sin exch cos div}def/point{resolution 72 div mul}def/dround	{transform round exch round exch itransform}def/xT{/devname exch def}def/xr{/mh exch def /my exch def /resolution exch def}def/xp{}def/xs{docsave restore end}def/xt{}def/xf{/fontname exch def /slotno exch def fontnames slotno get fontname eq not {fonts slotno fontname findfont put fontnames slotno fontname put}if}def/xH{/fontheight exch def F}def/xS{/fontslant exch def F}def/s{/fontsize exch def /fontheight fontsize def F}def/f{/fontnum exch def F}def/F{fontheight 0 le {/fontheight fontsize def}if   fonts fontnum get fontsize point 0 0 fontheight point neg 0 0 m1 astore   fontslant 0 ne{1 0 fontslant tan 1 0 0 m2 astore m3 concatmatrix}if   makefont setfont .04 fontsize point mul 0 dround pop setlinewidth}def/X{exch currentpoint exch pop moveto show}def/N{3 1 roll moveto show}def/Y{exch currentpoint pop exch moveto show}def/S{show}def/ditpush{}def/ditpop{}def/AX{3 -1 roll currentpoint exch pop moveto 0 exch ashow}def/AN{4 2 roll moveto 0 exch ashow}def/AY{3 -1 roll currentpoint pop exch moveto 0 exch ashow}def/AS{0 exch ashow}def/MX{currentpoint exch pop moveto}def/MY{currentpoint pop exch moveto}def/MXY{moveto}def/cb{pop}def	% action on unknown char -- nothing for now/n{}def/w{}def/p{pop showpage pagesave restore /pagesave save def}def% Manual Feed Definitions/SetStTime{statusdict /manualfeedtimeout 120 put} def/SetStatus{statusdict /manualfeed true put   statusdict /product get (LaserWriter) eq    {version (23.0) eq  % Don't redefine the show page if printer is not "Classic LW"     {/p {	 {statusdict /printerstatus get exec 16#22000000 and 0 eq{exit}if}loop	 pop showpage pagesave restore /pagesave save def}def}if }if}def/abspoint{currentpoint exch pop add exch currentpoint pop add exch}def/distance{dup mul exch dup mul add sqrt}def/dstroke{currentpoint stroke moveto}def/Dl{2 copy gsave rlineto stroke grestore rmoveto}def/arcellipse{/diamv exch def /diamh exch def oldmat currentmatrix pop currentpoint translate 1 diamv diamh div scale /rad diamh 2 div def currentpoint exch rad add exch rad -180 180 arc oldmat setmatrix}def/Dc{dup arcellipse dstroke}def/De{arcellipse dstroke}def/Da{/endv exch def /endh exch def /centerv exch def /centerh exch def /cradius centerv centerv mul centerh centerh mul add sqrt def /eradius endv endv mul endh endh mul add sqrt def /endang endv endh atan def /startang centerv neg centerh neg atan def /sweep startang endang sub dup 0 lt{360 add}if def sweep arctoobig gt {/midang startang sweep 2 div sub def /midrad cradius eradius add 2 div def  /midh midang cos midrad mul def /midv midang sin midrad mul def  midh neg midv neg endh endv centerh centerv midh midv Da  currentpoint moveto Da} {sweep arctoosmall ge  {/controldelt 1 sweep 2 div cos sub 3 sweep 2 div sin mul div 4 mul def  centerv neg controldelt mul centerh controldelt mul  endv neg controldelt mul centerh add endh add  endh controldelt mul centerv add endv add  centerh endh add centerv endv add rcurveto dstroke} {centerh endh add centerv endv add rlineto dstroke}ifelse}ifelse}def/Barray 200 array def % 200 values in a wiggle/D~{mark}def/D~~{counttomark Barray exch 0 exch getinterval astore /Bcontrol exch def pop /Blen Bcontrol length def Blen 4 ge Blen 2 mod 0 eq and {Bcontrol 0 get Bcontrol 1 get abspoint /Ycont exch def /Xcont exch def  Bcontrol 0 2 copy get 2 mul put Bcontrol 1 2 copy get 2 mul put  Bcontrol Blen 2 sub 2 copy get 2 mul put  Bcontrol Blen 1 sub 2 copy get 2 mul put  /Ybi /Xbi currentpoint 3 1 roll def def 0 2 Blen 4 sub  {/i exch def   Bcontrol i get 3 div Bcontrol i 1 add get 3 div   Bcontrol i get 3 mul Bcontrol i 2 add get add 6 div   Bcontrol i 1 add get 3 mul Bcontrol i 3 add get add 6 div   /Xbi Xcont Bcontrol i 2 add get 2 div add def   /Ybi Ycont Bcontrol i 3 add get 2 div add def   /Xcont Xcont Bcontrol i 2 add get add def   /Ycont Ycont Bcontrol i 3 add get add def   Xbi currentpoint pop sub Ybi currentpoint exch pop sub rcurveto  }for dstroke}if}defend/ditstart{$DITroff begin /nfonts 60 def			% NFONTS makedev/ditroff dependent! /fonts[nfonts{0}repeat]def /fontnames[nfonts{()}repeat]def/docsave save def}def% character outcalls/oc {/pswid exch def /cc exch def /name exch def   /ditwid pswid fontsize mul resolution mul 72000 div def   /ditsiz fontsize resolution mul 72 div def   ocprocs name known{ocprocs name get exec}{name cb}   ifelse}def/fractm [.65 0 0 .6 0 0] def/fraction {/fden exch def /fnum exch def gsave /cf currentfont def  cf fractm makefont setfont 0 .3 dm 2 copy neg rmoveto  fnum show rmoveto currentfont cf setfont(\244)show setfont fden show   grestore ditwid 0 rmoveto} def/oce {grestore ditwid 0 rmoveto}def/dm {ditsiz mul}def/ocprocs 50 dict def ocprocs begin(14){(1)(4)fraction}def(12){(1)(2)fraction}def(34){(3)(4)fraction}def(13){(1)(3)fraction}def(23){(2)(3)fraction}def(18){(1)(8)fraction}def(38){(3)(8)fraction}def(58){(5)(8)fraction}def(78){(7)(8)fraction}def(sr){gsave 0 .06 dm rmoveto(\326)show oce}def(is){gsave 0 .15 dm rmoveto(\362)show oce}def(->){gsave 0 .02 dm rmoveto(\256)show oce}def(<-){gsave 0 .02 dm rmoveto(\254)show oce}def(==){gsave 0 .05 dm rmoveto(\272)show oce}defend% an attempt at a PostScript FONT to implement ditroff special chars% this will enable us to %	cache the little buggers%	generate faster, more compact PS out of psdit%	confuse everyone (including myself)!50 dict dup begin/FontType 3 def/FontName /DIThacks def/FontMatrix [.001 0 0 .001 0 0] def/FontBBox [-260 -260 900 900] def% a lie but .../Encoding 256 array def0 1 255{Encoding exch /.notdef put}forEncoding dup 8#040/space put %space dup 8#110/rc put %right ceil dup 8#111/lt put %left  top curl dup 8#112/bv put %bold vert dup 8#113/lk put %left  mid curl dup 8#114/lb put %left  bot curl dup 8#115/rt put %right top curl dup 8#116/rk put %right mid curl dup 8#117/rb put %right bot curl dup 8#120/rf put %right floor dup 8#121/lf put %left  floor dup 8#122/lc put %left  ceil dup 8#140/sq put %square dup 8#141/bx put %box dup 8#142/ci put %circle dup 8#143/br put %box rule dup 8#144/rn put %root extender dup 8#145/vr put %vertical rule dup 8#146/ob put %outline bullet dup 8#147/bu put %bullet dup 8#150/ru put %rule dup 8#151/ul put %underline pop/DITfd 100 dict def/BuildChar{0 begin /cc exch def /fd exch def /charname fd /Encoding get cc get def /charwid fd /Metrics get charname get def /charproc fd /CharProcs get charname get def charwid 0 fd /FontBBox get aload pop setcachedevice 2 setlinejoin 40 setlinewidth newpath 0 0 moveto gsave charproc grestore end}def/BuildChar load 0 DITfd put%/UniqueID 5 def/CharProcs 50 dict defCharProcs begin/space{}def/.notdef{}def/ru{500 0 rls}def/rn{0 840 moveto 500 0 rls}def/vr{0 800 moveto 0 -770 rls}def/bv{0 800 moveto 0 -1000 rls}def/br{0 750 moveto 0 -1000 rls}def/ul{0 -140 moveto 500 0 rls}def/ob{200 250 rmoveto currentpoint newpath 200 0 360 arc closepath stroke}def/bu{200 250 rmoveto currentpoint newpath 200 0 360 arc closepath fill}def/sq{80 0 rmoveto currentpoint dround newpath moveto    640 0 rlineto 0 640 rlineto -640 0 rlineto closepath stroke}def/bx{80 0 rmoveto currentpoint dround newpath moveto    640 0 rlineto 0 640 rlineto -640 0 rlineto closepath fill}def/ci{500 360 rmoveto currentpoint newpath 333 0 360 arc    50 setlinewidth stroke}def/lt{0 -200 moveto 0 550 rlineto currx 800 2cx s4 add exch s4 a4p stroke}def/lb{0 800 moveto 0 -550 rlineto currx -200 2cx s4 add exch s4 a4p stroke}def/rt{0 -200 moveto 0 550 rlineto currx 800 2cx s4 sub exch s4 a4p stroke}def/rb{0 800 moveto 0 -500 rlineto currx -200 2cx s4 sub exch s4 a4p stroke}def/lk{0 800 moveto 0 300 -300 300 s4 arcto pop pop 1000 sub    0 300 4 2 roll s4 a4p 0 -200 lineto stroke}def/rk{0 800 moveto 0 300 s2 300 s4 arcto pop pop 1000 sub    0 300 4 2 roll s4 a4p 0 -200 lineto stroke}def/lf{0 800 moveto 0 -1000 rlineto s4 0 rls}def/rf{0 800 moveto 0 -1000 rlineto s4 neg 0 rls}def/lc{0 -200 moveto 0 1000 rlineto s4 0 rls}def/rc{0 -200 moveto 0 1000 rlineto s4 neg 0 rls}defend/Metrics 50 dict def Metrics begin/.notdef 0 def/space 500 def/ru 500 def/br 0 def/lt 416 def/lb 416 def/rt 416 def/rb 416 def/lk 416 def/rk 416 def/rc 416 def/lc 416 def/rf 416 def/lf 416 def/bv 416 def/ob 350 def/bu 350 def/ci 750 def/bx 750 def/sq 750 def/rn 500 def/ul 500 def/vr 0 defendDITfd begin/s2 500 def /s4 250 def /s3 333 def/a4p{arcto pop pop pop pop}def/2cx{2 copy exch}def/rls{rlineto stroke}def/currx{currentpoint pop}def/dround{transform round exch round exch itransform} defendend/DIThacks exch definefont popditstart(psc)xT576 1 1 xr1(Times-Roman)xf 1 f2(Times-Italic)xf 2 f3(Times-Bold)xf 3 f4(Times-BoldItalic)xf 4 f5(Helvetica)xf 5 f6(Helvetica-Bold)xf 6 f7(Courier)xf 7 f8(Courier-Bold)xf 8 f9(Symbol)xf 9 f10(DIThacks)xf 10 f10 s1 fxi%%EndProlog%%Page: 1 110 s 0 xH 0 xS 1 f3 f12 s576 1023(57:017)N872(CIE)X1 f2224(-)X2280(1)X2352(-)X3 f3458(Lecture)X3803(Notes)X576 1247(1.)N696(NULL)X1 p%%Page: 1 212 s 0 xH 0 xS 3 f16 s2158 803(Chapter)N2645(1)X2084 915(Introduction)N12 s576 1251(1.1.)N768(Overview)X1 f776 1391(This)N979(course)X1262(plays)X1497(a)X1572(unique)X1866(role)X2048(in)X2155(the)X2305(curriculum)X2761(of)X2874(engineers)X3276(in)X3384(our)X2 f3545(digitally)X1 f3900(controlled)X576 1503(world.)N859(Many)X1118(of)X1233(the)X1386(systems)X1725(that)X1905(as)X2020(little)X2233(as)X2348(ten)X2501(years)X2739(ago)X2913(were)X3135(controlled)X3561(by)X3692(analog)X3983(circuits,)X576 1615(mechanical)N1048(apparatus,)X1473(or)X1585 0.3542(electrical)AX1972(relays)X2234(are)X2384(now)X2581(digitally)X2935(controlled.)X3382(One)X3574(of)X3687(the)X3838(largest,)X4152(and)X576 1727(ever-present)N1091(examples)X1494(is)X1597(the)X1754(telephone)X2168(switching)X2581(system)X2887(in)X3001(our)X3168(country.)X3525(Once)X3766(controlled)X4195(by)X576 1839(large)N810(installations)X1317(of)X1438 0.3542(electrical)AX1834(relays,)X2129(this)X2309(task)X2505(is)X2610(nearly)X2892(all)X3030(controlled)X3463(by)X3601(digital)X3890(computers)X576 1951(today.)N839(The)X1014(computers)X1440(employed,)X1869(for)X2006(the)X2148(most)X2359(part,)X2557(are)X2699(general-purpose)X3343(and)X3506(could)X3744(be)X3859(identical)X4216(to)X576 2063(those)N814(processing)X1260(the)X1413(payroll)X1721(at)X1826(General)X2166(Motors,)X2502(or)X2617(controlling)X3075(robots)X3351(on)X3483(an)X3610(assembly)X4004(\257oor)X4221(at)X576 2175(Chrysler.)N955(What)X1188(makes)X1458(each)X1659(instance)X1999(different)X2355(is)X2443(simply)X2729(software.)X776 2315(While)N1037(many)X1276(people)X1558(are)X1701(aware)X1956(of)X2061(the)X2204(use)X2358(of)X2464(computers)X2891(to)X2992(process)X3306(the)X3450(payroll)X3749(at)X3845(a)X3914(company,)X576 2427(and)N748(also)X936(aware)X1199(that)X1377(many)X1624(homes)X1908(contain)X2225(personal)X2584(computers,)X3042(many)X3289(people)X3579(are)X2 f3729(not)X1 f3884(aware)X4146(that)X576 2539(computers)N1004(are)X1149(at)X1246(work)X1470(in)X1572(their)X1776(cars)X1958(\(controlling)X2441(air/fuel)X2748(mixture\))X3108(or)X3216(in)X3319(their)X3524(kitchen)X3836(\(controlling)X576 2651(their)N794(microwave\).)X1343(In)X1464(both)X1676(of)X1797(these)X2036(cases)X2280(again,)X2554(the)X2713(only)X2925(difference)X3357(in)X3473(these)X3712(systems)X4056(which)X576 2763(cause)N816(one)X981(to)X1082(behave)X1382(like)X1554(a)X1624(car,)X1793(and)X1959(the)X2104(other)X2329(to)X2431(behave)X2731(like)X2903(a)X2973(kitchen)X3284(applicance)X3724(is)X3815(the)X3960(software)X576 2875(contained)N996(in)X1116(the)X1279(respective)X1715(memories)X2140(of)X2265(the)X2428(two)X2616(systems.)X3012(It)X3115(is)X3223(this)X3406(ever-present)X3926(aspect)X4211(of)X576 2987(microprocessor-based,)N1478 0.1806(computer-controlled)AX2299(systems)X2637(that)X2816(brings)X3090(us)X3209(to)X3319(the)X3472(study)X3715(of)X3830(the)X3983(topic)X4211(of)X576 3099(this)N739(course.)X776 3239(Our)N954(course)X1234(has)X1391(three)X1613(main)X1835(practical)X2197(goals;)X2456(these)X2683(are,)X2854(to)X2958(teach)X3191(the)X3338(fundamental)X3849(concepts)X4216(in)X576 3351(the)N718(following:)X776 3491(1.)N920(Embedded)X1356(System)X1663(Design)X776 3631(2.)N920(Microprocessor)X1547(Instructon)X1961(Sets)X2145(and)X2308(Programming)X776 3771(3.)N920(Basic)X1158(Computer)X1567(Organization)X576 3911(This)N771(chapter)X1079(will)X1253(serve)X1480(to)X1579(brie\257y)X1854(describe)X2199(what)X2410(is)X2498(involved)X2859(in)X2958(each)X3159(of)X3263(these)X3485(topics.)X3 f576 4135(1.2.)N768(Embedded)X1234(System)X1551(Design)X1 f776 4275(A)N3 f871(microprocessor)X1 f1533(is)X1623(typically)X1987(a)X2056(single)X2313(chip)X2506(embodying)X2966(the)X3111(essence)X3432(of)X3539(a)X3609(computer)X4000(system.)X576 4387(A)N3 f669(microcomputer)X1329(system)X1 f1630(consists)X1958(of)X2062(basically)X2429(three)X2646(components)X3135(as)X3239(illustrated)X3649(in)X3748(Figure)X4023(1.1.)X776 4527(1.)N920(A)X1013(Microprocessor.)X1664(Also)X1869(sometimes)X2305(referred)X2634(to)X2733(as)X2837(a)X2904(Central)X3212(Processing)X3652(Unit)X3847(\(CPU\).)X776 4667(2.)N920(A)X1013(Memory)X1368(unit.)X776 4807(3.)N920(Input/Output)X1441(\(I/O\))X1657(devices.)X576 4947(The)N756(memory)X1107(and)X1276(I/O)X1434(are)X1582(connected)X2003(to)X2108(the)X2256(CPU)X2472(by)X2598(a)X2671(large)X2894(\(e.g.,)X3120(64)X3247(to)X3353(128\))X3560(collection)X3972(of)X4083(wires)X576 5059(which)N839(is)X931(commonly)X1371(called)X1630(a)X3 f1701(Bus)X1 f1855(.)X1931(By)X2071(implementing)X2635(the)X2781(input)X3007(and)X3173(output)X3446(of)X3553(such)X3756(a)X3826(system)X4120(with)X576 5171(devices)N896(such)X1103(as)X1214(switches,)X1600(valves,)X1901(or)X2012(motors,)X2334(one)X2504(can)X2669(then)X2866(create)X3128(software)X3490(which)X3756(the)X3906(micropro-)X576 5283(cessor)N844(then)X1038(executes)X1398(to)X1501(perform)X1839(the)X1984(desired)X2289(functionality)X2809(of)X2916(some)X3146(overall)X3441(system.)X3759(The)X3936(software,)X576 5395(by)N696(the)X838(way,)X1046(is)X1134(stored)X1393(in)X1492(the)X1634(Memory.)X2 p%%Page: 2 312 s 0 xH 0 xS 1 f3 f576 400(57:017)N872(CIE)X1 f2353(-)X2409(2)X2481(-)X3 f3717(Lecture)X4062(Notes)X1 f9 s1440 1613 MXY57 -57 Dl1440 1613 MXY57 57 Dl1785 1671 MXY57 -57 Dl1785 1556 MXY57 57 Dl1469 1584 MXY345 0 Dl1469 1642 MXY345 0 Dl3024 1613 MXY57 -57 Dl3024 1613 MXY57 57 Dl3369 1671 MXY57 -57 Dl3369 1556 MXY57 57 Dl3053 1584 MXY345 0 Dl3053 1642 MXY345 0 Dl893 2074 MXY0 -921 Dl1152 MY547 0 Dl0 921 Dl2074 MY-547 0 Dl1843 2391 MXY0 -1555 Dl1180 0 Dl3024 MX0 1555 Dl-1180 0 Dl893 1613 MXY547 0 Dl3427 2074 MXY0 -921 Dl1152 MY547 0 Dl0 921 Dl2074 MY-547 0 Dl12 s2361 1648(or)N2131 1498(Microprocessor)N2304 1838(CPU)N1037 1884(Output)N1065 1411(Input)N3542 1642(Memory)N9 s1584 1560(Bus)N3197 1555(Bus)N3 f12 s1302 2618(Figure)N1599(1.1.)X1767(Simpli\256ed)X2207(Structure)X2626(of)X2730(a)X2802(Computer)X3247(System.)X1 f776 2778(For)N936(example,)X1314(take)X1502(the)X1647(case)X1840(of)X1947(the)X2092(microwave)X2548(oven.)X2787(Here)X3002(we)X3142(write)X3368(software)X3727(to)X3830(handle)X4115(such)X576 2890(functions)N988(as)X1121(accepting)X1544(control)X1870(commands)X2340(from)X2580(the)X2751(``chef'',)X3122(and)X3314(starting)X3656(or)X3789(stopping)X4173(the)X576 3002(microwave)N1039(generator.)X1462(The)X1647(basic)X1880(structure)X2252(of)X

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -