📄 chap.3.assemblylang.ps
字号:
%!PS-Adobe-1.0%%Creator: hitchcock:tomc (Tom Casavant)%%Title: stdin (ditroff)%%CreationDate: Thu Oct 27 08:56:55 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 915(1.)N696(NULL)X576 1139(2.)N696(NULL)X576 1363(3.)N696(NULL)X19 p%%Page: 19 212 s 0 xH 0 xS 3 f1 f2329 400(-)N2385(19)X2505(-)X3 f16 s2158 1091(Chapter)N2645(3)X1107 1259(M)N1228(68000)X1580(Instruction)X2225(Set)X2428(and)X2666(Basic)X2990(Program)X3481(m)X3588(ing)X12 s576 1483(3.1.)N768(Introduction)X1 f776 1623(In)N881(this)X1045(chapter)X1354(we)X1492(begin)X1732(to)X1833(``peel)X2084(the)X2228(onion.'')X2585(This)X2782(``onion'')X3155(consists)X3485(of)X3591(the)X3735(different)X4093(com-)X576 1735(ponents)N904(of)X1013(an)X1133(embedded)X1558(computer)X1951(system.)X2271(We)X2434(begin)X2677(by)X2802(describing)X3232(some)X3464(very)X3663(simple)X3948(elements)X576 1847(of)N689(the)X840(toolkit)X1126(of)X1240(the)X1392(programmer)X1902(of)X2016(a)X2093(microprocessor.)X2744(The)X2928(goal)X3128(is)X3226(to)X3335(remove)X3658(any)X3831(abstractions)X576 1959(and)N750(allow)X999(understanding)X1579(of)X1694(the)X1847(machine)X2209(``at)X2378(it's)X2536(own)X2736(level.'')X3071(As)X3211(we)X3357(attempt)X3681(to)X3790(do)X3920(more)X4152(and)X576 2071(more)N798(complex)X1154(things)X1413(with)X1608(a)X1675(microprocessor)X2292(and)X2455(various)X2762(I/O)X2914(devices,)X3251(we)X3387(will)X3562(need)X3769(to)X3869(understand)X576 2183(more)N805(and)X975(more)X1203(of)X1313(the)X1461(sophisticated)X1994(aspects)X2302(of)X2412(a)X2485(system.)X2806(Until)X3034(then,)X3254(however,)X3639(we)X3781(will)X3961(just)X4130(peel)X576 2295(one)N739(layer)X956(of)X1060(the)X1202(``onion'')X1573(at)X1667(a)X1734(time.)X3 f576 2519(3.2.)N768(The)X952(Basic)X1195(Programmer's)X1823(Model)X1 f776 2659(The)N950(basic)X1172(programmer's)X1741(model)X2006(consists)X2334(of)X2438(the)X2580(components)X3069(shown)X3343(in)X3442(Figure)X3717(3.1.)X10 s2256 3869 MXY161 -161 Dl2256 3869 MXY161 161 Dl2969 4031 MXY161 -161 Dl2969 3707 MXY161 161 Dl2353 3772 MXY680 0 Dl2353 3966 MXY680 0 Dl2516 3901(MEM)N2727(BUS)X1057 2930 MXY226 0 Dl1226 2944 MXY57 -14 Dl1226 2915 MXY57 14 Dl928 2930 MXY-259 0 Dl726 2915 MXY-57 14 Dl726 2944 MXY-57 -14 Dl960 2962(32)N1932 3480 MXY226 0 Dl2101 3495 MXY57 -14 Dl2101 3466 MXY57 14 Dl1802 MX-259 0 Dl1601 3466 MXY-57 14 Dl1601 3495 MXY-57 -14 Dl1835 3512(32)N668 3253 MXY615 0 Dl668 3901 MXY615 0 Dl668 3772 MXY615 0 Dl668 3642 MXY615 0 Dl668 3513 MXY615 0 Dl668 3383 MXY615 0 Dl668 3124 MXY615 0 Dl671 4030 MXY0 -1036 Dl616 0 Dl0 1036 Dl-616 0 Dl602 4940 MXY0 -2136 Dl1653 0 Dl0 2136 Dl-1653 0 Dl3130 4681 MXY0 -1589 Dl1134 0 Dl4265 MX0 1589 Dl-1134 0 Dl1512 3385 MXY0 -126 Dl645 0 Dl0 126 Dl-645 0 Dl1641 2994 MXY0 129 Dl1770 2994 MXY0 129 Dl1900 2994 MXY0 129 Dl2029 2994 MXY0 129 Dl1512 3126 MXY0 -126 Dl2999 MY645 0 Dl0 126 Dl3126 MY-645 0 Dl733 3241(D1)N733 3357(D2)N733 3091(D0)N733 4005(D7)N733 3856(D6)N733 3739(D5)N733 3590(D4)N733 3474(D3)N12 s3520 3574(MEMORY)N16 s733 4640(M)N847(68000/CIE)X1441(m)X1541(icroprocessor)X10 s1705 2971(CCR)N1738 3221(PC)N12 s1543 3088(X)N1673 3091(N)N1802(Z)X1932(V)X2062(C)X18 s1187 4799(\(CPU)N(\))S3 f12 s1362 5167(Figure)N1659(3.1.)X1827(Simpli\256ed)X2267(M68000)X2622(Programmers)X3218(Model.)X1 f576 5327(The)N766(CPU)X992(executes)X1364(instructions)X1853(that)X2038(operate)X2362(upon)X2594(data)X2795(stored)X3070(in)X3185(the)X3343(Memory.)X3738(All)X3902(data)X4104(must)X576 5439(travel)N820(the)X962(path)X1152(from)X1363(memory)X1708(to)X1807(the)X1949(CPU)X2159(to)X2258(be)X2373(operated)X2729(upon,)X2969(and)X3132(then)X3322(make)X3555(the)X3697(return)X3951(trip)X4109(back)X576 5551(to)N675(memory)X1021(to)X1121(be)X1237(stored)X1497(until)X1699(needed)X1997(for)X2134(future)X2389(operations.)X2863(Not)X3032(only)X3228(does)X3429(the)X3572(memory)X3918(store)X4130(data)X576 5663(between)N932(operations,)X1392(but)X1550(the)X1703(memory)X2058(also)X2247(contains)X2602(the)X2 f2754(instructions)X1 f3242(themselves)X3704(which)X3973(get)X4125(exe-)X576 5775(cuted)N827(by)X965(the)X1125(CPU.)X1377(This)X1590(aspect)X1874(is)X1981(what)X2211(we)X2366(referred)X2714(to)X2832(in)X2950(Chapter)X3298(1)X3389(as)X3512(the)X2 f3673(stored)X3956(program)X20 p%%Page: 20 312 s 0 xH 0 xS 2 f1 f3 f576 400(57:017)N872(CIE)X1 f2329(-)X2385(20)X2505(-)X3 f3717(Lecture)X4062(Notes)X1 f576 803(concept.)N776 943(While)N1047(in)X1158(the)X1312(CPU,)X1558(data)X1755(need)X1973(a)X2052(place)X2292(to)X2403(be)X2530(stored.)X2825(The)X3011(name)X3256(we)X3404(use)X3568(for)X3716(these)X3950(places)X4227(is)X3 f576 1055(registers)N1 f929(.)X1001(In)X1105(our)X1257(model)X1522(of)X1626(the)X1768(M68000,)X2141(there)X2358(are)X2500(3)X2572(types)X2799(of)X2903(registers.)X776 1195(1.)N920(First)X1123(are)X1268(a)X1338(set)X1472(of)X3 f1579(data)X1787(registers)X1 f2140(.)X2191(These)X2448(have)X2657(very)X2855(speci\256c)X3176(names:)X3476(D0,)X3644(D1,)X3812(D2,)X3981(D3,)X4150(D4,)X920 1307(D5,)N1086(D6,)X1252(D7.)X1418(There)X1668(are)X1811(exactly)X2115(eight)X2333(of)X2438(them.)X2680(They)X2903(are)X3046(used)X3247(to)X3347(hold)X3543(copies)X3814(of)X3919(data)X4104(from)X920 1419(the)N1062(memory.)X1432(It)X1516(is)X1605(these)X1828(copies)X2099(that)X2269(may)X2460(be)X2576(operated)X2933(upon)X3150(by)X3271(the)X3414(instructions.)X3912(Each)X4130(data)X920 1531(register)N1233(is)X1321(32-bits)X1612(in)X1711(length.)X776 1671(2.)N920(Because)X1283(instructions)X1774(must)X2003(be)X2136(stored)X2413(in)X2530(memory,)X2917(the)X3077(CPU)X3306(must)X3536(have)X3761(some)X4007(idea)X4211(of)X920 1783(where)N1192(the)X1347(next)X1550(instruction)X1999(\(to)X2143(execute\))X2507(is.)X2632(This)X2840(``address'')X3292(is)X3392(stored)X3663(in)X3774(the)X3 f3928(program)X920 1895(counter)N1 f1268(register)X1590(\(PC\).)X1828(The)X2011(PC)X2161(is)X2258(32)X2387(bits)X2559(in)X2667(length.)X2965(Normally,)X3392(the)X3544(program)X3904(counter)X4227(is)X920 2007(incremented)N1429(by)X1557(one)X1728(after)X1937(each)X2146(instruction.)X2614(I.e.,)X2792(the)X2941(next)X3138(instruction)X3581(to)X3687(execute)X4013(usually)X920 2119(immediately)N1456(follows)X1797(the)X1968(current)X2295(one)X2488(being)X2756(executed.)X3177(This)X3402(is)X3520(what)X3761(is)X3879(commonly)X920 2231(referred)N1272(to)X1394(as)X2 f1521(sequential)X1 f1964(instruction)X2423(execution.)X2869(We)X3050(will)X3247(discuss)X3570(ways)X3813(to)X3934(alter)X4152(this)X920 2343(sequential)N1335(behavior)X1696(later.)X776 2483(3.)N920(The)X1100(third)X1313(class)X1531(of)X1642(register)X1962(is)X2057(one)X2227(which)X2493(saves)X2732(information)X3218(about)X3463(``special'')X3890(conditions)X920 2595(that)N1090(may)X1281(arise)X1488(during)X1764(the)X1907(execution)X2307(of)X2412(an)X2528(instruction.)X2989(In)X3094(the)X3236(M68000,)X3609(we)X3745(call)X3909(this)X4072(regis-)X920 2707(ter)N1051(the)X3 f1198(condition)X1611(code)X1827(register)X1 f2173(\(CCR\),)X2483(and)X2652(it)X2736(consists)X3070(of)X3180(5)X3258(bits,)X
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -