Integer Arithmetic IP Cores User Guide 2014.08.18 UG-01063 Subscribe SendFeedback ® YoucanuseAltera integermegafunctionIPcorestoperformmathematicaloperationsinyourdesign. Thesefunctionsoffermoreefficientlogicsynthesisanddeviceimplementationthancodingyourown functions.YoucancustomizetheIPcorestoaccommodateyourdesignrequirements. AlteraintegerarithmeticIPcoresaredividedintothefollowingtwocategories: • Libraryofparameterizedmodules(LPM)IPcores • Altera-specific(ALT)IPcores ThefollowingtableliststheintegerarithmeticIPcores. Table1:ListofIPCores IPCoreName FunctionOverview LPM_ADD_SUB(Adder/Subtractor)IPCore Adder/Subtractor LPM_COMPARE(Comparator)IPCore Comparator LPM_COUNTER(Counter)IPCore Counter LPM_DIVIDE(Divider)IPCore Divider LPM_MULT(Multiplier)IPCore Multiplier ALTECC ECCEncoder/Decoder ALTMULT_ADD(Multiply-Adder)IPCore Multiplier-Adder ALTMEMMULT(Memory-basedConstant Memory-basedConstantCoefficientMultiplier CoefficientMultiplier)IPCore ALTMULT_ACCUM(Multiply-Accumulate)IP Multiplier-Accumulator Core ALTMULT_ADD(Multiply-Adder)IPCore Multiplier-Adder ALTMULT_COMPLEX(ComplexMultiplier)IP ComplexMultiplier Core ALTSQRT(IntegerSquareRoot)IPCore IntegerSquare-Root PARALLEL_ADD(ParallelAdder)IPCore ParallelAdder RelatedInformation • IntroductiontoAlteraIPCores ©2014AlteraCorporation.Allrightsreserved.ALTERA,ARRIA,CYCLONE,ENPIRION,MAX,MEGACORE,NIOS,QUARTUSandSTRATIXwords andlogosaretrademarksofAlteraCorporationandregisteredintheU.S.PatentandTrademarkOfficeandinothercountries.Allother words and logos identified as trademarks or service marks are the property of their respective holders as described at ISO www.altera.com/common/legal.html.Alterawarrantsperformanceofitssemiconductorproductstocurrentspecificationsinaccordancewith 9001:2008 Altera'sstandardwarranty,butreservestherighttomakechangestoanyproductsandservicesatanytimewithoutnotice.Alteraassumes Registered noresponsibilityorliabilityarisingoutoftheapplicationoruseofanyinformation,product,orservicedescribedhereinexceptasexpressly agreedtoinwritingbyAltera.Alteracustomersareadvisedtoobtainthelatestversionofdevicespecificationsbeforerelyingonanypublished informationandbeforeplacingordersforproductsorservices. www.altera.com 101InnovationDrive,SanJose,CA95134 UG-01063 2 DesignExampleFiles 2014.08.18 • AlteraIPReleaseNotes Design Example Files ® AlteraprovidesdesignexamplefilesthataresimulatedintheModelSim -Alterasoftwaretogeneratea waveformdisplayofthedevicebehavior. YoushouldbefamiliarwiththeModelSim-Alterasoftwarebeforeusingthedesignexamples.Togetstarted withtheModelSim-Alterasoftware,refertotheModelSim-AlteraSoftwareSupportpageontheAltera website.Thesupportpageincludeslinkstosuchtopicsasinstallation,usage,andtroubleshooting.Formore detailsaboutthedesignexampleforaspecificIPcore,refertothe“DesignExample”sectionforthatIPcore. DesignexamplesareprovidedonlyforsomeIPcoresinthisuserguide. Installing and Licensing IP Cores TheAlteraIPLibraryprovidesmanyusefulIPcorefunctionsforproductionusewithoutpurchasingan additionallicense. YoucanevaluateanyAlteraIPcoreinsimulationandcompilationintheQuartusII ® softwareusingtheOpenCoreevaluationfeature.SomeAlteraIPcores,suchasMegaCore functions,require thatyoupurchaseaseparatelicenseforproductionuse.YoucanusetheOpenCorePlusfeaturetoevaluate IPthatrequirespurchaseofanadditionallicenseuntilyouaresatisfiedwiththefunctionalityandperformance. Afteryoupurchasealicense,visittheSelfServiceLicensingCentertoobtainalicensenumberforanyAltera product. Figure1:IPCoreInstallationPath acds quartus-ContainstheQuartusIIsoftware ip-ContainstheAlteraIPLibraryandthird-partyIPcores altera-ContainstheAlteraIPLibrarysourcecode <IPcorename>-ContainstheIPcoresourcefiles Note: ThedefaultIPinstallationdirectoryonWindowsis<drive>:\altera\<versionnumber>;onLinuxit is<homedirectory>/altera/<versionnumber>. RelatedInformation • AlteraLicensingSite • AlteraSoftwareInstallationandLicensingManual Customizing and Generating IP Cores YoucancustomizeIPcorestosupportawidevarietyofapplications.TheQuartusIIIPCatalogandparameter editorallowyoutoquicklyselectandconfigureIPcoreports,features,andoutputfiles. AlteraCorporation IntegerArithmeticIPCoresUserGuide SendFeedback UG-01063 IPCatalogandParameterEditor(replacesMegaWizardPlug-InManager) 3 2014.08.18 IP Catalog and Parameter Editor (replaces MegaWizard Plug-In Manager) TheQuartusIIIPCatalog(Tools>IPCatalog)andparametereditorhelpyoueasilycustomizeandintegrate IPcoresintoyourproject.YoucanusetheIPCatalogandparametereditortoselect,customize,andgenerate filesrepresentingyourcustomIPvariation. ™ Note: TheIPCatalog(Tools>IPCartalog)andparametereditorreplacetheMegaWizard Plug-In ManagerforIPselectionandparameterization,beginninginQuartusIIsoftwareversion14.0.Use theIPCatalogandparametereditortolocateandparamaterizeAlteraIPcores. TheIPCataloglistsIPcoresavailableforyourdesign.Double-clickanyIPcoretolaunchtheparameter editorandgeneratefilesrepresentingyourIPvariation.TheparametereditorpromptsyoutospecifyanIP variationname,optionalports,andoutputfilegenerationoptions.Theparametereditorgeneratesatop- levelQsyssystemfile(.qsys)orQuartusIIIPfile(.qip)representingtheIPcoreinyourproject.Youcan alsoparameterizeanIPvariationwithoutanopenproject. UsethefollowingfeaturestohelpyouquicklylocateandselectanIPcore: • FilterIPCatalogtoShowIPforactivedevicefamilyorShowIPforalldevicefamilies. • SearchtolocateanyfullorpartialIPcorenameinIPCatalog.ClickSearchforPartnerIP,toaccess partnerIPinformationontheAlterawebsite. • Right-clickanIPcorenameinIPCatalogtodisplaydetailsaboutsupporteddevices,opentheIPcore's installationfolder,andorviewlinkstodocumentation. Figure2:QuartusIIIPCatalog SearchandfilterIPforyourtargetdevice Double-clicktocustomize,right-clickforinformation Note: TheIPCatalogisalsoavailableinQsys(View>IPCatalog).TheQsysIPCatalogincludesexclusive systeminterconnect,videoandimageprocessing,andothersystem-levelIPthatarenotavailablein IntegerArithmeticIPCoresUserGuide AlteraCorporation SendFeedback UG-01063 4 UsingtheParameterEditor 2014.08.18 theQuartusIIIPCatalog.FormoreinformationaboutusingtheQsysIPCatalog,refertoCreating aSystemwithQsysintheQuartusIIHandbook. RelatedInformation • CreatingaSystemwithQsys Using the Parameter Editor TheparametereditorhelpsyoutoconfigureIPcoreports,parameters,andoutputfilegenerationoptions. • Usepresetsettingsintheparametereditor(whereprovided)toinstantlyapplypresetparametervalues forspecificapplications. • Viewportandparameterdescriptions,andlinkstodocumentation. • Generatetestbenchsystemsorexampledesigns(whereprovided). Figure3:IPParameterEditors ViewIPport andparameter details Legacyparameter editors SpecifyyourIPvariationname Applypresetparametersfor andtargetdevice specificapplications Specifying IP Core Parameters and Options TheparametereditorGUIallowsyoutoquicklyconfigureyourcustomIPvariation.Usethefollowingsteps tospecifyIPcoreoptionsandparametersintheQuartusIIsoftware. RefertoSpecifyingIPCoreParameters andOptions(LegacyParameterEditors)forconfigurationofIPcoresusingthelegacyparametereditor. 1. IntheIPCatalog(Tools>IPCatalog),locateanddouble-clickthenameoftheIPcoretocustomize. Theparametereditorappears. 2. Specifyatop-levelnameforyourcustomIPvariation.TheparametereditorsavestheIPvariationsettings inafilenamed<your_ip>.qsys.ClickOK. 3. SpecifytheparametersandoptionsforyourIPvariationintheparametereditor,includingoneormore ofthefollowing.RefertoyourIPcoreuserguideforinformationaboutspecificIPcoreparameters. AlteraCorporation IntegerArithmeticIPCoresUserGuide SendFeedback UG-01063 FilesGeneratedforAlteraIPCores 5 2014.08.18 • OptionallyselectpresetparametervaluesifprovidedforyourIPcore.Presetsspecifyinitialparameter valuesforspecificapplications. • SpecifyparametersdefiningtheIPcorefunctionality,portconfigurations,anddevice-specificfeatures. • SpecifyoptionsforprocessingtheIPcorefilesinotherEDAtools. 4. ClickGenerateHDL,theGenerationdialogboxappears. 5. Specifyoutputfilegenerationoptions,andthenclickGenerate.TheIPvariationfilesgenerateaccording toyourspecifications. 6. Togenerateasimulationtestbench,clickGenerate>GenerateTestbenchSystem. 7. TogenerateanHDLinstantiationtemplatethatyoucancopyandpasteintoyourtexteditor,click Generate>HDLExample. 8. ClickFinish.Theparametereditoraddsthetop-level.qsysfiletothecurrentprojectautomatically.If youarepromptedtomanuallyaddthe.qsysfiletotheproject,clickProject>Add/RemoveFilesin Projecttoaddthefile. 9. AftergeneratingandinstantiatingyourIPvariation,makeappropriatepinassignmentstoconnectports. Figure4:IPParameterEditor ViewIPport andparameter details SpecifyyourIPvariationname Applypresetparametersfor andtargetdevice specificapplications Files Generated for Altera IP Cores TheQuartusIIsoftwareversion14.0a10andlatergeneratesthefollowingIPcoreoutputfilestructurewhen targetingArria10devices. IntegerArithmeticIPCoresUserGuide AlteraCorporation SendFeedback UG-01063 6 FilesGeneratedforAlteraIPCores 2014.08.18 Figure5:IPCoreGeneratedFiles <projectdirectory> <your_ip>.qsys-SystemorIPintegrationfile <your_ip>.sopcinfo-Softwaretool-chainintegrationfile <your_ip> <your_ip>n <testbench>_tb IPvariationfiles IPvariationfiles testbenchsystem <your_ip>_tb.qsys <your_ip>.cmp-VHDLcomponentdeclarationfile Testbenchsystemfile <your_ip>_bb.v-VerilogHDLblackboxEDAsynthesisfile <your_ip>_inst.vor.vhd-Sampleinstantiationtemplate <testbench>_tb <your_ip>.ppf-XMLI/Opininformationfile testbenchfiles <your_ip>.qip-ListsIPsynthesisfiles <your_testbench>_tb.csv <your_ip>.sip-Listsfilesforsimulation <your_testbench>_tb.spd <your_ip>_generation.rpt-IPgenerationreport <your_ip>.debuginfo-Containspost-generationinformation sim <your_ip>.html-Connectionandmemorymapdata simulationfiles <your_ip>.bsf-Blocksymbolschematic <your_ip>.spd-Combinesindividualsimulationscripts <EDAtoolsetup scripts> sim synth <ipsubcores>n Subcorelibraries Simulationfiles IPsynthesisfiles <your_ip>.vor.vhd <your_ip>.vor.vhd Top-levelsimulationfile Top-levelIPsynthesisfile synth sim <EDAtoolname> Subcore Subcore Simulatorscripts synthesisfiles Simulationfiles <HDLfiles> <HDLfiles> <simulator_setup_scripts> Table2:IPCoreGeneratedFiles(version14.0a10) FileName Description <my_ip>.qsys TheQsyssystemortop-levelIPvariationfile.<my_ip>isthenamethat yougiveyourIPvariation. <system>.sopcinfo DescribestheconnectionsandIPcomponentparameterizationsinyour Qsyssystem.Youcanparseitscontentstogetrequirementswhenyou developsoftwaredriversforIPcomponents. DownstreamtoolssuchastheNiosIItoolchainusethisfile.The .sopcinfofileandthesystem.hfilegeneratedfortheNiosIItoolchain includeaddressmapinformationforeachslaverelativetoeachmaster thataccessestheslave.Differentmastersmayhaveadifferentaddress maptoaccessaparticularslavecomponent. AlteraCorporation IntegerArithmeticIPCoresUserGuide SendFeedback UG-01063 FilesGeneratedforAlteraIPCores 7 2014.08.18 FileName Description <my_ip>.cmp TheVHDLComponentDeclaration(.cmp)fileisatextfilethatcontains localgenericandportdefinitionsthatyoucanuseinVHDLdesign files. <my_ip>.html Areportthatcontainsconnectioninformation,amemorymapshowing theaddressofeachslavewithrespecttoeachmastertowhichitis connected,andparameterassignments. <my_ip>_generation.rpt IPorQsysgenerationlogfile.AsummaryofthemessagesduringIP generation. <my_ip>.debuginfo Containspost-generationinformation.UsedtopassSystemConsole andBusAnalyzerToolkitinformationabouttheQsysinterconnect. TheBusAnalysisToolkitusesthisfiletoidentifydebugcomponents intheQsysinterconnect. <my_ip>.qip ContainsalltherequiredinformationabouttheIPcomponentto integrateandcompiletheIPcomponentintheQuartusIIsoftware. <my_ip>.csv ContainsinformationabouttheupgradestatusoftheIPcomponent. <my_ip>.bsf ABlockSymbolFile(.bsf)representationoftheIPvariationforusein QuartusIIBlockDiagramFiles(.bdf). <my_ip>.spd Requiredinputfileforip-make-simscripttogeneratesimulation scriptsforsupportedsimulators.The.spdfilecontainsalistoffiles generatedforsimulation,alongwithinformationaboutmemoriesthat youcaninitialize. <my_ip>.ppf ThePinPlannerFile(.ppf)storestheportandnodeassignmentsfor IPcomponentscreatedforusewiththePinPlanner. <my_ip>_bb.v YoucanusetheVerilogblack-box(_bb.v)fileasanemptymodule declarationforuseasablackbox. <my_ip>.sip ContainsinformationrequiredforNativeLinksimulationofIP components.Youmustaddthe.sipfiletoyourQuartusIIproject. <my_ip>_inst.vor_inst.vhd HDLexampleinstantiationtemplate.Youcancopyandpastethe contentsofthisfileintoyourHDLfiletoinstantiatetheIPvariation. <my_ip>.regmap IfIPcontainsregisterinformation,.regmapfilegenerates.The.regmap filedescribestheregistermapinformationofmasterandslaveinterfaces. Thisfilecomplementsthe.sopcinfofilebyprovidingmoredetailed registerinformationaboutthesystem.Thisenablesregisterdisplay viewsandusercustomizablestatisticsintheSystemConsole. <my_ip>.svd AllowsHPSSystemDebugtoolstoviewtheregistermapsofperipherals connectedtoHPSwithinaQsyssystem. Duringsynthesis,the.svdfilesforslaveinterfacesvisibletoSystem Consolemastersarestoredinthe.soffileinthedebugsection.System Consolereadsthissection,whichQsyscanqueryforregistermap information.Forsystemslaves,Qsyscanaccesstheregistersbyname. IntegerArithmeticIPCoresUserGuide AlteraCorporation SendFeedback UG-01063 8 SpecifyingIPCoreParametersandOptions(LegacyParameterEditors) 2014.08.18 FileName Description <my_ip>.v HDLfilesthatinstantiateeachsubmoduleorchildIPcoreforsynthesis orsimulation. or <my_ip>.vhd mentor/ ContainsaModelSim®scriptmsim_setup.tcltosetupandruna simulation. aldec/ ContainsaRiviera-PROscriptrivierapro_setup.tcltosetupandruna simulation. /synopsys/vcs Containsashellscriptvcs_setup.shtosetupandrunaVCS®simulation. /synopsys/vcsmx Containsashellscriptvcsmx_setup.shandsynopsys_sim.setupfileto setupandrunaVCSMX®simulation. /cadence Containsashellscriptncsim_setup.shandothersetupfilestosetupand runanNCSIMsimulation. /submodules ContainsHDLfilesfortheIPcoresubmodule. <childIPcores>/ ForeachgeneratedchildIPcoredirectory,Qsysgenerates/synthand /simsub-directories. Specifying IP Core Parameters and Options (Legacy Parameter Editors) TheQuartusIIsoftwareversion14.0andprevioususesalegacyversionoftheparametereditorforIPcore configurationandgeneration.UsethefollowingstepstoconfigureandgenerateanIPvariationusinga legacyparametereditor. AlteraCorporation IntegerArithmeticIPCoresUserGuide SendFeedback UG-01063 FilesGeneratedforAlteraIPCores(version14.0andprevious) 9 2014.08.18 Note: Thelegacyparametereditorgeneratesadifferentoutputfilestructurethanthelatestparameter editor.RefertoSpecifyingIPCoreParametersandOptionsforconfigurationofIPcoresintheQuartus IIsoftwareversion14.0a10andlater. Figure6:LegacyParameterEditors Legacyparameter editors 1. IntheIPCatalog(Tools>IPCatalog),locateanddouble-clickthenameoftheIPcoretocustomize. Theparametereditorappears. 2. Specifyatop-levelnameandoutputHDLfiletypeforyourIPvariation.ThisnameidentifiestheIPcore variationfilesinyourproject.ClickOK. 3. SpecifytheparametersandoptionsforyourIPvariationintheparametereditor.RefertoyourIPcore userguideforinformationaboutspecificIPcoreparameters. 4. ClickFinishorGenerate(dependingontheparametereditorversion).Theparametereditorgenerates thefilesforyourIPvariationaccordingtoyourspecifications.ClickExitifpromptedwhengeneration iscomplete.Theparametereditoraddsthetop-level.qipfiletothecurrentprojectautomatically. Note: TomanuallyaddanIPvariationgeneratedwithlegacyparametereditortoaproject,clickProject> Add/RemoveFilesinProjectandaddtheIPvariation.qipfile. Files Generated for Altera IP Cores (version 14.0 and previous) TheQuartusIIversion14.0andearliersoftwaregeneratesthefollowingoutputforyourIPcore. IntegerArithmeticIPCoresUserGuide AlteraCorporation SendFeedback UG-01063 10 UpgradingIPCores 2014.08.18 Figure7:IPCoreGeneratedFiles <ProjectDirectory> <your_ip>.qip-QuartusIIIPintegrationfile <your_ip>.vor.vhd-Top-levelIPsynthesisfile <your_ip>_bb.v-VerilogHDLblackboxEDAsynthesisfile <your_ip>.bsf-Blocksymbolschematicfile <your_ip>_syn.vor.vhd-Timingandresourceestimationnetlist1 <your_ip>.voor.vho-IPfunctionalsimulationmodel2 <your_ip>_inst.vor.vhd-Sampleinstantiationtemplate <your_ip>.cmp-VHDLcomponentdeclarationfile greybox_tmp3 Notes: 1.IfsupportedandenabledforyourIPvariation 2.Iffunctionalsimulationmodelsaregenerated 3.Ignorethisdirectory Upgrading IP Cores IPcorevariantsgeneratedwithapreviousversionoftheQuartusIIsoftwaremayrequireupgradingbefore useinthecurrentversionoftheQuartusIIsoftware.ClickProject>UpgradeIPComponentstoidentify andupgradeIPcorevariants. TheUpgradeIPComponentsdialogboxprovidesinstructionswhenIPupgradeisrequired,optional,or unsupportedforspecificIPcoresinyourdesign.YoumustupgradeIPcoresthatrequireitbeforeyoucan compiletheIPvariationinthecurrentversionoftheQuartusIIsoftware.ManyAlteraIPcoressupport automaticupgrade. Theupgradeprocessrenamesandpreservestheexistingvariationfile(.v,.sv,or.vhd)as<my_variant>_ BAK.v,.sv,.vhdintheprojectdirectory. Table3:IPCoreUpgradeStatus IPCoreStatus CorrectiveAction RequiredUpgradeIP YoumustupgradetheIPvariationbeforecompilinginthecurrentversionof Components theQuartusIIsoftware. OptionalUpgradeIP UpgradeisoptionalforthisIPvariationinthecurrentversionoftheQuartusII Components software.YoucanupgradethisIPvariationtotakeadvantageofthelatest developmentofthisIPcore.AlternativelyyoucanretainpreviousIPcore characteristicsbydecliningtoupgrade. UpgradeUnsupported UpgradeoftheIPvariationisnotsupportedinthecurrentversionoftheQuartus IIsoftwareduetoIPcoreendoflifeorincompatabilitywiththecurrentversion oftheQuartusIIsoftware.YouarepromptedtoreplacetheobsoleteIPcorewith acurrentequivalentIPcorefromtheIPCatalog. AlteraCorporation IntegerArithmeticIPCoresUserGuide SendFeedback
Description: