mirror of
				https://github.com/FreeRTOS/FreeRTOS-Kernel.git
				synced 2025-10-24 21:57:46 -04:00 
			
		
		
		
	Add a starting point for a Freedom Studio Risc V project.
This commit is contained in:
		
							parent
							
								
									db64297487
								
							
						
					
					
						commit
						f7102f2342
					
				
					 58 changed files with 6836 additions and 0 deletions
				
			
		
							
								
								
									
										215
									
								
								FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/.cproject
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										215
									
								
								FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/.cproject
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,215 @@ | ||||||
|  | <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||||
|  | <?fileVersion 4.0.0?><cproject storage_type_id="org.eclipse.cdt.core.XmlProjectDescriptionStorage"> | ||||||
|  | 	<storageModule moduleId="org.eclipse.cdt.core.settings"> | ||||||
|  | 		<cconfiguration id="ilg.gnumcueclipse.managedbuild.cross.riscv.config.elf.debug.516870870"> | ||||||
|  | 			<storageModule buildSystemId="org.eclipse.cdt.managedbuilder.core.configurationDataProvider" id="ilg.gnumcueclipse.managedbuild.cross.riscv.config.elf.debug.516870870" moduleId="org.eclipse.cdt.core.settings" name="Debug"> | ||||||
|  | 				<externalSettings/> | ||||||
|  | 				<extensions> | ||||||
|  | 					<extension id="org.eclipse.cdt.core.ELF" point="org.eclipse.cdt.core.BinaryParser"/> | ||||||
|  | 					<extension id="org.eclipse.cdt.core.GASErrorParser" point="org.eclipse.cdt.core.ErrorParser"/> | ||||||
|  | 					<extension id="org.eclipse.cdt.core.GmakeErrorParser" point="org.eclipse.cdt.core.ErrorParser"/> | ||||||
|  | 					<extension id="org.eclipse.cdt.core.GLDErrorParser" point="org.eclipse.cdt.core.ErrorParser"/> | ||||||
|  | 					<extension id="org.eclipse.cdt.core.CWDLocator" point="org.eclipse.cdt.core.ErrorParser"/> | ||||||
|  | 					<extension id="org.eclipse.cdt.core.GCCErrorParser" point="org.eclipse.cdt.core.ErrorParser"/> | ||||||
|  | 				</extensions> | ||||||
|  | 			</storageModule> | ||||||
|  | 			<storageModule moduleId="cdtBuildSystem" version="4.0.0"> | ||||||
|  | 				<configuration artifactName="${ProjName}" buildArtefactType="org.eclipse.cdt.build.core.buildArtefactType.exe" buildProperties="org.eclipse.cdt.build.core.buildArtefactType=org.eclipse.cdt.build.core.buildArtefactType.exe,org.eclipse.cdt.build.core.buildType=org.eclipse.cdt.build.core.buildType.debug" cleanCommand="${cross_rm} -rf" description="" id="ilg.gnumcueclipse.managedbuild.cross.riscv.config.elf.debug.516870870" name="Debug" parent="ilg.gnumcueclipse.managedbuild.cross.riscv.config.elf.debug"> | ||||||
|  | 					<folderInfo id="ilg.gnumcueclipse.managedbuild.cross.riscv.config.elf.debug.516870870." name="/" resourcePath=""> | ||||||
|  | 						<toolChain id="ilg.gnumcueclipse.managedbuild.cross.riscv.toolchain.elf.debug.108811797" name="RISC-V Cross GCC" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.toolchain.elf.debug"> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.addtools.createflash.8320194" name="Create flash image" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.addtools.createflash" useByScannerDiscovery="false" value="true" valueType="boolean"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.addtools.createlisting.379436257" name="Create extended listing" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.addtools.createlisting" useByScannerDiscovery="false"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.addtools.printsize.1043841176" name="Print size" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.addtools.printsize" useByScannerDiscovery="false" value="true" valueType="boolean"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.optimization.level.383399415" name="Optimization Level" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.optimization.level" useByScannerDiscovery="true" value="ilg.gnumcueclipse.managedbuild.cross.riscv.option.optimization.level.more" valueType="enumerated"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.optimization.messagelength.178339006" name="Message length (-fmessage-length=0)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.optimization.messagelength" useByScannerDiscovery="true" value="false" valueType="boolean"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.optimization.signedchar.119459497" name="'char' is signed (-fsigned-char)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.optimization.signedchar" useByScannerDiscovery="true" value="false" valueType="boolean"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.optimization.functionsections.735578493" name="Function sections (-ffunction-sections)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.optimization.functionsections" useByScannerDiscovery="true" value="false" valueType="boolean"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.optimization.datasections.663648478" name="Data sections (-fdata-sections)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.optimization.datasections" useByScannerDiscovery="true" value="false" valueType="boolean"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.debugging.level.33211902" name="Debug level" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.debugging.level" useByScannerDiscovery="true" value="ilg.gnumcueclipse.managedbuild.cross.riscv.option.debugging.level.max" valueType="enumerated"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.debugging.format.1212459035" name="Debug format" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.debugging.format" useByScannerDiscovery="true"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.toolchain.name.2118228106" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.toolchain.name" useByScannerDiscovery="false" value="RISC-V GCC/Newlib" valueType="string"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.prefix.1953815021" name="Prefix" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.prefix" useByScannerDiscovery="false" value="riscv64-unknown-elf-" valueType="string"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.c.739203741" name="C compiler" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.c" useByScannerDiscovery="false" value="gcc" valueType="string"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.cpp.1844392607" name="C++ compiler" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.cpp" useByScannerDiscovery="false" value="g++" valueType="string"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.ar.2006331761" name="Archiver" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.ar" useByScannerDiscovery="false" value="ar" valueType="string"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.objcopy.953275776" name="Hex/Bin converter" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.objcopy" useByScannerDiscovery="false" value="objcopy" valueType="string"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.objdump.1629820216" name="Listing generator" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.objdump" useByScannerDiscovery="false" value="objdump" valueType="string"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.size.1139290195" name="Size command" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.size" useByScannerDiscovery="false" value="size" valueType="string"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.make.598152082" name="Build command" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.make" useByScannerDiscovery="false" value="make" valueType="string"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.rm.1903820766" name="Remove command" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.rm" useByScannerDiscovery="false" value="rm" valueType="string"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.target.isa.base.274413758" name="Architecture" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.target.isa.base" useByScannerDiscovery="false" value="ilg.gnumcueclipse.managedbuild.cross.riscv.option.target.arch.rv32i" valueType="enumerated"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.target.isa.multiply.1227968882" name="Multiply extension (RVM)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.target.isa.multiply" useByScannerDiscovery="false" value="true" valueType="boolean"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.target.isa.atomic.25268933" name="Atomic extension (RVA)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.target.isa.atomic" useByScannerDiscovery="false" value="true" valueType="boolean"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.target.isa.compressed.148707865" name="Compressed extension (RVC)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.target.isa.compressed" useByScannerDiscovery="false" value="true" valueType="boolean"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.target.abi.integer.2137340048" name="Integer ABI" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.target.abi.integer" useByScannerDiscovery="false" value="ilg.gnumcueclipse.managedbuild.cross.riscv.option.abi.integer.ilp32" valueType="enumerated"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.target.codemodel.93793405" name="Code model" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.target.codemodel" useByScannerDiscovery="false" value="ilg.gnumcueclipse.managedbuild.cross.riscv.option.target.codemodel.any" valueType="enumerated"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.toolchain.id.1107449554" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.toolchain.id" useByScannerDiscovery="false" value="-2032619395" valueType="string"/> | ||||||
|  | 							<targetPlatform archList="all" binaryParser="org.eclipse.cdt.core.ELF" id="ilg.gnumcueclipse.managedbuild.cross.riscv.targetPlatform.1301923652" isAbstract="false" osList="all" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.targetPlatform"/> | ||||||
|  | 							<builder buildPath="${workspace_loc:/RTOSDemo}/Debug" id="ilg.gnumcueclipse.managedbuild.cross.riscv.builder.1496635672" keepEnvironmentInBuildfile="false" managedBuildOn="true" name="Gnu Make Builder" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.builder"/> | ||||||
|  | 							<tool id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.assembler.1472778604" name="GNU RISC-V Cross Assembler" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.assembler"> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.assembler.usepreprocessor.874608690" name="Use preprocessor" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.assembler.usepreprocessor" useByScannerDiscovery="false" value="true" valueType="boolean"/> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.assembler.include.paths.545620458" name="Include paths (-I)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.assembler.include.paths" useByScannerDiscovery="true" valueType="includePath"> | ||||||
|  | 									<listOptionValue builtIn="false" value="../../../../bsp/env"/> | ||||||
|  | 									<listOptionValue builtIn="false" value="../../../../bsp/include"/> | ||||||
|  | 									<listOptionValue builtIn="false" value="../../../../bsp/env/freedom-e300-hifive1"/> | ||||||
|  | 									<listOptionValue builtIn="false" value="../../../../bsp/drivers"/> | ||||||
|  | 								</option> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.assembler.other.855588508" name="Other assembler flags" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.assembler.other" useByScannerDiscovery="false" value="-c" valueType="string"/> | ||||||
|  | 								<inputType id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.assembler.input.1208356864" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.assembler.input"/> | ||||||
|  | 							</tool> | ||||||
|  | 							<tool id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.c.compiler.1632260763" name="GNU RISC-V Cross C Compiler" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.c.compiler"> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.c.compiler.include.paths.1464742435" name="Include paths (-I)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.c.compiler.include.paths" useByScannerDiscovery="true" valueType="includePath"> | ||||||
|  | 									<listOptionValue builtIn="false" value=""${workspace_loc:/${ProjName}/freedom-e-sdk/drivers}""/> | ||||||
|  | 									<listOptionValue builtIn="false" value=""${workspace_loc:/${ProjName}/freedom-e-sdk/env}""/> | ||||||
|  | 									<listOptionValue builtIn="false" value=""${workspace_loc:/${ProjName}/freedom-e-sdk/env/freedom-e300-hifive1}""/> | ||||||
|  | 									<listOptionValue builtIn="false" value=""${workspace_loc:/${ProjName}/freedom-e-sdk/include}""/> | ||||||
|  | 								</option> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.c.compiler.defs.1115817835" name="Defined symbols (-D)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.c.compiler.defs" useByScannerDiscovery="true" valueType="definedSymbols"> | ||||||
|  | 									<listOptionValue builtIn="false" value="USE_PLIC"/> | ||||||
|  | 									<listOptionValue builtIn="false" value="USE_M_TIME"/> | ||||||
|  | 								</option> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.c.compiler.other.953712529" name="Other compiler flags" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.c.compiler.other" useByScannerDiscovery="true" value="-include sys/cdefs.h -fno-builtin-printf -c" valueType="string"/> | ||||||
|  | 								<inputType id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.c.compiler.input.517786622" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.c.compiler.input"/> | ||||||
|  | 							</tool> | ||||||
|  | 							<tool id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.cpp.compiler.890064572" name="GNU RISC-V Cross C++ Compiler" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.cpp.compiler"/> | ||||||
|  | 							<tool id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.c.linker.1118992651" name="GNU RISC-V Cross C Linker" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.c.linker"> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.c.linker.gcsections.303446425" name="Remove unused sections (-Xlinker --gc-sections)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.c.linker.gcsections" useByScannerDiscovery="false" value="false" valueType="boolean"/> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.c.linker.nostart.2092172057" name="Do not use standard start files (-nostartfiles)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.c.linker.nostart" useByScannerDiscovery="false" value="true" valueType="boolean"/> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.c.linker.libs.1930877742" name="Libraries (-l)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.c.linker.libs" useByScannerDiscovery="false" valueType="libs"> | ||||||
|  | 									<listOptionValue builtIn="false" value="c"/> | ||||||
|  | 								</option> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.c.linker.other.724386459" name="Other linker flags" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.c.linker.other" useByScannerDiscovery="false" value="-Wl,--start-group -Wl,--end-group -Wl,--wrap=malloc -Wl,--wrap=free -Wl,--wrap=open -Wl,--wrap=lseek -Wl,--wrap=read -Wl,--wrap=write -Wl,--wrap=fstat -Wl,--wrap=stat -Wl,--wrap=close -Wl,--wrap=link -Wl,--wrap=unlink -Wl,--wrap=execve -Wl,--wrap=fork -Wl,--wrap=getpid -Wl,--wrap=kill -Wl,--wrap=wait -Wl,--wrap=isatty -Wl,--wrap=times -Wl,--wrap=sbrk -Wl,--wrap=_exit -Wl,--wrap=puts -Wl,--wrap=_malloc -Wl,--wrap=_free -Wl,--wrap=_open -Wl,--wrap=_lseek -Wl,--wrap=_read -Wl,--wrap=_write -Wl,--wrap=_fstat -Wl,--wrap=_stat -Wl,--wrap=_close -Wl,--wrap=_link -Wl,--wrap=_unlink -Wl,--wrap=_execve -Wl,--wrap=_fork -Wl,--wrap=_getpid -Wl,--wrap=_kill -Wl,--wrap=_wait -Wl,--wrap=_isatty -Wl,--wrap=_times -Wl,--wrap=_sbrk -Wl,--wrap=__exit -Wl,--wrap=_puts" valueType="string"/> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.c.linker.paths.1340277823" name="Library search path (-L)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.c.linker.paths" useByScannerDiscovery="false" valueType="libPaths"> | ||||||
|  | 									<listOptionValue builtIn="false" value="../"/> | ||||||
|  | 								</option> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.c.linker.scriptfile.535033372" name="Script files (-T)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.c.linker.scriptfile" useByScannerDiscovery="false" valueType="stringList"> | ||||||
|  | 									<listOptionValue builtIn="false" value=""${workspace_loc:/${ProjName}/freedom-e-sdk/env/freedom-e300-hifive1/flash.lds}""/> | ||||||
|  | 								</option> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.c.linker.usenewlibnano.221590263" name="Use newlib-nano (--specs=nano.specs)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.c.linker.usenewlibnano" useByScannerDiscovery="false" value="true" valueType="boolean"/> | ||||||
|  | 								<inputType id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.c.linker.input.170776044" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.c.linker.input"> | ||||||
|  | 									<additionalInput kind="additionalinputdependency" paths="$(USER_OBJS)"/> | ||||||
|  | 									<additionalInput kind="additionalinput" paths="$(LIBS)"/> | ||||||
|  | 								</inputType> | ||||||
|  | 							</tool> | ||||||
|  | 							<tool id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.cpp.linker.151100904" name="GNU RISC-V Cross C++ Linker" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.cpp.linker"> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.cpp.linker.gcsections.2013052941" name="Remove unused sections (-Xlinker --gc-sections)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.cpp.linker.gcsections" value="true" valueType="boolean"/> | ||||||
|  | 							</tool> | ||||||
|  | 							<tool id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.archiver.735073113" name="GNU RISC-V Cross Archiver" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.archiver"/> | ||||||
|  | 							<tool id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.createflash.43162503" name="GNU RISC-V Cross Create Flash Image" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.createflash"/> | ||||||
|  | 							<tool id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.createlisting.407702640" name="GNU RISC-V Cross Create Listing" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.createlisting"> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.createlisting.source.1632875344" name="Display source (--source|-S)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.createlisting.source" value="true" valueType="boolean"/> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.createlisting.allheaders.730325053" name="Display all headers (--all-headers|-x)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.createlisting.allheaders" value="true" valueType="boolean"/> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.createlisting.demangle.442048872" name="Demangle names (--demangle|-C)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.createlisting.demangle" value="true" valueType="boolean"/> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.createlisting.linenumbers.2063176206" name="Display line numbers (--line-numbers|-l)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.createlisting.linenumbers" value="true" valueType="boolean"/> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.createlisting.wide.1824434021" name="Wide lines (--wide|-w)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.createlisting.wide" value="true" valueType="boolean"/> | ||||||
|  | 							</tool> | ||||||
|  | 							<tool id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.printsize.1818348681" name="GNU RISC-V Cross Print Size" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.printsize"> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.printsize.format.782529195" name="Size format" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.printsize.format" useByScannerDiscovery="false"/> | ||||||
|  | 							</tool> | ||||||
|  | 						</toolChain> | ||||||
|  | 					</folderInfo> | ||||||
|  | 					<sourceEntries> | ||||||
|  | 						<entry excluding="freedom-e-sdk/env/entry.S" flags="VALUE_WORKSPACE_PATH|RESOLVED" kind="sourcePath" name=""/> | ||||||
|  | 					</sourceEntries> | ||||||
|  | 				</configuration> | ||||||
|  | 			</storageModule> | ||||||
|  | 			<storageModule moduleId="org.eclipse.cdt.core.externalSettings"/> | ||||||
|  | 		</cconfiguration> | ||||||
|  | 		<cconfiguration id="ilg.gnumcueclipse.managedbuild.cross.riscv.config.elf.release.1992646408"> | ||||||
|  | 			<storageModule buildSystemId="org.eclipse.cdt.managedbuilder.core.configurationDataProvider" id="ilg.gnumcueclipse.managedbuild.cross.riscv.config.elf.release.1992646408" moduleId="org.eclipse.cdt.core.settings" name="Release"> | ||||||
|  | 				<externalSettings/> | ||||||
|  | 				<extensions> | ||||||
|  | 					<extension id="org.eclipse.cdt.core.ELF" point="org.eclipse.cdt.core.BinaryParser"/> | ||||||
|  | 					<extension id="org.eclipse.cdt.core.GASErrorParser" point="org.eclipse.cdt.core.ErrorParser"/> | ||||||
|  | 					<extension id="org.eclipse.cdt.core.GmakeErrorParser" point="org.eclipse.cdt.core.ErrorParser"/> | ||||||
|  | 					<extension id="org.eclipse.cdt.core.GLDErrorParser" point="org.eclipse.cdt.core.ErrorParser"/> | ||||||
|  | 					<extension id="org.eclipse.cdt.core.CWDLocator" point="org.eclipse.cdt.core.ErrorParser"/> | ||||||
|  | 					<extension id="org.eclipse.cdt.core.GCCErrorParser" point="org.eclipse.cdt.core.ErrorParser"/> | ||||||
|  | 				</extensions> | ||||||
|  | 			</storageModule> | ||||||
|  | 			<storageModule moduleId="cdtBuildSystem" version="4.0.0"> | ||||||
|  | 				<configuration artifactName="${ProjName}" buildArtefactType="org.eclipse.cdt.build.core.buildArtefactType.exe" buildProperties="org.eclipse.cdt.build.core.buildArtefactType=org.eclipse.cdt.build.core.buildArtefactType.exe,org.eclipse.cdt.build.core.buildType=org.eclipse.cdt.build.core.buildType.release" cleanCommand="${cross_rm} -rf" description="" id="ilg.gnumcueclipse.managedbuild.cross.riscv.config.elf.release.1992646408" name="Release" parent="ilg.gnumcueclipse.managedbuild.cross.riscv.config.elf.release"> | ||||||
|  | 					<folderInfo id="ilg.gnumcueclipse.managedbuild.cross.riscv.config.elf.release.1992646408." name="/" resourcePath=""> | ||||||
|  | 						<toolChain id="ilg.gnumcueclipse.managedbuild.cross.riscv.toolchain.elf.release.1937283388" name="RISC-V Cross GCC" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.toolchain.elf.release"> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.addtools.createflash.672219611" name="Create flash image" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.addtools.createflash" value="true" valueType="boolean"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.addtools.createlisting.1692672647" name="Create extended listing" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.addtools.createlisting"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.addtools.printsize.1955835524" name="Print size" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.addtools.printsize" value="true" valueType="boolean"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.optimization.level.1634926912" name="Optimization Level" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.optimization.level" value="ilg.gnumcueclipse.managedbuild.cross.riscv.option.optimization.level.size" valueType="enumerated"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.optimization.messagelength.1936180446" name="Message length (-fmessage-length=0)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.optimization.messagelength" value="true" valueType="boolean"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.optimization.signedchar.148983493" name="'char' is signed (-fsigned-char)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.optimization.signedchar" value="true" valueType="boolean"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.optimization.functionsections.2117145633" name="Function sections (-ffunction-sections)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.optimization.functionsections" value="true" valueType="boolean"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.optimization.datasections.1653949713" name="Data sections (-fdata-sections)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.optimization.datasections" value="true" valueType="boolean"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.debugging.level.728682044" name="Debug level" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.debugging.level"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.debugging.format.1767313058" name="Debug format" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.debugging.format"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.toolchain.name.254213830" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.toolchain.name" value="RISC-V GCC/Newlib" valueType="string"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.prefix.372256120" name="Prefix" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.prefix" value="riscv64-unknown-elf-" valueType="string"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.c.298542489" name="C compiler" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.c" value="gcc" valueType="string"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.cpp.1240126358" name="C++ compiler" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.cpp" value="g++" valueType="string"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.ar.170388081" name="Archiver" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.ar" value="ar" valueType="string"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.objcopy.1277104890" name="Hex/Bin converter" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.objcopy" value="objcopy" valueType="string"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.objdump.488685269" name="Listing generator" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.objdump" value="objdump" valueType="string"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.size.554860593" name="Size command" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.size" value="size" valueType="string"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.make.468110366" name="Build command" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.make" value="make" valueType="string"/> | ||||||
|  | 							<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.rm.309041178" name="Remove command" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.command.rm" value="rm" valueType="string"/> | ||||||
|  | 							<targetPlatform archList="all" binaryParser="org.eclipse.cdt.core.ELF" id="ilg.gnumcueclipse.managedbuild.cross.riscv.targetPlatform.687762738" isAbstract="false" osList="all" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.targetPlatform"/> | ||||||
|  | 							<builder buildPath="${workspace_loc:/RTOSDemo}/Release" id="ilg.gnumcueclipse.managedbuild.cross.riscv.builder.609463428" keepEnvironmentInBuildfile="false" managedBuildOn="true" name="Gnu Make Builder" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.builder"/> | ||||||
|  | 							<tool id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.assembler.1648537074" name="GNU RISC-V Cross Assembler" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.assembler"> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.assembler.usepreprocessor.1113623358" name="Use preprocessor" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.assembler.usepreprocessor" value="true" valueType="boolean"/> | ||||||
|  | 								<inputType id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.assembler.input.1033931684" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.assembler.input"/> | ||||||
|  | 							</tool> | ||||||
|  | 							<tool id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.c.compiler.1778523424" name="GNU RISC-V Cross C Compiler" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.c.compiler"> | ||||||
|  | 								<inputType id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.c.compiler.input.1714150627" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.c.compiler.input"/> | ||||||
|  | 							</tool> | ||||||
|  | 							<tool id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.cpp.compiler.669753833" name="GNU RISC-V Cross C++ Compiler" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.cpp.compiler"/> | ||||||
|  | 							<tool id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.c.linker.1530679232" name="GNU RISC-V Cross C Linker" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.c.linker"> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.c.linker.gcsections.1637900674" name="Remove unused sections (-Xlinker --gc-sections)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.c.linker.gcsections" value="true" valueType="boolean"/> | ||||||
|  | 								<inputType id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.c.linker.input.1335245598" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.c.linker.input"> | ||||||
|  | 									<additionalInput kind="additionalinputdependency" paths="$(USER_OBJS)"/> | ||||||
|  | 									<additionalInput kind="additionalinput" paths="$(LIBS)"/> | ||||||
|  | 								</inputType> | ||||||
|  | 							</tool> | ||||||
|  | 							<tool id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.cpp.linker.648232936" name="GNU RISC-V Cross C++ Linker" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.cpp.linker"> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.cpp.linker.gcsections.929507343" name="Remove unused sections (-Xlinker --gc-sections)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.cpp.linker.gcsections" value="true" valueType="boolean"/> | ||||||
|  | 							</tool> | ||||||
|  | 							<tool id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.archiver.439296099" name="GNU RISC-V Cross Archiver" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.archiver"/> | ||||||
|  | 							<tool id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.createflash.2024214820" name="GNU RISC-V Cross Create Flash Image" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.createflash"/> | ||||||
|  | 							<tool id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.createlisting.1648338834" name="GNU RISC-V Cross Create Listing" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.createlisting"> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.createlisting.source.1291642104" name="Display source (--source|-S)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.createlisting.source" value="true" valueType="boolean"/> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.createlisting.allheaders.616461822" name="Display all headers (--all-headers|-x)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.createlisting.allheaders" value="true" valueType="boolean"/> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.createlisting.demangle.1146271318" name="Demangle names (--demangle|-C)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.createlisting.demangle" value="true" valueType="boolean"/> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.createlisting.linenumbers.1242922810" name="Display line numbers (--line-numbers|-l)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.createlisting.linenumbers" value="true" valueType="boolean"/> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.createlisting.wide.876301703" name="Wide lines (--wide|-w)" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.createlisting.wide" value="true" valueType="boolean"/> | ||||||
|  | 							</tool> | ||||||
|  | 							<tool id="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.printsize.1112238656" name="GNU RISC-V Cross Print Size" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.tool.printsize"> | ||||||
|  | 								<option id="ilg.gnumcueclipse.managedbuild.cross.riscv.option.printsize.format.483461408" name="Size format" superClass="ilg.gnumcueclipse.managedbuild.cross.riscv.option.printsize.format"/> | ||||||
|  | 							</tool> | ||||||
|  | 						</toolChain> | ||||||
|  | 					</folderInfo> | ||||||
|  | 				</configuration> | ||||||
|  | 			</storageModule> | ||||||
|  | 			<storageModule moduleId="org.eclipse.cdt.core.externalSettings"/> | ||||||
|  | 		</cconfiguration> | ||||||
|  | 	</storageModule> | ||||||
|  | 	<storageModule moduleId="cdtBuildSystem" version="4.0.0"> | ||||||
|  | 		<project id="RTOSDemo.ilg.gnumcueclipse.managedbuild.cross.riscv.target.elf.431462479" name="Executable" projectType="ilg.gnumcueclipse.managedbuild.cross.riscv.target.elf"/> | ||||||
|  | 	</storageModule> | ||||||
|  | 	<storageModule moduleId="scannerConfiguration"> | ||||||
|  | 		<autodiscovery enabled="true" problemReportingEnabled="true" selectedProfileId=""/> | ||||||
|  | 		<scannerConfigBuildInfo instanceId="ilg.gnumcueclipse.managedbuild.cross.riscv.config.elf.release.1992646408;ilg.gnumcueclipse.managedbuild.cross.riscv.config.elf.release.1992646408.;ilg.gnumcueclipse.managedbuild.cross.riscv.tool.c.compiler.1778523424;ilg.gnumcueclipse.managedbuild.cross.riscv.tool.c.compiler.input.1714150627"> | ||||||
|  | 			<autodiscovery enabled="true" problemReportingEnabled="true" selectedProfileId=""/> | ||||||
|  | 		</scannerConfigBuildInfo> | ||||||
|  | 		<scannerConfigBuildInfo instanceId="ilg.gnumcueclipse.managedbuild.cross.riscv.config.elf.debug.516870870;ilg.gnumcueclipse.managedbuild.cross.riscv.config.elf.debug.516870870.;ilg.gnumcueclipse.managedbuild.cross.riscv.tool.c.compiler.1632260763;ilg.gnumcueclipse.managedbuild.cross.riscv.tool.c.compiler.input.517786622"> | ||||||
|  | 			<autodiscovery enabled="true" problemReportingEnabled="true" selectedProfileId=""/> | ||||||
|  | 		</scannerConfigBuildInfo> | ||||||
|  | 	</storageModule> | ||||||
|  | 	<storageModule moduleId="org.eclipse.cdt.core.LanguageSettingsProviders"/> | ||||||
|  | 	<storageModule moduleId="refreshScope" versionNumber="2"> | ||||||
|  | 		<configuration configurationName="Debug"> | ||||||
|  | 			<resource resourceType="PROJECT" workspacePath="/RTOSDemo"/> | ||||||
|  | 		</configuration> | ||||||
|  | 		<configuration configurationName="Release"> | ||||||
|  | 			<resource resourceType="PROJECT" workspacePath="/RTOSDemo"/> | ||||||
|  | 		</configuration> | ||||||
|  | 	</storageModule> | ||||||
|  | 	<storageModule moduleId="org.eclipse.cdt.make.core.buildtargets"/> | ||||||
|  | </cproject> | ||||||
							
								
								
									
										26
									
								
								FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/.project
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/.project
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,26 @@ | ||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <projectDescription> | ||||||
|  | 	<name>RTOSDemo</name> | ||||||
|  | 	<comment></comment> | ||||||
|  | 	<projects> | ||||||
|  | 	</projects> | ||||||
|  | 	<buildSpec> | ||||||
|  | 		<buildCommand> | ||||||
|  | 			<name>org.eclipse.cdt.managedbuilder.core.genmakebuilder</name> | ||||||
|  | 			<triggers>clean,full,incremental,</triggers> | ||||||
|  | 			<arguments> | ||||||
|  | 			</arguments> | ||||||
|  | 		</buildCommand> | ||||||
|  | 		<buildCommand> | ||||||
|  | 			<name>org.eclipse.cdt.managedbuilder.core.ScannerConfigBuilder</name> | ||||||
|  | 			<triggers>full,incremental,</triggers> | ||||||
|  | 			<arguments> | ||||||
|  | 			</arguments> | ||||||
|  | 		</buildCommand> | ||||||
|  | 	</buildSpec> | ||||||
|  | 	<natures> | ||||||
|  | 		<nature>org.eclipse.cdt.core.cnature</nature> | ||||||
|  | 		<nature>org.eclipse.cdt.managedbuilder.core.managedBuildNature</nature> | ||||||
|  | 		<nature>org.eclipse.cdt.managedbuilder.core.ScannerConfigNature</nature> | ||||||
|  | 	</natures> | ||||||
|  | </projectDescription> | ||||||
|  | @ -0,0 +1,25 @@ | ||||||
|  | <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||||
|  | <project> | ||||||
|  | 	<configuration id="ilg.gnumcueclipse.managedbuild.cross.riscv.config.elf.debug.516870870" name="Debug"> | ||||||
|  | 		<extension point="org.eclipse.cdt.core.LanguageSettingsProvider"> | ||||||
|  | 			<provider copy-of="extension" id="org.eclipse.cdt.ui.UserLanguageSettingsProvider"/> | ||||||
|  | 			<provider-reference id="org.eclipse.cdt.core.ReferencedProjectsLanguageSettingsProvider" ref="shared-provider"/> | ||||||
|  | 			<provider-reference id="org.eclipse.cdt.managedbuilder.core.MBSLanguageSettingsProvider" ref="shared-provider"/> | ||||||
|  | 			<provider class="org.eclipse.cdt.managedbuilder.language.settings.providers.GCCBuiltinSpecsDetector" console="false" env-hash="1866420524446515374" id="ilg.gnumcueclipse.managedbuild.cross.riscv.GCCBuiltinSpecsDetector" keep-relative-paths="false" name="CDT RISC-V Cross GCC Built-in Compiler Settings" parameter="${COMMAND} ${FLAGS} ${cross_toolchain_flags} -E -P -v -dD "${INPUTS}"" prefer-non-shared="true"> | ||||||
|  | 				<language-scope id="org.eclipse.cdt.core.gcc"/> | ||||||
|  | 				<language-scope id="org.eclipse.cdt.core.g++"/> | ||||||
|  | 			</provider> | ||||||
|  | 		</extension> | ||||||
|  | 	</configuration> | ||||||
|  | 	<configuration id="ilg.gnumcueclipse.managedbuild.cross.riscv.config.elf.release.1992646408" name="Release"> | ||||||
|  | 		<extension point="org.eclipse.cdt.core.LanguageSettingsProvider"> | ||||||
|  | 			<provider copy-of="extension" id="org.eclipse.cdt.ui.UserLanguageSettingsProvider"/> | ||||||
|  | 			<provider-reference id="org.eclipse.cdt.core.ReferencedProjectsLanguageSettingsProvider" ref="shared-provider"/> | ||||||
|  | 			<provider-reference id="org.eclipse.cdt.managedbuilder.core.MBSLanguageSettingsProvider" ref="shared-provider"/> | ||||||
|  | 			<provider class="org.eclipse.cdt.managedbuilder.language.settings.providers.GCCBuiltinSpecsDetector" console="false" env-hash="1935790922815146096" id="ilg.gnumcueclipse.managedbuild.cross.riscv.GCCBuiltinSpecsDetector" keep-relative-paths="false" name="CDT RISC-V Cross GCC Built-in Compiler Settings" parameter="${COMMAND} ${FLAGS} ${cross_toolchain_flags} -E -P -v -dD "${INPUTS}"" prefer-non-shared="true"> | ||||||
|  | 				<language-scope id="org.eclipse.cdt.core.gcc"/> | ||||||
|  | 				<language-scope id="org.eclipse.cdt.core.g++"/> | ||||||
|  | 			</provider> | ||||||
|  | 		</extension> | ||||||
|  | 	</configuration> | ||||||
|  | </project> | ||||||
|  | @ -0,0 +1,44 @@ | ||||||
|  | <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||||
|  | <launchConfiguration type="org.eclipse.cdt.debug.gdbjtag.launchConfigurationType"> | ||||||
|  | <intAttribute key="org.eclipse.cdt.debug.gdbjtag.core.delay" value="3"/> | ||||||
|  | <booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.doHalt" value="false"/> | ||||||
|  | <booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.doReset" value="false"/> | ||||||
|  | <stringAttribute key="org.eclipse.cdt.debug.gdbjtag.core.imageFileName" value=""/> | ||||||
|  | <stringAttribute key="org.eclipse.cdt.debug.gdbjtag.core.imageOffset" value=""/> | ||||||
|  | <stringAttribute key="org.eclipse.cdt.debug.gdbjtag.core.initCommands" value=""/> | ||||||
|  | <stringAttribute key="org.eclipse.cdt.debug.gdbjtag.core.ipAddress" value="localhost"/> | ||||||
|  | <stringAttribute key="org.eclipse.cdt.debug.gdbjtag.core.jtagDevice" value="Generic TCP/IP"/> | ||||||
|  | <booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.loadImage" value="false"/> | ||||||
|  | <booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.loadSymbols" value="true"/> | ||||||
|  | <stringAttribute key="org.eclipse.cdt.debug.gdbjtag.core.pcRegister" value=""/> | ||||||
|  | <intAttribute key="org.eclipse.cdt.debug.gdbjtag.core.portNumber" value="1234"/> | ||||||
|  | <stringAttribute key="org.eclipse.cdt.debug.gdbjtag.core.runCommands" value=""/> | ||||||
|  | <booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.setPcRegister" value="false"/> | ||||||
|  | <booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.setResume" value="true"/> | ||||||
|  | <booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.setStopAt" value="true"/> | ||||||
|  | <stringAttribute key="org.eclipse.cdt.debug.gdbjtag.core.stopAt" value="main"/> | ||||||
|  | <stringAttribute key="org.eclipse.cdt.debug.gdbjtag.core.symbolsFileName" value=""/> | ||||||
|  | <stringAttribute key="org.eclipse.cdt.debug.gdbjtag.core.symbolsOffset" value=""/> | ||||||
|  | <booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.useFileForImage" value="false"/> | ||||||
|  | <booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.useFileForSymbols" value="false"/> | ||||||
|  | <booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.useProjBinaryForImage" value="true"/> | ||||||
|  | <booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.useProjBinaryForSymbols" value="true"/> | ||||||
|  | <booleanAttribute key="org.eclipse.cdt.debug.gdbjtag.core.useRemoteTarget" value="true"/> | ||||||
|  | <stringAttribute key="org.eclipse.cdt.dsf.gdb.DEBUG_NAME" value="riscv64-unknown-elf-gdb.exe --command=c:\temp\gdbinit"/> | ||||||
|  | <booleanAttribute key="org.eclipse.cdt.dsf.gdb.UPDATE_THREADLIST_ON_SUSPEND" value="false"/> | ||||||
|  | <intAttribute key="org.eclipse.cdt.launch.ATTR_BUILD_BEFORE_LAUNCH_ATTR" value="2"/> | ||||||
|  | <stringAttribute key="org.eclipse.cdt.launch.COREFILE_PATH" value=""/> | ||||||
|  | <stringAttribute key="org.eclipse.cdt.launch.DEBUGGER_START_MODE" value="remote"/> | ||||||
|  | <stringAttribute key="org.eclipse.cdt.launch.PROGRAM_NAME" value="Debug\RTOSDemo.elf"/> | ||||||
|  | <stringAttribute key="org.eclipse.cdt.launch.PROJECT_ATTR" value="RTOSDemo"/> | ||||||
|  | <booleanAttribute key="org.eclipse.cdt.launch.PROJECT_BUILD_CONFIG_AUTO_ATTR" value="false"/> | ||||||
|  | <stringAttribute key="org.eclipse.cdt.launch.PROJECT_BUILD_CONFIG_ID_ATTR" value=""/> | ||||||
|  | <listAttribute key="org.eclipse.debug.core.MAPPED_RESOURCE_PATHS"> | ||||||
|  | <listEntry value="/RTOSDemo"/> | ||||||
|  | </listAttribute> | ||||||
|  | <listAttribute key="org.eclipse.debug.core.MAPPED_RESOURCE_TYPES"> | ||||||
|  | <listEntry value="4"/> | ||||||
|  | </listAttribute> | ||||||
|  | <stringAttribute key="org.eclipse.dsf.launch.MEMORY_BLOCKS" value="<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<memoryBlockExpressionList context="reserved-for-future-use"/>
"/> | ||||||
|  | <stringAttribute key="process_factory_id" value="org.eclipse.cdt.dsf.gdb.GdbProcessFactory"/> | ||||||
|  | </launchConfiguration> | ||||||
							
								
								
									
										2325
									
								
								FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/fe310-xsvd.json
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										2325
									
								
								FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/fe310-xsvd.json
									
										
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							|  | @ -0,0 +1,206 @@ | ||||||
|  | 
 | ||||||
|  | This software, except as otherwise noted in subrepositories,  | ||||||
|  | is licensed under the Apache 2 license, quoted below. | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |                                  Apache License | ||||||
|  |                            Version 2.0, January 2004 | ||||||
|  |                         http://www.apache.org/licenses/ | ||||||
|  | 
 | ||||||
|  |    TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION | ||||||
|  | 
 | ||||||
|  |    1. Definitions. | ||||||
|  | 
 | ||||||
|  |       "License" shall mean the terms and conditions for use, reproduction, | ||||||
|  |       and distribution as defined by Sections 1 through 9 of this document. | ||||||
|  | 
 | ||||||
|  |       "Licensor" shall mean the copyright owner or entity authorized by | ||||||
|  |       the copyright owner that is granting the License. | ||||||
|  | 
 | ||||||
|  |       "Legal Entity" shall mean the union of the acting entity and all | ||||||
|  |       other entities that control, are controlled by, or are under common | ||||||
|  |       control with that entity. For the purposes of this definition, | ||||||
|  |       "control" means (i) the power, direct or indirect, to cause the | ||||||
|  |       direction or management of such entity, whether by contract or | ||||||
|  |       otherwise, or (ii) ownership of fifty percent (50%) or more of the | ||||||
|  |       outstanding shares, or (iii) beneficial ownership of such entity. | ||||||
|  | 
 | ||||||
|  |       "You" (or "Your") shall mean an individual or Legal Entity | ||||||
|  |       exercising permissions granted by this License. | ||||||
|  | 
 | ||||||
|  |       "Source" form shall mean the preferred form for making modifications, | ||||||
|  |       including but not limited to software source code, documentation | ||||||
|  |       source, and configuration files. | ||||||
|  | 
 | ||||||
|  |       "Object" form shall mean any form resulting from mechanical | ||||||
|  |       transformation or translation of a Source form, including but | ||||||
|  |       not limited to compiled object code, generated documentation, | ||||||
|  |       and conversions to other media types. | ||||||
|  | 
 | ||||||
|  |       "Work" shall mean the work of authorship, whether in Source or | ||||||
|  |       Object form, made available under the License, as indicated by a | ||||||
|  |       copyright notice that is included in or attached to the work | ||||||
|  |       (an example is provided in the Appendix below). | ||||||
|  | 
 | ||||||
|  |       "Derivative Works" shall mean any work, whether in Source or Object | ||||||
|  |       form, that is based on (or derived from) the Work and for which the | ||||||
|  |       editorial revisions, annotations, elaborations, or other modifications | ||||||
|  |       represent, as a whole, an original work of authorship. For the purposes | ||||||
|  |       of this License, Derivative Works shall not include works that remain | ||||||
|  |       separable from, or merely link (or bind by name) to the interfaces of, | ||||||
|  |       the Work and Derivative Works thereof. | ||||||
|  | 
 | ||||||
|  |       "Contribution" shall mean any work of authorship, including | ||||||
|  |       the original version of the Work and any modifications or additions | ||||||
|  |       to that Work or Derivative Works thereof, that is intentionally | ||||||
|  |       submitted to Licensor for inclusion in the Work by the copyright owner | ||||||
|  |       or by an individual or Legal Entity authorized to submit on behalf of | ||||||
|  |       the copyright owner. For the purposes of this definition, "submitted" | ||||||
|  |       means any form of electronic, verbal, or written communication sent | ||||||
|  |       to the Licensor or its representatives, including but not limited to | ||||||
|  |       communication on electronic mailing lists, source code control systems, | ||||||
|  |       and issue tracking systems that are managed by, or on behalf of, the | ||||||
|  |       Licensor for the purpose of discussing and improving the Work, but | ||||||
|  |       excluding communication that is conspicuously marked or otherwise | ||||||
|  |       designated in writing by the copyright owner as "Not a Contribution." | ||||||
|  | 
 | ||||||
|  |       "Contributor" shall mean Licensor and any individual or Legal Entity | ||||||
|  |       on behalf of whom a Contribution has been received by Licensor and | ||||||
|  |       subsequently incorporated within the Work. | ||||||
|  | 
 | ||||||
|  |    2. Grant of Copyright License. Subject to the terms and conditions of | ||||||
|  |       this License, each Contributor hereby grants to You a perpetual, | ||||||
|  |       worldwide, non-exclusive, no-charge, royalty-free, irrevocable | ||||||
|  |       copyright license to reproduce, prepare Derivative Works of, | ||||||
|  |       publicly display, publicly perform, sublicense, and distribute the | ||||||
|  |       Work and such Derivative Works in Source or Object form. | ||||||
|  | 
 | ||||||
|  |    3. Grant of Patent License. Subject to the terms and conditions of | ||||||
|  |       this License, each Contributor hereby grants to You a perpetual, | ||||||
|  |       worldwide, non-exclusive, no-charge, royalty-free, irrevocable | ||||||
|  |       (except as stated in this section) patent license to make, have made, | ||||||
|  |       use, offer to sell, sell, import, and otherwise transfer the Work, | ||||||
|  |       where such license applies only to those patent claims licensable | ||||||
|  |       by such Contributor that are necessarily infringed by their | ||||||
|  |       Contribution(s) alone or by combination of their Contribution(s) | ||||||
|  |       with the Work to which such Contribution(s) was submitted. If You | ||||||
|  |       institute patent litigation against any entity (including a | ||||||
|  |       cross-claim or counterclaim in a lawsuit) alleging that the Work | ||||||
|  |       or a Contribution incorporated within the Work constitutes direct | ||||||
|  |       or contributory patent infringement, then any patent licenses | ||||||
|  |       granted to You under this License for that Work shall terminate | ||||||
|  |       as of the date such litigation is filed. | ||||||
|  | 
 | ||||||
|  |    4. Redistribution. You may reproduce and distribute copies of the | ||||||
|  |       Work or Derivative Works thereof in any medium, with or without | ||||||
|  |       modifications, and in Source or Object form, provided that You | ||||||
|  |       meet the following conditions: | ||||||
|  | 
 | ||||||
|  |       (a) You must give any other recipients of the Work or | ||||||
|  |           Derivative Works a copy of this License; and | ||||||
|  | 
 | ||||||
|  |       (b) You must cause any modified files to carry prominent notices | ||||||
|  |           stating that You changed the files; and | ||||||
|  | 
 | ||||||
|  |       (c) You must retain, in the Source form of any Derivative Works | ||||||
|  |           that You distribute, all copyright, patent, trademark, and | ||||||
|  |           attribution notices from the Source form of the Work, | ||||||
|  |           excluding those notices that do not pertain to any part of | ||||||
|  |           the Derivative Works; and | ||||||
|  | 
 | ||||||
|  |       (d) If the Work includes a "NOTICE" text file as part of its | ||||||
|  |           distribution, then any Derivative Works that You distribute must | ||||||
|  |           include a readable copy of the attribution notices contained | ||||||
|  |           within such NOTICE file, excluding those notices that do not | ||||||
|  |           pertain to any part of the Derivative Works, in at least one | ||||||
|  |           of the following places: within a NOTICE text file distributed | ||||||
|  |           as part of the Derivative Works; within the Source form or | ||||||
|  |           documentation, if provided along with the Derivative Works; or, | ||||||
|  |           within a display generated by the Derivative Works, if and | ||||||
|  |           wherever such third-party notices normally appear. The contents | ||||||
|  |           of the NOTICE file are for informational purposes only and | ||||||
|  |           do not modify the License. You may add Your own attribution | ||||||
|  |           notices within Derivative Works that You distribute, alongside | ||||||
|  |           or as an addendum to the NOTICE text from the Work, provided | ||||||
|  |           that such additional attribution notices cannot be construed | ||||||
|  |           as modifying the License. | ||||||
|  | 
 | ||||||
|  |       You may add Your own copyright statement to Your modifications and | ||||||
|  |       may provide additional or different license terms and conditions | ||||||
|  |       for use, reproduction, or distribution of Your modifications, or | ||||||
|  |       for any such Derivative Works as a whole, provided Your use, | ||||||
|  |       reproduction, and distribution of the Work otherwise complies with | ||||||
|  |       the conditions stated in this License. | ||||||
|  | 
 | ||||||
|  |    5. Submission of Contributions. Unless You explicitly state otherwise, | ||||||
|  |       any Contribution intentionally submitted for inclusion in the Work | ||||||
|  |       by You to the Licensor shall be under the terms and conditions of | ||||||
|  |       this License, without any additional terms or conditions. | ||||||
|  |       Notwithstanding the above, nothing herein shall supersede or modify | ||||||
|  |       the terms of any separate license agreement you may have executed | ||||||
|  |       with Licensor regarding such Contributions. | ||||||
|  | 
 | ||||||
|  |    6. Trademarks. This License does not grant permission to use the trade | ||||||
|  |       names, trademarks, service marks, or product names of the Licensor, | ||||||
|  |       except as required for reasonable and customary use in describing the | ||||||
|  |       origin of the Work and reproducing the content of the NOTICE file. | ||||||
|  | 
 | ||||||
|  |    7. Disclaimer of Warranty. Unless required by applicable law or | ||||||
|  |       agreed to in writing, Licensor provides the Work (and each | ||||||
|  |       Contributor provides its Contributions) on an "AS IS" BASIS, | ||||||
|  |       WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or | ||||||
|  |       implied, including, without limitation, any warranties or conditions | ||||||
|  |       of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A | ||||||
|  |       PARTICULAR PURPOSE. You are solely responsible for determining the | ||||||
|  |       appropriateness of using or redistributing the Work and assume any | ||||||
|  |       risks associated with Your exercise of permissions under this License. | ||||||
|  | 
 | ||||||
|  |    8. Limitation of Liability. In no event and under no legal theory, | ||||||
|  |       whether in tort (including negligence), contract, or otherwise, | ||||||
|  |       unless required by applicable law (such as deliberate and grossly | ||||||
|  |       negligent acts) or agreed to in writing, shall any Contributor be | ||||||
|  |       liable to You for damages, including any direct, indirect, special, | ||||||
|  |       incidental, or consequential damages of any character arising as a | ||||||
|  |       result of this License or out of the use or inability to use the | ||||||
|  |       Work (including but not limited to damages for loss of goodwill, | ||||||
|  |       work stoppage, computer failure or malfunction, or any and all | ||||||
|  |       other commercial damages or losses), even if such Contributor | ||||||
|  |       has been advised of the possibility of such damages. | ||||||
|  | 
 | ||||||
|  |    9. Accepting Warranty or Additional Liability. While redistributing | ||||||
|  |       the Work or Derivative Works thereof, You may choose to offer, | ||||||
|  |       and charge a fee for, acceptance of support, warranty, indemnity, | ||||||
|  |       or other liability obligations and/or rights consistent with this | ||||||
|  |       License. However, in accepting such obligations, You may act only | ||||||
|  |       on Your own behalf and on Your sole responsibility, not on behalf | ||||||
|  |       of any other Contributor, and only if You agree to indemnify, | ||||||
|  |       defend, and hold each Contributor harmless for any liability | ||||||
|  |       incurred by, or claims asserted against, such Contributor by reason | ||||||
|  |       of your accepting any such warranty or additional liability. | ||||||
|  | 
 | ||||||
|  |    END OF TERMS AND CONDITIONS | ||||||
|  | 
 | ||||||
|  |    APPENDIX: How to apply the Apache License to your work. | ||||||
|  | 
 | ||||||
|  |       To apply the Apache License to your work, attach the following | ||||||
|  |       boilerplate notice, with the fields enclosed by brackets "[]" | ||||||
|  |       replaced with your own identifying information. (Don't include | ||||||
|  |       the brackets!)  The text should be enclosed in the appropriate | ||||||
|  |       comment syntax for the file format. We also recommend that a | ||||||
|  |       file or class name and description of purpose be included on the | ||||||
|  |       same "printed page" as the copyright notice for easier | ||||||
|  |       identification within third-party archives. | ||||||
|  | 
 | ||||||
|  |    Copyright 2016 SiFive, Inc. | ||||||
|  | 
 | ||||||
|  |    Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  |    you may not use this file except in compliance with the License. | ||||||
|  |    You may obtain a copy of the License at | ||||||
|  | 
 | ||||||
|  |        http://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | 
 | ||||||
|  |    Unless required by applicable law or agreed to in writing, software | ||||||
|  |    distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  |    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  |    See the License for the specific language governing permissions and | ||||||
|  |    limitations under the License. | ||||||
|  | @ -0,0 +1,252 @@ | ||||||
|  | // See LICENSE file for license details
 | ||||||
|  | 
 | ||||||
|  | #include "platform.h" | ||||||
|  | 
 | ||||||
|  | #ifdef PRCI_CTRL_ADDR | ||||||
|  | #include "fe300prci/fe300prci_driver.h" | ||||||
|  | #include <unistd.h> | ||||||
|  | 
 | ||||||
|  | #define rdmcycle(x)  {				       \ | ||||||
|  |     uint32_t lo, hi, hi2;			       \ | ||||||
|  |     __asm__ __volatile__ ("1:\n\t"		       \ | ||||||
|  | 			  "csrr %0, mcycleh\n\t"       \ | ||||||
|  | 			  "csrr %1, mcycle\n\t"	       \ | ||||||
|  | 			  "csrr %2, mcycleh\n\t"		\ | ||||||
|  | 			  "bne  %0, %2, 1b\n\t"			\ | ||||||
|  | 			  : "=r" (hi), "=r" (lo), "=r" (hi2)) ;	\ | ||||||
|  |     *(x) = lo | ((uint64_t) hi << 32); 				\ | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  | uint32_t PRCI_measure_mcycle_freq(uint32_t mtime_ticks, uint32_t mtime_freq) | ||||||
|  | { | ||||||
|  | 
 | ||||||
|  |   uint32_t start_mtime = CLINT_REG(CLINT_MTIME); | ||||||
|  |   uint32_t end_mtime = start_mtime + mtime_ticks + 1; | ||||||
|  | 
 | ||||||
|  |   // Make sure we won't get rollover.
 | ||||||
|  |   while (end_mtime < start_mtime){ | ||||||
|  |     start_mtime = CLINT_REG(CLINT_MTIME); | ||||||
|  |     end_mtime = start_mtime + mtime_ticks + 1; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   // Don't start measuring until mtime edge.
 | ||||||
|  |   uint32_t tmp = start_mtime; | ||||||
|  |   do { | ||||||
|  |     start_mtime = CLINT_REG(CLINT_MTIME); | ||||||
|  |   } while (start_mtime == tmp); | ||||||
|  |    | ||||||
|  |   uint64_t start_mcycle; | ||||||
|  |   rdmcycle(&start_mcycle); | ||||||
|  |    | ||||||
|  |   while (CLINT_REG(CLINT_MTIME) < end_mtime) ; | ||||||
|  |    | ||||||
|  |   uint64_t end_mcycle; | ||||||
|  |   rdmcycle(&end_mcycle); | ||||||
|  |   uint32_t difference = (uint32_t) (end_mcycle - start_mcycle); | ||||||
|  | 
 | ||||||
|  |   uint64_t freq = ((uint64_t) difference * mtime_freq) / mtime_ticks; | ||||||
|  |   return (uint32_t) freq & 0xFFFFFFFF; | ||||||
|  |    | ||||||
|  | } | ||||||
|  |   | ||||||
|  | 
 | ||||||
|  | void PRCI_use_hfrosc(int div, int trim) | ||||||
|  | { | ||||||
|  |   // Make sure the HFROSC is running at its default setting
 | ||||||
|  |   // It is OK to change this even if we are running off of it.
 | ||||||
|  |    | ||||||
|  |   PRCI_REG(PRCI_HFROSCCFG) = (ROSC_DIV(div) | ROSC_TRIM(trim) | ROSC_EN(1)); | ||||||
|  | 
 | ||||||
|  |   while ((PRCI_REG(PRCI_HFROSCCFG) & ROSC_RDY(1)) == 0); | ||||||
|  |    | ||||||
|  |   PRCI_REG(PRCI_PLLCFG) &= ~PLL_SEL(1); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void PRCI_use_pll(int refsel, int bypass, | ||||||
|  | 			 int r, int f, int q, int finaldiv, | ||||||
|  | 			 int hfroscdiv, int hfrosctrim) | ||||||
|  | { | ||||||
|  |   // Ensure that we aren't running off the PLL before we mess with it.
 | ||||||
|  |   if (PRCI_REG(PRCI_PLLCFG) & PLL_SEL(1)) { | ||||||
|  |     // Make sure the HFROSC is running at its default setting
 | ||||||
|  |     PRCI_use_hfrosc(4, 16); | ||||||
|  |   } | ||||||
|  |    | ||||||
|  |   // Set PLL Source to be HFXOSC if desired.
 | ||||||
|  |   uint32_t config_value = 0; | ||||||
|  | 
 | ||||||
|  |   config_value |= PLL_REFSEL(refsel); | ||||||
|  |    | ||||||
|  |   if (bypass) { | ||||||
|  |     // Bypass
 | ||||||
|  |     config_value |= PLL_BYPASS(1); | ||||||
|  | 
 | ||||||
|  |     PRCI_REG(PRCI_PLLCFG) = config_value; | ||||||
|  | 
 | ||||||
|  |     // If we don't have an HFXTAL, this doesn't really matter.
 | ||||||
|  |     // Set our Final output divide to divide-by-1:
 | ||||||
|  |     PRCI_REG(PRCI_PLLDIV) = (PLL_FINAL_DIV_BY_1(1) | PLL_FINAL_DIV(0)); | ||||||
|  |   } else { | ||||||
|  |    | ||||||
|  |     // To overclock, use the hfrosc
 | ||||||
|  |     if (hfrosctrim >= 0 && hfroscdiv >= 0) { | ||||||
|  |       PRCI_use_hfrosc(hfroscdiv, hfrosctrim); | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     // Set DIV Settings for PLL
 | ||||||
|  |      | ||||||
|  |     // (Legal values of f_REF are 6-48MHz)
 | ||||||
|  | 
 | ||||||
|  |     // Set DIVR to divide-by-2 to get 8MHz frequency
 | ||||||
|  |     // (legal values of f_R are 6-12 MHz)
 | ||||||
|  | 
 | ||||||
|  |     config_value |= PLL_BYPASS(1); | ||||||
|  |     config_value |= PLL_R(r); | ||||||
|  | 
 | ||||||
|  |     // Set DIVF to get 512Mhz frequncy
 | ||||||
|  |     // There is an implied multiply-by-2, 16Mhz.
 | ||||||
|  |     // So need to write 32-1
 | ||||||
|  |     // (legal values of f_F are 384-768 MHz)
 | ||||||
|  |     config_value |= PLL_F(f); | ||||||
|  | 
 | ||||||
|  |     // Set DIVQ to divide-by-2 to get 256 MHz frequency
 | ||||||
|  |     // (legal values of f_Q are 50-400Mhz)
 | ||||||
|  |     config_value |= PLL_Q(q); | ||||||
|  | 
 | ||||||
|  |     // Set our Final output divide to divide-by-1:
 | ||||||
|  |     if (finaldiv == 1){ | ||||||
|  |       PRCI_REG(PRCI_PLLDIV) = (PLL_FINAL_DIV_BY_1(1) | PLL_FINAL_DIV(0)); | ||||||
|  |     } else { | ||||||
|  |       PRCI_REG(PRCI_PLLDIV) = (PLL_FINAL_DIV(finaldiv-1)); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     PRCI_REG(PRCI_PLLCFG) = config_value; | ||||||
|  | 
 | ||||||
|  |     // Un-Bypass the PLL.
 | ||||||
|  |     PRCI_REG(PRCI_PLLCFG) &= ~PLL_BYPASS(1); | ||||||
|  | 
 | ||||||
|  |     // Wait for PLL Lock
 | ||||||
|  |     // Note that the Lock signal can be glitchy.
 | ||||||
|  |     // Need to wait 100 us
 | ||||||
|  |     // RTC is running at 32kHz.
 | ||||||
|  |     // So wait 4 ticks of RTC.
 | ||||||
|  |     uint32_t now = CLINT_REG(CLINT_MTIME); | ||||||
|  |     while (CLINT_REG(CLINT_MTIME) - now < 4) ; | ||||||
|  |      | ||||||
|  |     // Now it is safe to check for PLL Lock
 | ||||||
|  |     while ((PRCI_REG(PRCI_PLLCFG) & PLL_LOCK(1)) == 0); | ||||||
|  | 
 | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   // Switch over to PLL Clock source
 | ||||||
|  |   PRCI_REG(PRCI_PLLCFG) |= PLL_SEL(1); | ||||||
|  | 
 | ||||||
|  |   // If we're running off HFXOSC, turn off the HFROSC to
 | ||||||
|  |   // save power.
 | ||||||
|  |   if (refsel) { | ||||||
|  |     PRCI_REG(PRCI_HFROSCCFG) &= ~ROSC_EN(1); | ||||||
|  |   } | ||||||
|  |    | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void PRCI_use_default_clocks() | ||||||
|  | { | ||||||
|  |   // Turn off the LFROSC
 | ||||||
|  |   AON_REG(AON_LFROSC) &= ~ROSC_EN(1); | ||||||
|  | 
 | ||||||
|  |   // Use HFROSC
 | ||||||
|  |   PRCI_use_hfrosc(4, 16); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void PRCI_use_hfxosc(uint32_t finaldiv) | ||||||
|  | { | ||||||
|  |    | ||||||
|  |   PRCI_use_pll(1, // Use HFXTAL
 | ||||||
|  | 	       1, // Bypass = 1
 | ||||||
|  | 	       0, // PLL settings don't matter
 | ||||||
|  | 	       0, // PLL settings don't matter
 | ||||||
|  | 	       0, // PLL settings don't matter
 | ||||||
|  | 	       finaldiv, | ||||||
|  | 	       -1, | ||||||
|  | 	       -1); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // This is a generic function, which
 | ||||||
|  | // doesn't span the entire range of HFROSC settings.
 | ||||||
|  | // It only adjusts the trim, which can span a hundred MHz or so.
 | ||||||
|  | // This function does not check the legality of the PLL settings
 | ||||||
|  | // at all, and it is quite possible to configure invalid PLL settings
 | ||||||
|  | // this way.
 | ||||||
|  | // It returns the actual measured CPU frequency.
 | ||||||
|  | 
 | ||||||
|  | uint32_t PRCI_set_hfrosctrim_for_f_cpu(uint32_t f_cpu, PRCI_freq_target target ) | ||||||
|  | { | ||||||
|  | 
 | ||||||
|  |   uint32_t hfrosctrim = 0; | ||||||
|  |   uint32_t hfroscdiv = 4; | ||||||
|  |   uint32_t prev_trim = 0; | ||||||
|  | 
 | ||||||
|  |   // In this function we use PLL settings which
 | ||||||
|  |   // will give us a 32x multiplier from the output
 | ||||||
|  |   // of the HFROSC source to the output of the
 | ||||||
|  |   // PLL. We first measure our HFROSC to get the
 | ||||||
|  |   // right trim, then finally use it as the PLL source.
 | ||||||
|  |   // We should really check here that the f_cpu
 | ||||||
|  |   // requested is something in the limit of the PLL. For
 | ||||||
|  |   // now that is up to the user.
 | ||||||
|  | 
 | ||||||
|  |   // This will undershoot for frequencies not divisible by 16.
 | ||||||
|  |   uint32_t desired_hfrosc_freq = (f_cpu/ 16); | ||||||
|  | 
 | ||||||
|  |   PRCI_use_hfrosc(hfroscdiv, hfrosctrim); | ||||||
|  |    | ||||||
|  |   // Ignore the first run (for icache reasons)
 | ||||||
|  |   uint32_t cpu_freq = PRCI_measure_mcycle_freq(3000, RTC_FREQ); | ||||||
|  | 
 | ||||||
|  |   cpu_freq = PRCI_measure_mcycle_freq(3000, RTC_FREQ); | ||||||
|  |   uint32_t prev_freq = cpu_freq; | ||||||
|  |    | ||||||
|  |   while ((cpu_freq < desired_hfrosc_freq) && (hfrosctrim < 0x1F)){ | ||||||
|  |     prev_trim = hfrosctrim; | ||||||
|  |     prev_freq = cpu_freq; | ||||||
|  |     hfrosctrim ++; | ||||||
|  |     PRCI_use_hfrosc(hfroscdiv, hfrosctrim); | ||||||
|  |     cpu_freq = PRCI_measure_mcycle_freq(3000, RTC_FREQ); | ||||||
|  |   }  | ||||||
|  | 
 | ||||||
|  |   // We couldn't go low enough
 | ||||||
|  |   if (prev_freq > desired_hfrosc_freq){ | ||||||
|  |     PRCI_use_pll(0, 0, 1, 31, 1, 1, hfroscdiv, prev_trim); | ||||||
|  |     cpu_freq = PRCI_measure_mcycle_freq(1000, RTC_FREQ); | ||||||
|  |     return cpu_freq; | ||||||
|  |   } | ||||||
|  |    | ||||||
|  |   // We couldn't go high enough
 | ||||||
|  |   if (cpu_freq < desired_hfrosc_freq){ | ||||||
|  |     PRCI_use_pll(0, 0, 1, 31, 1, 1, hfroscdiv, prev_trim); | ||||||
|  |     cpu_freq = PRCI_measure_mcycle_freq(1000, RTC_FREQ); | ||||||
|  |     return cpu_freq; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   // Check for over/undershoot
 | ||||||
|  |   switch(target) { | ||||||
|  |   case(PRCI_FREQ_CLOSEST): | ||||||
|  |     if ((desired_hfrosc_freq - prev_freq) < (cpu_freq - desired_hfrosc_freq)) { | ||||||
|  |       PRCI_use_pll(0, 0, 1, 31, 1, 1, hfroscdiv, prev_trim); | ||||||
|  |     } else { | ||||||
|  |       PRCI_use_pll(0, 0, 1, 31, 1, 1, hfroscdiv, hfrosctrim); | ||||||
|  |     } | ||||||
|  |     break; | ||||||
|  |   case(PRCI_FREQ_UNDERSHOOT): | ||||||
|  |     PRCI_use_pll(0, 0, 1, 31, 1, 1, hfroscdiv, prev_trim); | ||||||
|  |     break; | ||||||
|  |   default: | ||||||
|  |     PRCI_use_pll(0, 0, 1, 31, 1, 1, hfroscdiv, hfrosctrim); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   cpu_freq =  PRCI_measure_mcycle_freq(1000, RTC_FREQ); | ||||||
|  |   return cpu_freq; | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #endif | ||||||
|  | @ -0,0 +1,79 @@ | ||||||
|  | // See LICENSE file for license details
 | ||||||
|  | 
 | ||||||
|  | #ifndef _FE300PRCI_DRIVER_H_ | ||||||
|  | #define _FE300PRCI_DRIVER_H_ | ||||||
|  | 
 | ||||||
|  | __BEGIN_DECLS | ||||||
|  | 
 | ||||||
|  | #include <unistd.h> | ||||||
|  | 
 | ||||||
|  | typedef enum prci_freq_target { | ||||||
|  |    | ||||||
|  |   PRCI_FREQ_OVERSHOOT, | ||||||
|  |   PRCI_FREQ_CLOSEST, | ||||||
|  |   PRCI_FREQ_UNDERSHOOT | ||||||
|  | 
 | ||||||
|  | } PRCI_freq_target; | ||||||
|  | 
 | ||||||
|  | /* Measure and return the approximate frequency of the 
 | ||||||
|  |  * CPU, as given by measuring the mcycle counter against  | ||||||
|  |  * the mtime ticks. | ||||||
|  |  */ | ||||||
|  | uint32_t PRCI_measure_mcycle_freq(uint32_t mtime_ticks, uint32_t mtime_freq); | ||||||
|  | 
 | ||||||
|  | /* Safely switch over to the HFROSC using the given div
 | ||||||
|  |  * and trim settings. | ||||||
|  |  */ | ||||||
|  | void PRCI_use_hfrosc(int div, int trim); | ||||||
|  | 
 | ||||||
|  | /* Safely switch over to the 16MHz HFXOSC,
 | ||||||
|  |  * applying the finaldiv clock divider (1 is the lowest | ||||||
|  |  * legal value). | ||||||
|  |  */ | ||||||
|  | void PRCI_use_hfxosc(uint32_t finaldiv); | ||||||
|  | 
 | ||||||
|  | /* Safely switch over to the PLL using the given
 | ||||||
|  |  * settings. | ||||||
|  |  *  | ||||||
|  |  * Note that not all combinations of the inputs are actually | ||||||
|  |  * legal, and this function does not check for their | ||||||
|  |  * legality ("safely" means that this function won't turn off | ||||||
|  |  * or glitch the clock the CPU is actually running off, but | ||||||
|  |  * doesn't protect against you making it too fast or slow.) | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | void PRCI_use_pll(int refsel, int bypass, | ||||||
|  | 			 int r, int f, int q, int finaldiv, | ||||||
|  | 			 int hfroscdiv, int hfrosctrim); | ||||||
|  | 
 | ||||||
|  | /* Use the default clocks configured at reset.
 | ||||||
|  |  * This is ~16Mhz HFROSC and turns off the LFROSC | ||||||
|  |  * (on the current FE310 Dev Platforms, an external LFROSC is  | ||||||
|  |  * used as it is more power efficient). | ||||||
|  |  */ | ||||||
|  | void PRCI_use_default_clocks(); | ||||||
|  | 
 | ||||||
|  | /* This routine will adjust the HFROSC trim
 | ||||||
|  |  * while using HFROSC as the clock source,  | ||||||
|  |  * measure the resulting frequency, then | ||||||
|  |  * use it as the PLL clock source,  | ||||||
|  |  * in an attempt to get over, under, or close to the  | ||||||
|  |  * requested frequency. It returns the actual measured  | ||||||
|  |  * frequency.  | ||||||
|  |  * | ||||||
|  |  * Note that the requested frequency must be within the  | ||||||
|  |  * range supported by the PLL so not all values are  | ||||||
|  |  * achievable with this function, and not all  | ||||||
|  |  * are guaranteed to actually work. The PLL | ||||||
|  |  * is rated higher than the hardware. | ||||||
|  |  *  | ||||||
|  |  * There is no check on the desired f_cpu frequency, it | ||||||
|  |  * is up to the user to specify something reasonable. | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | uint32_t PRCI_set_hfrosctrim_for_f_cpu(uint32_t f_cpu, PRCI_freq_target target); | ||||||
|  | 
 | ||||||
|  | __END_DECLS | ||||||
|  | 
 | ||||||
|  | #endif | ||||||
|  |    | ||||||
|  | @ -0,0 +1,127 @@ | ||||||
|  | // See LICENSE for license details.
 | ||||||
|  | 
 | ||||||
|  | #include "sifive/devices/plic.h" | ||||||
|  | #include "plic/plic_driver.h" | ||||||
|  | #include "platform.h" | ||||||
|  | #include "encoding.h" | ||||||
|  | #include <string.h> | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | // Note that there are no assertions or bounds checking on these
 | ||||||
|  | // parameter values.
 | ||||||
|  | 
 | ||||||
|  | void volatile_memzero(uint8_t * base, unsigned int size) | ||||||
|  | { | ||||||
|  |   volatile uint8_t * ptr; | ||||||
|  |   for (ptr = base; ptr < (base + size); ptr++){ | ||||||
|  |     *ptr = 0; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void PLIC_init ( | ||||||
|  |                 plic_instance_t * this_plic, | ||||||
|  |                 uintptr_t         base_addr, | ||||||
|  |                 uint32_t num_sources, | ||||||
|  |                 uint32_t num_priorities | ||||||
|  |                 ) | ||||||
|  | { | ||||||
|  |    | ||||||
|  |   this_plic->base_addr = base_addr; | ||||||
|  |   this_plic->num_sources = num_sources; | ||||||
|  |   this_plic->num_priorities = num_priorities; | ||||||
|  |    | ||||||
|  |   // Disable all interrupts (don't assume that these registers are reset).
 | ||||||
|  |   unsigned long hart_id = read_csr(mhartid); | ||||||
|  |   volatile_memzero((uint8_t*) (this_plic->base_addr + | ||||||
|  |                                PLIC_ENABLE_OFFSET + | ||||||
|  |                                (hart_id << PLIC_ENABLE_SHIFT_PER_TARGET)), | ||||||
|  |                    (num_sources + 8) / 8); | ||||||
|  |    | ||||||
|  |   // Set all priorities to 0 (equal priority -- don't assume that these are reset).
 | ||||||
|  |   volatile_memzero ((uint8_t *)(this_plic->base_addr + | ||||||
|  |                                 PLIC_PRIORITY_OFFSET), | ||||||
|  |                     (num_sources + 1) << PLIC_PRIORITY_SHIFT_PER_SOURCE); | ||||||
|  | 
 | ||||||
|  |   // Set the threshold to 0.
 | ||||||
|  |   volatile plic_threshold* threshold = (plic_threshold*) | ||||||
|  |     (this_plic->base_addr + | ||||||
|  |      PLIC_THRESHOLD_OFFSET + | ||||||
|  |      (hart_id << PLIC_THRESHOLD_SHIFT_PER_TARGET)); | ||||||
|  | 
 | ||||||
|  |   *threshold = 0; | ||||||
|  |    | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void PLIC_set_threshold (plic_instance_t * this_plic, | ||||||
|  | 			 plic_threshold threshold){ | ||||||
|  | 
 | ||||||
|  |   unsigned long hart_id = read_csr(mhartid);   | ||||||
|  |   volatile plic_threshold* threshold_ptr = (plic_threshold*) (this_plic->base_addr + | ||||||
|  |                                                               PLIC_THRESHOLD_OFFSET + | ||||||
|  |                                                               (hart_id << PLIC_THRESHOLD_SHIFT_PER_TARGET)); | ||||||
|  | 
 | ||||||
|  |   *threshold_ptr = threshold; | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  |    | ||||||
|  | 
 | ||||||
|  | void PLIC_enable_interrupt (plic_instance_t * this_plic, plic_source source){ | ||||||
|  | 
 | ||||||
|  |   unsigned long hart_id = read_csr(mhartid); | ||||||
|  |   volatile uint8_t * current_ptr = (volatile uint8_t *)(this_plic->base_addr + | ||||||
|  |                                                         PLIC_ENABLE_OFFSET + | ||||||
|  |                                                         (hart_id << PLIC_ENABLE_SHIFT_PER_TARGET) + | ||||||
|  |                                                         (source >> 3)); | ||||||
|  |   uint8_t current = *current_ptr; | ||||||
|  |   current = current | ( 1 << (source & 0x7)); | ||||||
|  |   *current_ptr = current; | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void PLIC_disable_interrupt (plic_instance_t * this_plic, plic_source source){ | ||||||
|  |    | ||||||
|  |   unsigned long hart_id = read_csr(mhartid); | ||||||
|  |   volatile uint8_t * current_ptr = (volatile uint8_t *) (this_plic->base_addr + | ||||||
|  |                                                          PLIC_ENABLE_OFFSET + | ||||||
|  |                                                          (hart_id << PLIC_ENABLE_SHIFT_PER_TARGET) + | ||||||
|  |                                                          (source >> 3)); | ||||||
|  |   uint8_t current = *current_ptr; | ||||||
|  |   current = current & ~(( 1 << (source & 0x7))); | ||||||
|  |   *current_ptr = current; | ||||||
|  |    | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void PLIC_set_priority (plic_instance_t * this_plic, plic_source source, plic_priority priority){ | ||||||
|  | 
 | ||||||
|  |   if (this_plic->num_priorities > 0) { | ||||||
|  |     volatile plic_priority * priority_ptr = (volatile plic_priority *) | ||||||
|  |       (this_plic->base_addr + | ||||||
|  |        PLIC_PRIORITY_OFFSET + | ||||||
|  |        (source << PLIC_PRIORITY_SHIFT_PER_SOURCE)); | ||||||
|  |     *priority_ptr = priority; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | plic_source PLIC_claim_interrupt(plic_instance_t * this_plic){ | ||||||
|  |    | ||||||
|  |   unsigned long hart_id = read_csr(mhartid); | ||||||
|  | 
 | ||||||
|  |   volatile plic_source * claim_addr = (volatile plic_source * ) | ||||||
|  |     (this_plic->base_addr + | ||||||
|  |      PLIC_CLAIM_OFFSET + | ||||||
|  |      (hart_id << PLIC_CLAIM_SHIFT_PER_TARGET)); | ||||||
|  | 
 | ||||||
|  |   return  *claim_addr; | ||||||
|  |    | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void PLIC_complete_interrupt(plic_instance_t * this_plic, plic_source source){ | ||||||
|  |    | ||||||
|  |   unsigned long hart_id = read_csr(mhartid); | ||||||
|  |   volatile plic_source * claim_addr = (volatile plic_source *) (this_plic->base_addr + | ||||||
|  |                                                                 PLIC_CLAIM_OFFSET + | ||||||
|  |                                                                 (hart_id << PLIC_CLAIM_SHIFT_PER_TARGET)); | ||||||
|  |   *claim_addr = source; | ||||||
|  |    | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | @ -0,0 +1,51 @@ | ||||||
|  | // See LICENSE file for licence details
 | ||||||
|  | 
 | ||||||
|  | #ifndef PLIC_DRIVER_H | ||||||
|  | #define PLIC_DRIVER_H | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | __BEGIN_DECLS | ||||||
|  | 
 | ||||||
|  | #include "platform.h" | ||||||
|  | 
 | ||||||
|  | typedef struct __plic_instance_t | ||||||
|  | { | ||||||
|  |   uintptr_t base_addr; | ||||||
|  | 
 | ||||||
|  |   uint32_t num_sources; | ||||||
|  |   uint32_t num_priorities; | ||||||
|  |    | ||||||
|  | } plic_instance_t; | ||||||
|  | 
 | ||||||
|  | typedef uint32_t plic_source; | ||||||
|  | typedef uint32_t plic_priority; | ||||||
|  | typedef uint32_t plic_threshold; | ||||||
|  | 
 | ||||||
|  | void PLIC_init ( | ||||||
|  |                 plic_instance_t * this_plic, | ||||||
|  |                 uintptr_t         base_addr, | ||||||
|  |                 uint32_t num_sources, | ||||||
|  |                 uint32_t num_priorities | ||||||
|  |                 ); | ||||||
|  | 
 | ||||||
|  | void PLIC_set_threshold (plic_instance_t * this_plic, | ||||||
|  | 			 plic_threshold threshold); | ||||||
|  |    | ||||||
|  | void PLIC_enable_interrupt (plic_instance_t * this_plic, | ||||||
|  | 			    plic_source source); | ||||||
|  | 
 | ||||||
|  | void PLIC_disable_interrupt (plic_instance_t * this_plic, | ||||||
|  | 			     plic_source source); | ||||||
|  |    | ||||||
|  | void PLIC_set_priority (plic_instance_t * this_plic, | ||||||
|  | 			plic_source source, | ||||||
|  | 			plic_priority priority); | ||||||
|  | 
 | ||||||
|  | plic_source PLIC_claim_interrupt(plic_instance_t * this_plic); | ||||||
|  | 
 | ||||||
|  | void PLIC_complete_interrupt(plic_instance_t * this_plic, | ||||||
|  | 			     plic_source source); | ||||||
|  | 
 | ||||||
|  | __END_DECLS | ||||||
|  | 
 | ||||||
|  | #endif | ||||||
							
								
								
									
										1313
									
								
								FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/freedom-e-sdk/env/encoding.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1313
									
								
								FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/freedom-e-sdk/env/encoding.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										98
									
								
								FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/freedom-e-sdk/env/entry.S
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										98
									
								
								FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/freedom-e-sdk/env/entry.S
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,98 @@ | ||||||
|  | // See LICENSE for license details | ||||||
|  | 
 | ||||||
|  | #ifndef ENTRY_S | ||||||
|  | #define ENTRY_S | ||||||
|  | 
 | ||||||
|  | #include "encoding.h" | ||||||
|  | #include "sifive/bits.h" | ||||||
|  | 
 | ||||||
|  |   .section      .text.entry	 | ||||||
|  |   .align 2
 | ||||||
|  |   .weak trap_entry
 | ||||||
|  |   .global trap_entry
 | ||||||
|  | trap_entry: | ||||||
|  |   addi sp, sp, -32*REGBYTES | ||||||
|  | 
 | ||||||
|  |   STORE x1, 1*REGBYTES(sp) | ||||||
|  |   STORE x2, 2*REGBYTES(sp) | ||||||
|  |   STORE x3, 3*REGBYTES(sp) | ||||||
|  |   STORE x4, 4*REGBYTES(sp) | ||||||
|  |   STORE x5, 5*REGBYTES(sp) | ||||||
|  |   STORE x6, 6*REGBYTES(sp) | ||||||
|  |   STORE x7, 7*REGBYTES(sp) | ||||||
|  |   STORE x8, 8*REGBYTES(sp) | ||||||
|  |   STORE x9, 9*REGBYTES(sp) | ||||||
|  |   STORE x10, 10*REGBYTES(sp) | ||||||
|  |   STORE x11, 11*REGBYTES(sp) | ||||||
|  |   STORE x12, 12*REGBYTES(sp) | ||||||
|  |   STORE x13, 13*REGBYTES(sp) | ||||||
|  |   STORE x14, 14*REGBYTES(sp) | ||||||
|  |   STORE x15, 15*REGBYTES(sp) | ||||||
|  |   STORE x16, 16*REGBYTES(sp) | ||||||
|  |   STORE x17, 17*REGBYTES(sp) | ||||||
|  |   STORE x18, 18*REGBYTES(sp) | ||||||
|  |   STORE x19, 19*REGBYTES(sp) | ||||||
|  |   STORE x20, 20*REGBYTES(sp) | ||||||
|  |   STORE x21, 21*REGBYTES(sp) | ||||||
|  |   STORE x22, 22*REGBYTES(sp) | ||||||
|  |   STORE x23, 23*REGBYTES(sp) | ||||||
|  |   STORE x24, 24*REGBYTES(sp) | ||||||
|  |   STORE x25, 25*REGBYTES(sp) | ||||||
|  |   STORE x26, 26*REGBYTES(sp) | ||||||
|  |   STORE x27, 27*REGBYTES(sp) | ||||||
|  |   STORE x28, 28*REGBYTES(sp) | ||||||
|  |   STORE x29, 29*REGBYTES(sp) | ||||||
|  |   STORE x30, 30*REGBYTES(sp) | ||||||
|  |   STORE x31, 31*REGBYTES(sp) | ||||||
|  | 
 | ||||||
|  |   csrr a0, mcause | ||||||
|  |   csrr a1, mepc | ||||||
|  |   mv a2, sp | ||||||
|  |   call handle_trap | ||||||
|  |   csrw mepc, a0 | ||||||
|  | 
 | ||||||
|  |   # Remain in M-mode after mret | ||||||
|  |   li t0, MSTATUS_MPP | ||||||
|  |   csrs mstatus, t0 | ||||||
|  | 
 | ||||||
|  |   LOAD x1, 1*REGBYTES(sp) | ||||||
|  |   LOAD x2, 2*REGBYTES(sp) | ||||||
|  |   LOAD x3, 3*REGBYTES(sp) | ||||||
|  |   LOAD x4, 4*REGBYTES(sp) | ||||||
|  |   LOAD x5, 5*REGBYTES(sp) | ||||||
|  |   LOAD x6, 6*REGBYTES(sp) | ||||||
|  |   LOAD x7, 7*REGBYTES(sp) | ||||||
|  |   LOAD x8, 8*REGBYTES(sp) | ||||||
|  |   LOAD x9, 9*REGBYTES(sp) | ||||||
|  |   LOAD x10, 10*REGBYTES(sp) | ||||||
|  |   LOAD x11, 11*REGBYTES(sp) | ||||||
|  |   LOAD x12, 12*REGBYTES(sp) | ||||||
|  |   LOAD x13, 13*REGBYTES(sp) | ||||||
|  |   LOAD x14, 14*REGBYTES(sp) | ||||||
|  |   LOAD x15, 15*REGBYTES(sp) | ||||||
|  |   LOAD x16, 16*REGBYTES(sp) | ||||||
|  |   LOAD x17, 17*REGBYTES(sp) | ||||||
|  |   LOAD x18, 18*REGBYTES(sp) | ||||||
|  |   LOAD x19, 19*REGBYTES(sp) | ||||||
|  |   LOAD x20, 20*REGBYTES(sp) | ||||||
|  |   LOAD x21, 21*REGBYTES(sp) | ||||||
|  |   LOAD x22, 22*REGBYTES(sp) | ||||||
|  |   LOAD x23, 23*REGBYTES(sp) | ||||||
|  |   LOAD x24, 24*REGBYTES(sp) | ||||||
|  |   LOAD x25, 25*REGBYTES(sp) | ||||||
|  |   LOAD x26, 26*REGBYTES(sp) | ||||||
|  |   LOAD x27, 27*REGBYTES(sp) | ||||||
|  |   LOAD x28, 28*REGBYTES(sp) | ||||||
|  |   LOAD x29, 29*REGBYTES(sp) | ||||||
|  |   LOAD x30, 30*REGBYTES(sp) | ||||||
|  |   LOAD x31, 31*REGBYTES(sp) | ||||||
|  | 
 | ||||||
|  |   addi sp, sp, 32*REGBYTES | ||||||
|  |   mret | ||||||
|  | 
 | ||||||
|  | .weak handle_trap
 | ||||||
|  | handle_trap: | ||||||
|  | 1: | ||||||
|  |   j 1b | ||||||
|  | 	 | ||||||
|  | #endif | ||||||
|  | @ -0,0 +1,157 @@ | ||||||
|  | OUTPUT_ARCH( "riscv" ) | ||||||
|  | 
 | ||||||
|  | ENTRY( _start ) | ||||||
|  | 
 | ||||||
|  | MEMORY | ||||||
|  | { | ||||||
|  |   flash (rxai!w) : ORIGIN = 0x20400000, LENGTH = 512M | ||||||
|  |   ram (wxa!ri) : ORIGIN = 0x80000000, LENGTH = 16K | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | PHDRS | ||||||
|  | { | ||||||
|  |   flash PT_LOAD; | ||||||
|  |   ram_init PT_LOAD; | ||||||
|  |   ram PT_NULL; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | SECTIONS | ||||||
|  | { | ||||||
|  |   __stack_size = DEFINED(__stack_size) ? __stack_size : 2K; | ||||||
|  | 
 | ||||||
|  |   .init           : | ||||||
|  |   { | ||||||
|  |     KEEP (*(SORT_NONE(.init))) | ||||||
|  |   } >flash AT>flash :flash | ||||||
|  | 
 | ||||||
|  |   .text           : | ||||||
|  |   { | ||||||
|  |     *(.text.unlikely .text.unlikely.*) | ||||||
|  |     *(.text.startup .text.startup.*) | ||||||
|  |     *(.text .text.*) | ||||||
|  |     *(.gnu.linkonce.t.*) | ||||||
|  |   } >flash AT>flash :flash | ||||||
|  | 
 | ||||||
|  |   .fini           : | ||||||
|  |   { | ||||||
|  |     KEEP (*(SORT_NONE(.fini))) | ||||||
|  |   } >flash AT>flash :flash | ||||||
|  | 
 | ||||||
|  |   PROVIDE (__etext = .); | ||||||
|  |   PROVIDE (_etext = .); | ||||||
|  |   PROVIDE (etext = .); | ||||||
|  | 
 | ||||||
|  |   . = ALIGN(4); | ||||||
|  | 
 | ||||||
|  |   .preinit_array  : | ||||||
|  |   { | ||||||
|  |     PROVIDE_HIDDEN (__preinit_array_start = .); | ||||||
|  |     KEEP (*(.preinit_array)) | ||||||
|  |     PROVIDE_HIDDEN (__preinit_array_end = .); | ||||||
|  |   } >flash AT>flash :flash | ||||||
|  | 
 | ||||||
|  |   .init_array     : | ||||||
|  |   { | ||||||
|  |     PROVIDE_HIDDEN (__init_array_start = .); | ||||||
|  |     KEEP (*(SORT_BY_INIT_PRIORITY(.init_array.*) SORT_BY_INIT_PRIORITY(.ctors.*))) | ||||||
|  |     KEEP (*(.init_array EXCLUDE_FILE (*crtbegin.o *crtbegin?.o *crtend.o *crtend?.o ) .ctors)) | ||||||
|  |     PROVIDE_HIDDEN (__init_array_end = .); | ||||||
|  |   } >flash AT>flash :flash | ||||||
|  | 
 | ||||||
|  |   .fini_array     : | ||||||
|  |   { | ||||||
|  |     PROVIDE_HIDDEN (__fini_array_start = .); | ||||||
|  |     KEEP (*(SORT_BY_INIT_PRIORITY(.fini_array.*) SORT_BY_INIT_PRIORITY(.dtors.*))) | ||||||
|  |     KEEP (*(.fini_array EXCLUDE_FILE (*crtbegin.o *crtbegin?.o *crtend.o *crtend?.o ) .dtors)) | ||||||
|  |     PROVIDE_HIDDEN (__fini_array_end = .); | ||||||
|  |   } >flash AT>flash :flash | ||||||
|  | 
 | ||||||
|  |   .ctors          : | ||||||
|  |   { | ||||||
|  |     /* gcc uses crtbegin.o to find the start of | ||||||
|  |        the constructors, so we make sure it is | ||||||
|  |        first.  Because this is a wildcard, it | ||||||
|  |        doesn't matter if the user does not | ||||||
|  |        actually link against crtbegin.o; the | ||||||
|  |        linker won't look for a file to match a | ||||||
|  |        wildcard.  The wildcard also means that it | ||||||
|  |        doesn't matter which directory crtbegin.o | ||||||
|  |        is in.  */ | ||||||
|  |     KEEP (*crtbegin.o(.ctors)) | ||||||
|  |     KEEP (*crtbegin?.o(.ctors)) | ||||||
|  |     /* We don't want to include the .ctor section from | ||||||
|  |        the crtend.o file until after the sorted ctors. | ||||||
|  |        The .ctor section from the crtend file contains the | ||||||
|  |        end of ctors marker and it must be last */ | ||||||
|  |     KEEP (*(EXCLUDE_FILE (*crtend.o *crtend?.o ) .ctors)) | ||||||
|  |     KEEP (*(SORT(.ctors.*))) | ||||||
|  |     KEEP (*(.ctors)) | ||||||
|  |   } >flash AT>flash :flash | ||||||
|  | 
 | ||||||
|  |   .dtors          : | ||||||
|  |   { | ||||||
|  |     KEEP (*crtbegin.o(.dtors)) | ||||||
|  |     KEEP (*crtbegin?.o(.dtors)) | ||||||
|  |     KEEP (*(EXCLUDE_FILE (*crtend.o *crtend?.o ) .dtors)) | ||||||
|  |     KEEP (*(SORT(.dtors.*))) | ||||||
|  |     KEEP (*(.dtors)) | ||||||
|  |   } >flash AT>flash :flash | ||||||
|  | 
 | ||||||
|  |   .lalign         : | ||||||
|  |   { | ||||||
|  |     . = ALIGN(4); | ||||||
|  |     PROVIDE( _data_lma = . ); | ||||||
|  |   } >flash AT>flash :flash | ||||||
|  | 
 | ||||||
|  |   .dalign         : | ||||||
|  |   { | ||||||
|  |     . = ALIGN(4); | ||||||
|  |     PROVIDE( _data = . ); | ||||||
|  |   } >ram AT>flash :ram_init | ||||||
|  | 
 | ||||||
|  |   .data          : | ||||||
|  |   { | ||||||
|  |     *(.rdata) | ||||||
|  |     *(.rodata .rodata.*) | ||||||
|  |     *(.gnu.linkonce.r.*) | ||||||
|  |     *(.data .data.*) | ||||||
|  |     *(.gnu.linkonce.d.*) | ||||||
|  |     . = ALIGN(8); | ||||||
|  |     PROVIDE( __global_pointer$ = . + 0x800 ); | ||||||
|  |     *(.sdata .sdata.*) | ||||||
|  |     *(.gnu.linkonce.s.*) | ||||||
|  |     . = ALIGN(8); | ||||||
|  |     *(.srodata.cst16) | ||||||
|  |     *(.srodata.cst8) | ||||||
|  |     *(.srodata.cst4) | ||||||
|  |     *(.srodata.cst2) | ||||||
|  |     *(.srodata .srodata.*) | ||||||
|  |   } >ram AT>flash :ram_init | ||||||
|  | 
 | ||||||
|  |   . = ALIGN(4); | ||||||
|  |   PROVIDE( _edata = . ); | ||||||
|  |   PROVIDE( edata = . ); | ||||||
|  | 
 | ||||||
|  |   PROVIDE( _fbss = . ); | ||||||
|  |   PROVIDE( __bss_start = . ); | ||||||
|  |   .bss            : | ||||||
|  |   { | ||||||
|  |     *(.sbss*) | ||||||
|  |     *(.gnu.linkonce.sb.*) | ||||||
|  |     *(.bss .bss.*) | ||||||
|  |     *(.gnu.linkonce.b.*) | ||||||
|  |     *(COMMON) | ||||||
|  |     . = ALIGN(4); | ||||||
|  |   } >ram AT>ram :ram | ||||||
|  | 
 | ||||||
|  |   . = ALIGN(8); | ||||||
|  |   PROVIDE( _end = . ); | ||||||
|  |   PROVIDE( end = . ); | ||||||
|  | 
 | ||||||
|  |   .stack ORIGIN(ram) + LENGTH(ram) - __stack_size : | ||||||
|  |   { | ||||||
|  |     PROVIDE( _heap_end = . ); | ||||||
|  |     . = __stack_size; | ||||||
|  |     PROVIDE( _sp = . ); | ||||||
|  |   } >ram AT>ram :ram | ||||||
|  | } | ||||||
							
								
								
									
										161
									
								
								FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/freedom-e-sdk/env/freedom-e300-hifive1/flash.lds
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										161
									
								
								FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/freedom-e-sdk/env/freedom-e300-hifive1/flash.lds
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,161 @@ | ||||||
|  | OUTPUT_ARCH( "riscv" ) | ||||||
|  | 
 | ||||||
|  | ENTRY( _start ) | ||||||
|  | 
 | ||||||
|  | MEMORY | ||||||
|  | { | ||||||
|  |   flash (rxai!w) : ORIGIN = 0x20400000, LENGTH = 512M | ||||||
|  |   ram (wxa!ri) : ORIGIN = 0x80000000, LENGTH = 16K | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | PHDRS | ||||||
|  | { | ||||||
|  |   flash PT_LOAD; | ||||||
|  |   ram_init PT_LOAD; | ||||||
|  |   ram PT_NULL; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | SECTIONS | ||||||
|  | { | ||||||
|  |   __stack_size = DEFINED(__stack_size) ? __stack_size : 2K; | ||||||
|  | 
 | ||||||
|  |   .init           : | ||||||
|  |   { | ||||||
|  |     KEEP (*(SORT_NONE(.init))) | ||||||
|  |   } >flash AT>flash :flash | ||||||
|  | 
 | ||||||
|  |   .text           : | ||||||
|  |   { | ||||||
|  |     *(.text.unlikely .text.unlikely.*) | ||||||
|  |     *(.text.startup .text.startup.*) | ||||||
|  |     *(.text .text.*) | ||||||
|  |     *(.gnu.linkonce.t.*) | ||||||
|  |   } >flash AT>flash :flash | ||||||
|  | 
 | ||||||
|  |   .fini           : | ||||||
|  |   { | ||||||
|  |     KEEP (*(SORT_NONE(.fini))) | ||||||
|  |   } >flash AT>flash :flash | ||||||
|  | 
 | ||||||
|  |   PROVIDE (__etext = .); | ||||||
|  |   PROVIDE (_etext = .); | ||||||
|  |   PROVIDE (etext = .); | ||||||
|  | 
 | ||||||
|  |   .rodata         : | ||||||
|  |   { | ||||||
|  |     *(.rdata) | ||||||
|  |     *(.rodata .rodata.*) | ||||||
|  |     *(.gnu.linkonce.r.*) | ||||||
|  |   } >flash AT>flash :flash | ||||||
|  | 
 | ||||||
|  |   . = ALIGN(4); | ||||||
|  | 
 | ||||||
|  |   .preinit_array  : | ||||||
|  |   { | ||||||
|  |     PROVIDE_HIDDEN (__preinit_array_start = .); | ||||||
|  |     KEEP (*(.preinit_array)) | ||||||
|  |     PROVIDE_HIDDEN (__preinit_array_end = .); | ||||||
|  |   } >flash AT>flash :flash | ||||||
|  | 
 | ||||||
|  |   .init_array     : | ||||||
|  |   { | ||||||
|  |     PROVIDE_HIDDEN (__init_array_start = .); | ||||||
|  |     KEEP (*(SORT_BY_INIT_PRIORITY(.init_array.*) SORT_BY_INIT_PRIORITY(.ctors.*))) | ||||||
|  |     KEEP (*(.init_array EXCLUDE_FILE (*crtbegin.o *crtbegin?.o *crtend.o *crtend?.o ) .ctors)) | ||||||
|  |     PROVIDE_HIDDEN (__init_array_end = .); | ||||||
|  |   } >flash AT>flash :flash | ||||||
|  | 
 | ||||||
|  |   .fini_array     : | ||||||
|  |   { | ||||||
|  |     PROVIDE_HIDDEN (__fini_array_start = .); | ||||||
|  |     KEEP (*(SORT_BY_INIT_PRIORITY(.fini_array.*) SORT_BY_INIT_PRIORITY(.dtors.*))) | ||||||
|  |     KEEP (*(.fini_array EXCLUDE_FILE (*crtbegin.o *crtbegin?.o *crtend.o *crtend?.o ) .dtors)) | ||||||
|  |     PROVIDE_HIDDEN (__fini_array_end = .); | ||||||
|  |   } >flash AT>flash :flash | ||||||
|  | 
 | ||||||
|  |   .ctors          : | ||||||
|  |   { | ||||||
|  |     /* gcc uses crtbegin.o to find the start of | ||||||
|  |        the constructors, so we make sure it is | ||||||
|  |        first.  Because this is a wildcard, it | ||||||
|  |        doesn't matter if the user does not | ||||||
|  |        actually link against crtbegin.o; the | ||||||
|  |        linker won't look for a file to match a | ||||||
|  |        wildcard.  The wildcard also means that it | ||||||
|  |        doesn't matter which directory crtbegin.o | ||||||
|  |        is in.  */ | ||||||
|  |     KEEP (*crtbegin.o(.ctors)) | ||||||
|  |     KEEP (*crtbegin?.o(.ctors)) | ||||||
|  |     /* We don't want to include the .ctor section from | ||||||
|  |        the crtend.o file until after the sorted ctors. | ||||||
|  |        The .ctor section from the crtend file contains the | ||||||
|  |        end of ctors marker and it must be last */ | ||||||
|  |     KEEP (*(EXCLUDE_FILE (*crtend.o *crtend?.o ) .ctors)) | ||||||
|  |     KEEP (*(SORT(.ctors.*))) | ||||||
|  |     KEEP (*(.ctors)) | ||||||
|  |   } >flash AT>flash :flash | ||||||
|  | 
 | ||||||
|  |   .dtors          : | ||||||
|  |   { | ||||||
|  |     KEEP (*crtbegin.o(.dtors)) | ||||||
|  |     KEEP (*crtbegin?.o(.dtors)) | ||||||
|  |     KEEP (*(EXCLUDE_FILE (*crtend.o *crtend?.o ) .dtors)) | ||||||
|  |     KEEP (*(SORT(.dtors.*))) | ||||||
|  |     KEEP (*(.dtors)) | ||||||
|  |   } >flash AT>flash :flash | ||||||
|  | 
 | ||||||
|  |   .lalign         : | ||||||
|  |   { | ||||||
|  |     . = ALIGN(4); | ||||||
|  |     PROVIDE( _data_lma = . ); | ||||||
|  |   } >flash AT>flash :flash | ||||||
|  | 
 | ||||||
|  |   .dalign         : | ||||||
|  |   { | ||||||
|  |     . = ALIGN(4); | ||||||
|  |     PROVIDE( _data = . ); | ||||||
|  |   } >ram AT>flash :ram_init | ||||||
|  | 
 | ||||||
|  |   .data          : | ||||||
|  |   { | ||||||
|  |     *(.data .data.*) | ||||||
|  |     *(.gnu.linkonce.d.*) | ||||||
|  |     . = ALIGN(8); | ||||||
|  |     PROVIDE( __global_pointer$ = . + 0x800 ); | ||||||
|  |     *(.sdata .sdata.*) | ||||||
|  |     *(.gnu.linkonce.s.*) | ||||||
|  |     . = ALIGN(8); | ||||||
|  |     *(.srodata.cst16) | ||||||
|  |     *(.srodata.cst8) | ||||||
|  |     *(.srodata.cst4) | ||||||
|  |     *(.srodata.cst2) | ||||||
|  |     *(.srodata .srodata.*) | ||||||
|  |   } >ram AT>flash :ram_init | ||||||
|  | 
 | ||||||
|  |   . = ALIGN(4); | ||||||
|  |   PROVIDE( _edata = . ); | ||||||
|  |   PROVIDE( edata = . ); | ||||||
|  | 
 | ||||||
|  |   PROVIDE( _fbss = . ); | ||||||
|  |   PROVIDE( __bss_start = . ); | ||||||
|  |   .bss            : | ||||||
|  |   { | ||||||
|  |     *(.sbss*) | ||||||
|  |     *(.gnu.linkonce.sb.*) | ||||||
|  |     *(.bss .bss.*) | ||||||
|  |     *(.gnu.linkonce.b.*) | ||||||
|  |     *(COMMON) | ||||||
|  |     . = ALIGN(4); | ||||||
|  |   } >ram AT>ram :ram | ||||||
|  | 
 | ||||||
|  |   . = ALIGN(8); | ||||||
|  |   PROVIDE( _end = . ); | ||||||
|  |   PROVIDE( end = . ); | ||||||
|  | 
 | ||||||
|  |   .stack ORIGIN(ram) + LENGTH(ram) - __stack_size : | ||||||
|  |   { | ||||||
|  |     PROVIDE( _heap_end = . ); | ||||||
|  |     . = __stack_size; | ||||||
|  |     PROVIDE( _sp = . ); | ||||||
|  |   } >ram AT>ram :ram | ||||||
|  | } | ||||||
							
								
								
									
										238
									
								
								FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/freedom-e-sdk/env/freedom-e300-hifive1/init.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										238
									
								
								FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/freedom-e-sdk/env/freedom-e300-hifive1/init.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,238 @@ | ||||||
|  | #include <stdint.h> | ||||||
|  | #include <stdio.h> | ||||||
|  | #include <unistd.h> | ||||||
|  | 
 | ||||||
|  | #include "platform.h" | ||||||
|  | #include "encoding.h" | ||||||
|  | 
 | ||||||
|  | extern int main(int argc, char** argv); | ||||||
|  | extern void trap_entry(); | ||||||
|  | 
 | ||||||
|  | static unsigned long mtime_lo(void) | ||||||
|  | { | ||||||
|  |   return *(volatile unsigned long *)(CLINT_CTRL_ADDR + CLINT_MTIME); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #ifdef __riscv32 | ||||||
|  | 
 | ||||||
|  | static uint32_t mtime_hi(void) | ||||||
|  | { | ||||||
|  |   return *(volatile uint32_t *)(CLINT_CTRL_ADDR + CLINT_MTIME + 4); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | uint64_t get_timer_value() | ||||||
|  | { | ||||||
|  |   while (1) { | ||||||
|  |     uint32_t hi = mtime_hi(); | ||||||
|  |     uint32_t lo = mtime_lo(); | ||||||
|  |     if (hi == mtime_hi()) | ||||||
|  |       return ((uint64_t)hi << 32) | lo; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #else /* __riscv32 */ | ||||||
|  | 
 | ||||||
|  | uint64_t get_timer_value() | ||||||
|  | { | ||||||
|  |   return mtime_lo(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | unsigned long get_timer_freq() | ||||||
|  | { | ||||||
|  |   return 32768; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | static void use_hfrosc(int div, int trim) | ||||||
|  | { | ||||||
|  |   // Make sure the HFROSC is running at its default setting
 | ||||||
|  |   PRCI_REG(PRCI_HFROSCCFG) = (ROSC_DIV(div) | ROSC_TRIM(trim) | ROSC_EN(1)); | ||||||
|  |   while ((PRCI_REG(PRCI_HFROSCCFG) & ROSC_RDY(1)) == 0) ; | ||||||
|  |   PRCI_REG(PRCI_PLLCFG) &= ~PLL_SEL(1); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | static void use_pll(int refsel, int bypass, int r, int f, int q) | ||||||
|  | { | ||||||
|  |   // Ensure that we aren't running off the PLL before we mess with it.
 | ||||||
|  |   if (PRCI_REG(PRCI_PLLCFG) & PLL_SEL(1)) { | ||||||
|  |     // Make sure the HFROSC is running at its default setting
 | ||||||
|  |     use_hfrosc(4, 16); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   // Set PLL Source to be HFXOSC if available.
 | ||||||
|  |   uint32_t config_value = 0; | ||||||
|  | 
 | ||||||
|  |   config_value |= PLL_REFSEL(refsel); | ||||||
|  | 
 | ||||||
|  |   if (bypass) { | ||||||
|  |     // Bypass
 | ||||||
|  |     config_value |= PLL_BYPASS(1); | ||||||
|  | 
 | ||||||
|  |     PRCI_REG(PRCI_PLLCFG) = config_value; | ||||||
|  | 
 | ||||||
|  |     // If we don't have an HFXTAL, this doesn't really matter.
 | ||||||
|  |     // Set our Final output divide to divide-by-1:
 | ||||||
|  |     PRCI_REG(PRCI_PLLDIV) = (PLL_FINAL_DIV_BY_1(1) | PLL_FINAL_DIV(0)); | ||||||
|  |   } else { | ||||||
|  |     // In case we are executing from QSPI,
 | ||||||
|  |     // (which is quite likely) we need to
 | ||||||
|  |     // set the QSPI clock divider appropriately
 | ||||||
|  |     // before boosting the clock frequency.
 | ||||||
|  | 
 | ||||||
|  |     // Div = f_sck/2
 | ||||||
|  |     SPI0_REG(SPI_REG_SCKDIV) = 8; | ||||||
|  | 
 | ||||||
|  |     // Set DIV Settings for PLL
 | ||||||
|  |     // Both HFROSC and HFXOSC are modeled as ideal
 | ||||||
|  |     // 16MHz sources (assuming dividers are set properly for
 | ||||||
|  |     // HFROSC).
 | ||||||
|  |     // (Legal values of f_REF are 6-48MHz)
 | ||||||
|  | 
 | ||||||
|  |     // Set DIVR to divide-by-2 to get 8MHz frequency
 | ||||||
|  |     // (legal values of f_R are 6-12 MHz)
 | ||||||
|  | 
 | ||||||
|  |     config_value |= PLL_BYPASS(1); | ||||||
|  |     config_value |= PLL_R(r); | ||||||
|  | 
 | ||||||
|  |     // Set DIVF to get 512Mhz frequncy
 | ||||||
|  |     // There is an implied multiply-by-2, 16Mhz.
 | ||||||
|  |     // So need to write 32-1
 | ||||||
|  |     // (legal values of f_F are 384-768 MHz)
 | ||||||
|  |     config_value |= PLL_F(f); | ||||||
|  | 
 | ||||||
|  |     // Set DIVQ to divide-by-2 to get 256 MHz frequency
 | ||||||
|  |     // (legal values of f_Q are 50-400Mhz)
 | ||||||
|  |     config_value |= PLL_Q(q); | ||||||
|  | 
 | ||||||
|  |     // Set our Final output divide to divide-by-1:
 | ||||||
|  |     PRCI_REG(PRCI_PLLDIV) = (PLL_FINAL_DIV_BY_1(1) | PLL_FINAL_DIV(0)); | ||||||
|  | 
 | ||||||
|  |     PRCI_REG(PRCI_PLLCFG) = config_value; | ||||||
|  | 
 | ||||||
|  |     // Un-Bypass the PLL.
 | ||||||
|  |     PRCI_REG(PRCI_PLLCFG) &= ~PLL_BYPASS(1); | ||||||
|  | 
 | ||||||
|  |     // Wait for PLL Lock
 | ||||||
|  |     // Note that the Lock signal can be glitchy.
 | ||||||
|  |     // Need to wait 100 us
 | ||||||
|  |     // RTC is running at 32kHz.
 | ||||||
|  |     // So wait 4 ticks of RTC.
 | ||||||
|  |     uint32_t now = mtime_lo(); | ||||||
|  |     while (mtime_lo() - now < 4) ; | ||||||
|  | 
 | ||||||
|  |     // Now it is safe to check for PLL Lock
 | ||||||
|  |     while ((PRCI_REG(PRCI_PLLCFG) & PLL_LOCK(1)) == 0) ; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   // Switch over to PLL Clock source
 | ||||||
|  |   PRCI_REG(PRCI_PLLCFG) |= PLL_SEL(1); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | static void use_default_clocks() | ||||||
|  | { | ||||||
|  |   // Turn off the LFROSC
 | ||||||
|  |   AON_REG(AON_LFROSC) &= ~ROSC_EN(1); | ||||||
|  | 
 | ||||||
|  |   // Use HFROSC
 | ||||||
|  |   use_hfrosc(4, 16); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | static unsigned long __attribute__((noinline)) measure_cpu_freq(size_t n) | ||||||
|  | { | ||||||
|  |   unsigned long start_mtime, delta_mtime; | ||||||
|  |   unsigned long mtime_freq = get_timer_freq(); | ||||||
|  | 
 | ||||||
|  |   // Don't start measuruing until we see an mtime tick
 | ||||||
|  |   unsigned long tmp = mtime_lo(); | ||||||
|  |   do { | ||||||
|  |     start_mtime = mtime_lo(); | ||||||
|  |   } while (start_mtime == tmp); | ||||||
|  | 
 | ||||||
|  |   unsigned long start_mcycle = read_csr(mcycle); | ||||||
|  | 
 | ||||||
|  |   do { | ||||||
|  |     delta_mtime = mtime_lo() - start_mtime; | ||||||
|  |   } while (delta_mtime < n); | ||||||
|  | 
 | ||||||
|  |   unsigned long delta_mcycle = read_csr(mcycle) - start_mcycle; | ||||||
|  | 
 | ||||||
|  |   return (delta_mcycle / delta_mtime) * mtime_freq | ||||||
|  |          + ((delta_mcycle % delta_mtime) * mtime_freq) / delta_mtime; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | unsigned long get_cpu_freq() | ||||||
|  | { | ||||||
|  |   static uint32_t cpu_freq; | ||||||
|  | 
 | ||||||
|  |   if (!cpu_freq) { | ||||||
|  |     // warm up I$
 | ||||||
|  |     measure_cpu_freq(1); | ||||||
|  |     // measure for real
 | ||||||
|  |     cpu_freq = measure_cpu_freq(10); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   return cpu_freq; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | static void uart_init(size_t baud_rate) | ||||||
|  | { | ||||||
|  |   GPIO_REG(GPIO_IOF_SEL) &= ~IOF0_UART0_MASK; | ||||||
|  |   GPIO_REG(GPIO_IOF_EN) |= IOF0_UART0_MASK; | ||||||
|  |   UART0_REG(UART_REG_DIV) = get_cpu_freq() / baud_rate - 1; | ||||||
|  |   UART0_REG(UART_REG_TXCTRL) |= UART_TXEN; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | #ifdef USE_PLIC | ||||||
|  | extern void handle_m_ext_interrupt(); | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | #ifdef USE_M_TIME | ||||||
|  | extern void handle_m_time_interrupt(); | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | uintptr_t handle_trap(uintptr_t mcause, uintptr_t epc) | ||||||
|  | { | ||||||
|  |   if (0){ | ||||||
|  | #ifdef USE_PLIC | ||||||
|  |     // External Machine-Level interrupt from PLIC
 | ||||||
|  |   } else if ((mcause & MCAUSE_INT) && ((mcause & MCAUSE_CAUSE) == IRQ_M_EXT)) { | ||||||
|  |     handle_m_ext_interrupt(); | ||||||
|  | #endif | ||||||
|  | #ifdef USE_M_TIME | ||||||
|  |     // External Machine-Level interrupt from PLIC
 | ||||||
|  |   } else if ((mcause & MCAUSE_INT) && ((mcause & MCAUSE_CAUSE) == IRQ_M_TIMER)){ | ||||||
|  |     handle_m_time_interrupt(); | ||||||
|  | #endif | ||||||
|  |   } | ||||||
|  |   else { | ||||||
|  |     write(1, "trap\n", 5); | ||||||
|  |     _exit(1 + mcause); | ||||||
|  |   } | ||||||
|  |   return epc; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void _init() | ||||||
|  | { | ||||||
|  |    | ||||||
|  |   #ifndef NO_INIT | ||||||
|  |   use_default_clocks(); | ||||||
|  |   use_pll(0, 0, 1, 31, 1); | ||||||
|  |   uart_init(115200); | ||||||
|  | 
 | ||||||
|  |   printf("core freq at %d Hz\n", get_cpu_freq()); | ||||||
|  | 
 | ||||||
|  |   write_csr(mtvec, &trap_entry); | ||||||
|  |   if (read_csr(misa) & (1 << ('F' - 'A'))) { // if F extension is present
 | ||||||
|  |     write_csr(mstatus, MSTATUS_FS); // allow FPU instructions without trapping
 | ||||||
|  |     write_csr(fcsr, 0); // initialize rounding mode, undefined at reset
 | ||||||
|  |   } | ||||||
|  |   #endif | ||||||
|  |    | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void _fini() | ||||||
|  | { | ||||||
|  | } | ||||||
|  | @ -0,0 +1,34 @@ | ||||||
|  | adapter_khz     10000 | ||||||
|  | 
 | ||||||
|  | interface ftdi | ||||||
|  | ftdi_device_desc "Dual RS232-HS" | ||||||
|  | ftdi_vid_pid 0x0403 0x6010 | ||||||
|  | 
 | ||||||
|  | ftdi_layout_init 0x0008 0x001b | ||||||
|  | ftdi_layout_signal nSRST -oe 0x0020 -data 0x0020 | ||||||
|  | 
 | ||||||
|  | #Reset Stretcher logic on FE310 is ~1 second long | ||||||
|  | #This doesn't apply if you use | ||||||
|  | # ftdi_set_signal, but still good to document | ||||||
|  | #adapter_nsrst_delay 1500 | ||||||
|  | 
 | ||||||
|  | set _CHIPNAME riscv | ||||||
|  | jtag newtap $_CHIPNAME cpu -irlen 5 -expected-id 0x10e31913 | ||||||
|  | 
 | ||||||
|  | set _TARGETNAME $_CHIPNAME.cpu | ||||||
|  | target create $_TARGETNAME riscv -chain-position $_TARGETNAME | ||||||
|  | $_TARGETNAME configure -work-area-phys 0x80000000 -work-area-size 10000 -work-area-backup 1 | ||||||
|  | 
 | ||||||
|  | flash bank onboard_spi_flash fespi 0x20000000 0 0 0 $_TARGETNAME | ||||||
|  | init | ||||||
|  | #reset -- This type of reset is not implemented yet | ||||||
|  | if {[ info exists pulse_srst]} { | ||||||
|  |   ftdi_set_signal nSRST 0 | ||||||
|  |   ftdi_set_signal nSRST z | ||||||
|  |   #Wait for the reset stretcher | ||||||
|  |   #It will work without this, but | ||||||
|  |   #will incur lots of delays for later commands. | ||||||
|  |   sleep 1500 | ||||||
|  | }	 | ||||||
|  | halt | ||||||
|  | #flash protect 0 64 last off | ||||||
							
								
								
									
										133
									
								
								FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/freedom-e-sdk/env/freedom-e300-hifive1/platform.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										133
									
								
								FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/freedom-e-sdk/env/freedom-e300-hifive1/platform.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,133 @@ | ||||||
|  | // See LICENSE for license details.
 | ||||||
|  | 
 | ||||||
|  | #ifndef _SIFIVE_PLATFORM_H | ||||||
|  | #define _SIFIVE_PLATFORM_H | ||||||
|  | 
 | ||||||
|  | // Some things missing from the official encoding.h
 | ||||||
|  | #define MCAUSE_INT         0x80000000 | ||||||
|  | #define MCAUSE_CAUSE       0x7FFFFFFF | ||||||
|  | 
 | ||||||
|  | #include "sifive/const.h" | ||||||
|  | #include "sifive/devices/aon.h" | ||||||
|  | #include "sifive/devices/clint.h" | ||||||
|  | #include "sifive/devices/gpio.h" | ||||||
|  | #include "sifive/devices/otp.h" | ||||||
|  | #include "sifive/devices/plic.h" | ||||||
|  | #include "sifive/devices/prci.h" | ||||||
|  | #include "sifive/devices/pwm.h" | ||||||
|  | #include "sifive/devices/spi.h" | ||||||
|  | #include "sifive/devices/uart.h" | ||||||
|  | 
 | ||||||
|  | /****************************************************************************
 | ||||||
|  |  * Platform definitions | ||||||
|  |  *****************************************************************************/ | ||||||
|  | 
 | ||||||
|  | // Memory map
 | ||||||
|  | #define MASKROM_MEM_ADDR _AC(0x00001000,UL) | ||||||
|  | #define TRAPVEC_TABLE_CTRL_ADDR _AC(0x00001010,UL) | ||||||
|  | #define OTP_MEM_ADDR _AC(0x00020000,UL) | ||||||
|  | #define CLINT_CTRL_ADDR _AC(0x02000000,UL) | ||||||
|  | #define PLIC_CTRL_ADDR _AC(0x0C000000,UL) | ||||||
|  | #define AON_CTRL_ADDR _AC(0x10000000,UL) | ||||||
|  | #define PRCI_CTRL_ADDR _AC(0x10008000,UL) | ||||||
|  | #define OTP_CTRL_ADDR _AC(0x10010000,UL) | ||||||
|  | #define GPIO_CTRL_ADDR _AC(0x10012000,UL) | ||||||
|  | #define UART0_CTRL_ADDR _AC(0x10013000,UL) | ||||||
|  | #define SPI0_CTRL_ADDR _AC(0x10014000,UL) | ||||||
|  | #define PWM0_CTRL_ADDR _AC(0x10015000,UL) | ||||||
|  | #define UART1_CTRL_ADDR _AC(0x10023000,UL) | ||||||
|  | #define SPI1_CTRL_ADDR _AC(0x10024000,UL) | ||||||
|  | #define PWM1_CTRL_ADDR _AC(0x10025000,UL) | ||||||
|  | #define SPI2_CTRL_ADDR _AC(0x10034000,UL) | ||||||
|  | #define PWM2_CTRL_ADDR _AC(0x10035000,UL) | ||||||
|  | #define SPI0_MEM_ADDR _AC(0x20000000,UL) | ||||||
|  | #define MEM_CTRL_ADDR _AC(0x80000000,UL) | ||||||
|  | 
 | ||||||
|  | // IOF masks
 | ||||||
|  | #define IOF0_SPI1_MASK          _AC(0x000007FC,UL) | ||||||
|  | #define SPI11_NUM_SS     (4) | ||||||
|  | #define IOF_SPI1_SS0          (2u) | ||||||
|  | #define IOF_SPI1_SS1          (8u) | ||||||
|  | #define IOF_SPI1_SS2          (9u) | ||||||
|  | #define IOF_SPI1_SS3          (10u) | ||||||
|  | #define IOF_SPI1_MOSI         (3u) | ||||||
|  | #define IOF_SPI1_MISO         (4u) | ||||||
|  | #define IOF_SPI1_SCK          (5u) | ||||||
|  | #define IOF_SPI1_DQ0          (3u) | ||||||
|  | #define IOF_SPI1_DQ1          (4u) | ||||||
|  | #define IOF_SPI1_DQ2          (6u) | ||||||
|  | #define IOF_SPI1_DQ3          (7u) | ||||||
|  | 
 | ||||||
|  | #define IOF0_SPI2_MASK          _AC(0xFC000000,UL) | ||||||
|  | #define SPI2_NUM_SS       (1) | ||||||
|  | #define IOF_SPI2_SS0          (26u) | ||||||
|  | #define IOF_SPI2_MOSI         (27u) | ||||||
|  | #define IOF_SPI2_MISO         (28u) | ||||||
|  | #define IOF_SPI2_SCK          (29u) | ||||||
|  | #define IOF_SPI2_DQ0          (27u) | ||||||
|  | #define IOF_SPI2_DQ1          (28u) | ||||||
|  | #define IOF_SPI2_DQ2          (30u) | ||||||
|  | #define IOF_SPI2_DQ3          (31u) | ||||||
|  | 
 | ||||||
|  | //#define IOF0_I2C_MASK          _AC(0x00003000,UL)
 | ||||||
|  | 
 | ||||||
|  | #define IOF0_UART0_MASK         _AC(0x00030000, UL) | ||||||
|  | #define IOF_UART0_RX   (16u) | ||||||
|  | #define IOF_UART0_TX   (17u) | ||||||
|  | 
 | ||||||
|  | #define IOF0_UART1_MASK         _AC(0x03000000, UL) | ||||||
|  | #define IOF_UART1_RX (24u) | ||||||
|  | #define IOF_UART1_TX (25u) | ||||||
|  | 
 | ||||||
|  | #define IOF1_PWM0_MASK          _AC(0x0000000F, UL) | ||||||
|  | #define IOF1_PWM1_MASK          _AC(0x00780000, UL) | ||||||
|  | #define IOF1_PWM2_MASK          _AC(0x00003C00, UL) | ||||||
|  | 
 | ||||||
|  | // Interrupt numbers
 | ||||||
|  | #define INT_RESERVED 0 | ||||||
|  | #define INT_WDOGCMP 1 | ||||||
|  | #define INT_RTCCMP 2 | ||||||
|  | #define INT_UART0_BASE 3 | ||||||
|  | #define INT_UART1_BASE 4 | ||||||
|  | #define INT_SPI0_BASE 5 | ||||||
|  | #define INT_SPI1_BASE 6 | ||||||
|  | #define INT_SPI2_BASE 7 | ||||||
|  | #define INT_GPIO_BASE 8 | ||||||
|  | #define INT_PWM0_BASE 40 | ||||||
|  | #define INT_PWM1_BASE 44 | ||||||
|  | #define INT_PWM2_BASE 48 | ||||||
|  | 
 | ||||||
|  | // Helper functions
 | ||||||
|  | #define _REG32(p, i) (*(volatile uint32_t *) ((p) + (i))) | ||||||
|  | #define _REG32P(p, i) ((volatile uint32_t *) ((p) + (i))) | ||||||
|  | #define AON_REG(offset) _REG32(AON_CTRL_ADDR, offset) | ||||||
|  | #define CLINT_REG(offset) _REG32(CLINT_CTRL_ADDR, offset) | ||||||
|  | #define GPIO_REG(offset) _REG32(GPIO_CTRL_ADDR, offset) | ||||||
|  | #define OTP_REG(offset)  _REG32(OTP_CTRL_ADDR, offset) | ||||||
|  | #define PLIC_REG(offset) _REG32(PLIC_CTRL_ADDR, offset) | ||||||
|  | #define PRCI_REG(offset) _REG32(PRCI_CTRL_ADDR, offset) | ||||||
|  | #define PWM0_REG(offset) _REG32(PWM0_CTRL_ADDR, offset) | ||||||
|  | #define PWM1_REG(offset) _REG32(PWM1_CTRL_ADDR, offset) | ||||||
|  | #define PWM2_REG(offset) _REG32(PWM2_CTRL_ADDR, offset) | ||||||
|  | #define SPI0_REG(offset) _REG32(SPI0_CTRL_ADDR, offset) | ||||||
|  | #define SPI1_REG(offset) _REG32(SPI1_CTRL_ADDR, offset) | ||||||
|  | #define SPI2_REG(offset) _REG32(SPI2_CTRL_ADDR, offset) | ||||||
|  | #define UART0_REG(offset) _REG32(UART0_CTRL_ADDR, offset) | ||||||
|  | #define UART1_REG(offset) _REG32(UART1_CTRL_ADDR, offset) | ||||||
|  | 
 | ||||||
|  | // Misc
 | ||||||
|  | 
 | ||||||
|  | #include <stdint.h> | ||||||
|  | 
 | ||||||
|  | #define NUM_GPIO 32 | ||||||
|  | 
 | ||||||
|  | #define PLIC_NUM_INTERRUPTS 52 | ||||||
|  | #define PLIC_NUM_PRIORITIES 7 | ||||||
|  | 
 | ||||||
|  | #include "hifive1.h" | ||||||
|  | 
 | ||||||
|  | unsigned long get_cpu_freq(void); | ||||||
|  | unsigned long get_timer_freq(void); | ||||||
|  | uint64_t get_timer_value(void); | ||||||
|  | 
 | ||||||
|  | #endif /* _SIFIVE_PLATFORM_H */ | ||||||
							
								
								
									
										81
									
								
								FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/freedom-e-sdk/env/hifive1.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										81
									
								
								FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/freedom-e-sdk/env/hifive1.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,81 @@ | ||||||
|  | // See LICENSE for license details.
 | ||||||
|  | 
 | ||||||
|  | #ifndef _SIFIVE_HIFIVE1_H | ||||||
|  | #define _SIFIVE_HIFIVE1_H | ||||||
|  | 
 | ||||||
|  | #include <stdint.h> | ||||||
|  | 
 | ||||||
|  | /****************************************************************************
 | ||||||
|  |  * GPIO Connections | ||||||
|  |  *****************************************************************************/ | ||||||
|  | 
 | ||||||
|  | // These are the GPIO bit offsets for the RGB LED on HiFive1 Board.
 | ||||||
|  | // These are also mapped to RGB LEDs on the Freedom E300 Arty
 | ||||||
|  | // FPGA
 | ||||||
|  | // Dev Kit.
 | ||||||
|  | 
 | ||||||
|  | #define RED_LED_OFFSET   22 | ||||||
|  | #define GREEN_LED_OFFSET 19 | ||||||
|  | #define BLUE_LED_OFFSET  21 | ||||||
|  | 
 | ||||||
|  | // These are the GPIO bit offsets for the differen digital pins
 | ||||||
|  | // on the headers for both the HiFive1 Board and the Freedom E300 Arty FPGA Dev Kit.
 | ||||||
|  | #define PIN_0_OFFSET 16 | ||||||
|  | #define PIN_1_OFFSET 17 | ||||||
|  | #define PIN_2_OFFSET 18 | ||||||
|  | #define PIN_3_OFFSET 19 | ||||||
|  | #define PIN_4_OFFSET 20 | ||||||
|  | #define PIN_5_OFFSET 21 | ||||||
|  | #define PIN_6_OFFSET 22 | ||||||
|  | #define PIN_7_OFFSET 23 | ||||||
|  | #define PIN_8_OFFSET 0 | ||||||
|  | #define PIN_9_OFFSET 1 | ||||||
|  | #define PIN_10_OFFSET 2 | ||||||
|  | #define PIN_11_OFFSET 3 | ||||||
|  | #define PIN_12_OFFSET 4 | ||||||
|  | #define PIN_13_OFFSET 5 | ||||||
|  | //#define PIN_14_OFFSET 8 //This pin is not connected on either board.
 | ||||||
|  | #define PIN_15_OFFSET 9 | ||||||
|  | #define PIN_16_OFFSET 10 | ||||||
|  | #define PIN_17_OFFSET 11 | ||||||
|  | #define PIN_18_OFFSET 12 | ||||||
|  | #define PIN_19_OFFSET 13 | ||||||
|  | 
 | ||||||
|  | // These are *PIN* numbers, not
 | ||||||
|  | // GPIO Offset Numbers.
 | ||||||
|  | #define PIN_SPI1_SCK    (13u) | ||||||
|  | #define PIN_SPI1_MISO   (12u) | ||||||
|  | #define PIN_SPI1_MOSI   (11u) | ||||||
|  | #define PIN_SPI1_SS0    (10u) | ||||||
|  | #define PIN_SPI1_SS1    (14u)  | ||||||
|  | #define PIN_SPI1_SS2    (15u) | ||||||
|  | #define PIN_SPI1_SS3    (16u) | ||||||
|  | 
 | ||||||
|  | #define SS_PIN_TO_CS_ID(x) \ | ||||||
|  |   ((x==PIN_SPI1_SS0 ? 0 :		 \ | ||||||
|  |     (x==PIN_SPI1_SS1 ? 1 :		 \ | ||||||
|  |      (x==PIN_SPI1_SS2 ? 2 :		 \ | ||||||
|  |       (x==PIN_SPI1_SS3 ? 3 :		 \ | ||||||
|  |        -1)))))  | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | // These buttons are present only on the Freedom E300 Arty Dev Kit.
 | ||||||
|  | #ifdef HAS_BOARD_BUTTONS | ||||||
|  | #define BUTTON_0_OFFSET 15 | ||||||
|  | #define BUTTON_1_OFFSET 30 | ||||||
|  | #define BUTTON_2_OFFSET 31 | ||||||
|  | 
 | ||||||
|  | #define INT_DEVICE_BUTTON_0 (INT_GPIO_BASE + BUTTON_0_OFFSET) | ||||||
|  | #define INT_DEVICE_BUTTON_1 (INT_GPIO_BASE + BUTTON_1_OFFSET) | ||||||
|  | #define INT_DEVICE_BUTTON_2 (INT_GPIO_BASE + BUTTON_2_OFFSET) | ||||||
|  | 
 | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | #define HAS_HFXOSC 1 | ||||||
|  | #define HAS_LFROSC_BYPASS 1 | ||||||
|  | 
 | ||||||
|  | #define RTC_FREQ 32768 | ||||||
|  | 
 | ||||||
|  | void write_hex(int fd, unsigned long int hex); | ||||||
|  | 
 | ||||||
|  | #endif /* _SIFIVE_HIFIVE1_H */ | ||||||
							
								
								
									
										110
									
								
								FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/freedom-e-sdk/env/start.S
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										110
									
								
								FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/freedom-e-sdk/env/start.S
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,110 @@ | ||||||
|  | // See LICENSE for license details. | ||||||
|  | 
 | ||||||
|  | /* This is defined in sifive/platform.h, but that can't be included from | ||||||
|  |  * assembly. */ | ||||||
|  | #define CLINT_CTRL_ADDR 0x02000000 | ||||||
|  | 
 | ||||||
|  | 	.section .init | ||||||
|  | 	.globl _start
 | ||||||
|  | 	.type _start,@function
 | ||||||
|  | 
 | ||||||
|  | _start: | ||||||
|  | 	.cfi_startproc | ||||||
|  | 	.cfi_undefined ra
 | ||||||
|  | .option push
 | ||||||
|  | .option norelax
 | ||||||
|  | 	la gp, __global_pointer$ | ||||||
|  | .option pop
 | ||||||
|  | 	la sp, _sp | ||||||
|  | 
 | ||||||
|  | #if defined(ENABLE_SMP) | ||||||
|  | 	smp_pause(t0, t1) | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | 	/* Load data section */ | ||||||
|  | 	la a0, _data_lma | ||||||
|  | 	la a1, _data | ||||||
|  | 	la a2, _edata | ||||||
|  | 	bgeu a1, a2, 2f | ||||||
|  | 1: | ||||||
|  | 	lw t0, (a0) | ||||||
|  | 	sw t0, (a1) | ||||||
|  | 	addi a0, a0, 4 | ||||||
|  | 	addi a1, a1, 4 | ||||||
|  | 	bltu a1, a2, 1b | ||||||
|  | 2: | ||||||
|  | 
 | ||||||
|  | 	/* Clear bss section */ | ||||||
|  | 	la a0, __bss_start | ||||||
|  | 	la a1, _end | ||||||
|  | 	bgeu a0, a1, 2f | ||||||
|  | 1: | ||||||
|  | 	sw zero, (a0) | ||||||
|  | 	addi a0, a0, 4 | ||||||
|  | 	bltu a0, a1, 1b | ||||||
|  | 2: | ||||||
|  | 
 | ||||||
|  | 	/* Call global constructors */ | ||||||
|  | 	la a0, __libc_fini_array | ||||||
|  | 	call atexit | ||||||
|  | 	call __libc_init_array | ||||||
|  | 
 | ||||||
|  | #ifndef __riscv_float_abi_soft | ||||||
|  | 	/* Enable FPU */ | ||||||
|  | 	li t0, MSTATUS_FS | ||||||
|  | 	csrs mstatus, t0 | ||||||
|  | 	csrr t1, mstatus | ||||||
|  | 	and t1, t1, t0 | ||||||
|  | 	beqz t1, 1f | ||||||
|  | 	fssr x0 | ||||||
|  | 1: | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | #if defined(ENABLE_SMP) | ||||||
|  | 	smp_resume(t0, t1) | ||||||
|  | 
 | ||||||
|  | 	csrr a0, mhartid | ||||||
|  | 	bnez a0, 2f | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | 	auipc ra, 0 | ||||||
|  | 	addi sp, sp, -16 | ||||||
|  | #if __riscv_xlen == 32 | ||||||
|  | 	sw ra, 8(sp) | ||||||
|  | #else | ||||||
|  | 	sd ra, 8(sp) | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | 	/* argc = argv = 0 */ | ||||||
|  | 	li a0, 0 | ||||||
|  | 	li a1, 0 | ||||||
|  | 	call main | ||||||
|  | 	tail exit | ||||||
|  | 1: | ||||||
|  | 	j 1b | ||||||
|  | 
 | ||||||
|  | #if defined(ENABLE_SMP) | ||||||
|  | 2: | ||||||
|  | 	la t0, trap_entry | ||||||
|  | 	csrw mtvec, t0 | ||||||
|  | 
 | ||||||
|  | 	csrr a0, mhartid | ||||||
|  | 	la t1, _sp | ||||||
|  | 	slli t0, a0, 10 | ||||||
|  | 	sub sp, t1, t0 | ||||||
|  | 
 | ||||||
|  | 	auipc ra, 0 | ||||||
|  | 	addi sp, sp, -16 | ||||||
|  | #if __riscv_xlen == 32 | ||||||
|  | 	sw ra, 8(sp) | ||||||
|  | #else | ||||||
|  | 	sd ra, 8(sp) | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | 	call secondary_main | ||||||
|  | 	tail exit | ||||||
|  | 
 | ||||||
|  | 1: | ||||||
|  | 	j 1b | ||||||
|  | #endif | ||||||
|  | 	.cfi_endproc | ||||||
|  | @ -0,0 +1,36 @@ | ||||||
|  | // See LICENSE for license details.
 | ||||||
|  | #ifndef _RISCV_BITS_H | ||||||
|  | #define _RISCV_BITS_H | ||||||
|  | 
 | ||||||
|  | #define likely(x) __builtin_expect((x), 1) | ||||||
|  | #define unlikely(x) __builtin_expect((x), 0) | ||||||
|  | 
 | ||||||
|  | #define ROUNDUP(a, b) ((((a)-1)/(b)+1)*(b)) | ||||||
|  | #define ROUNDDOWN(a, b) ((a)/(b)*(b)) | ||||||
|  | 
 | ||||||
|  | #define MAX(a, b) ((a) > (b) ? (a) : (b)) | ||||||
|  | #define MIN(a, b) ((a) < (b) ? (a) : (b)) | ||||||
|  | #define CLAMP(a, lo, hi) MIN(MAX(a, lo), hi) | ||||||
|  | 
 | ||||||
|  | #define EXTRACT_FIELD(val, which) (((val) & (which)) / ((which) & ~((which)-1))) | ||||||
|  | #define INSERT_FIELD(val, which, fieldval) (((val) & ~(which)) | ((fieldval) * ((which) & ~((which)-1)))) | ||||||
|  | 
 | ||||||
|  | #define STR(x) XSTR(x) | ||||||
|  | #define XSTR(x) #x | ||||||
|  | 
 | ||||||
|  | #if __riscv_xlen == 64 | ||||||
|  | # define SLL32    sllw | ||||||
|  | # define STORE    sd | ||||||
|  | # define LOAD     ld | ||||||
|  | # define LWU      lwu | ||||||
|  | # define LOG_REGBYTES 3 | ||||||
|  | #else | ||||||
|  | # define SLL32    sll | ||||||
|  | # define STORE    sw | ||||||
|  | # define LOAD     lw | ||||||
|  | # define LWU      lw | ||||||
|  | # define LOG_REGBYTES 2 | ||||||
|  | #endif | ||||||
|  | #define REGBYTES (1 << LOG_REGBYTES) | ||||||
|  | 
 | ||||||
|  | #endif | ||||||
|  | @ -0,0 +1,18 @@ | ||||||
|  | // See LICENSE for license details.
 | ||||||
|  | /* Derived from <linux/const.h> */ | ||||||
|  | 
 | ||||||
|  | #ifndef _SIFIVE_CONST_H | ||||||
|  | #define _SIFIVE_CONST_H | ||||||
|  | 
 | ||||||
|  | #ifdef __ASSEMBLER__ | ||||||
|  | #define _AC(X,Y)        X | ||||||
|  | #define _AT(T,X)        X | ||||||
|  | #else | ||||||
|  | #define _AC(X,Y)        (X##Y) | ||||||
|  | #define _AT(T,X)        ((T)(X)) | ||||||
|  | #endif /* !__ASSEMBLER__*/ | ||||||
|  | 
 | ||||||
|  | #define _BITUL(x)       (_AC(1,UL) << (x)) | ||||||
|  | #define _BITULL(x)      (_AC(1,ULL) << (x)) | ||||||
|  | 
 | ||||||
|  | #endif /* _SIFIVE_CONST_H */ | ||||||
|  | @ -0,0 +1,88 @@ | ||||||
|  | // See LICENSE for license details.
 | ||||||
|  | 
 | ||||||
|  | #ifndef _SIFIVE_AON_H | ||||||
|  | #define _SIFIVE_AON_H | ||||||
|  | 
 | ||||||
|  | /* Register offsets */ | ||||||
|  | 
 | ||||||
|  | #define AON_WDOGCFG     0x000 | ||||||
|  | #define AON_WDOGCOUNT   0x008 | ||||||
|  | #define AON_WDOGS       0x010 | ||||||
|  | #define AON_WDOGFEED    0x018 | ||||||
|  | #define AON_WDOGKEY     0x01C | ||||||
|  | #define AON_WDOGCMP     0x020 | ||||||
|  | 
 | ||||||
|  | #define AON_RTCCFG      0x040 | ||||||
|  | #define AON_RTCLO       0x048 | ||||||
|  | #define AON_RTCHI       0x04C | ||||||
|  | #define AON_RTCS        0x050 | ||||||
|  | #define AON_RTCCMP      0x060 | ||||||
|  | 
 | ||||||
|  | #define AON_BACKUP0     0x080 | ||||||
|  | #define AON_BACKUP1     0x084 | ||||||
|  | #define AON_BACKUP2     0x088 | ||||||
|  | #define AON_BACKUP3     0x08C | ||||||
|  | #define AON_BACKUP4     0x090 | ||||||
|  | #define AON_BACKUP5     0x094 | ||||||
|  | #define AON_BACKUP6     0x098 | ||||||
|  | #define AON_BACKUP7     0x09C | ||||||
|  | #define AON_BACKUP8     0x0A0 | ||||||
|  | #define AON_BACKUP9     0x0A4 | ||||||
|  | #define AON_BACKUP10    0x0A8 | ||||||
|  | #define AON_BACKUP11    0x0AC | ||||||
|  | #define AON_BACKUP12    0x0B0 | ||||||
|  | #define AON_BACKUP13    0x0B4 | ||||||
|  | #define AON_BACKUP14    0x0B8 | ||||||
|  | #define AON_BACKUP15    0x0BC | ||||||
|  | 
 | ||||||
|  | #define AON_PMUWAKEUPI0 0x100 | ||||||
|  | #define AON_PMUWAKEUPI1 0x104 | ||||||
|  | #define AON_PMUWAKEUPI2 0x108 | ||||||
|  | #define AON_PMUWAKEUPI3 0x10C | ||||||
|  | #define AON_PMUWAKEUPI4 0x110 | ||||||
|  | #define AON_PMUWAKEUPI5 0x114 | ||||||
|  | #define AON_PMUWAKEUPI6 0x118 | ||||||
|  | #define AON_PMUWAKEUPI7 0x11C | ||||||
|  | #define AON_PMUSLEEPI0  0x120 | ||||||
|  | #define AON_PMUSLEEPI1  0x124 | ||||||
|  | #define AON_PMUSLEEPI2  0x128 | ||||||
|  | #define AON_PMUSLEEPI3  0x12C | ||||||
|  | #define AON_PMUSLEEPI4  0x130 | ||||||
|  | #define AON_PMUSLEEPI5  0x134 | ||||||
|  | #define AON_PMUSLEEPI6  0x138 | ||||||
|  | #define AON_PMUSLEEPI7  0x13C | ||||||
|  | #define AON_PMUIE       0x140 | ||||||
|  | #define AON_PMUCAUSE    0x144 | ||||||
|  | #define AON_PMUSLEEP    0x148 | ||||||
|  | #define AON_PMUKEY      0x14C | ||||||
|  | 
 | ||||||
|  | #define AON_LFROSC      0x070 | ||||||
|  | /* Constants */ | ||||||
|  | 
 | ||||||
|  | #define AON_WDOGKEY_VALUE  0x51F15E | ||||||
|  | #define AON_WDOGFEED_VALUE 0xD09F00D | ||||||
|  | 
 | ||||||
|  | #define AON_WDOGCFG_SCALE       0x0000000F | ||||||
|  | #define AON_WDOGCFG_RSTEN       0x00000100 | ||||||
|  | #define AON_WDOGCFG_ZEROCMP     0x00000200 | ||||||
|  | #define AON_WDOGCFG_ENALWAYS    0x00001000 | ||||||
|  | #define AON_WDOGCFG_ENCOREAWAKE 0x00002000 | ||||||
|  | #define AON_WDOGCFG_CMPIP       0x10000000 | ||||||
|  | 
 | ||||||
|  | #define AON_RTCCFG_SCALE     0x0000000F | ||||||
|  | #define AON_RTCCFG_ENALWAYS  0x00001000 | ||||||
|  | #define AON_RTCCFG_CMPIP     0x10000000 | ||||||
|  | 
 | ||||||
|  | #define AON_WAKEUPCAUSE_RESET   0x00 | ||||||
|  | #define AON_WAKEUPCAUSE_RTC     0x01 | ||||||
|  | #define AON_WAKEUPCAUSE_DWAKEUP 0x02 | ||||||
|  | #define AON_WAKEUPCAUSE_AWAKEUP 0x03 | ||||||
|  | 
 | ||||||
|  | #define AON_RESETCAUSE_POWERON  0x0000 | ||||||
|  | #define AON_RESETCAUSE_EXTERNAL 0x0100 | ||||||
|  | #define AON_RESETCAUSE_WATCHDOG 0x0200 | ||||||
|  | 
 | ||||||
|  | #define AON_PMUCAUSE_WAKEUPCAUSE 0x00FF | ||||||
|  | #define AON_PMUCAUSE_RESETCAUSE  0xFF00 | ||||||
|  | 
 | ||||||
|  | #endif /* _SIFIVE_AON_H */ | ||||||
|  | @ -0,0 +1,14 @@ | ||||||
|  | // See LICENSE for license details
 | ||||||
|  | 
 | ||||||
|  | #ifndef _SIFIVE_CLINT_H | ||||||
|  | #define _SIFIVE_CLINT_H | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | #define CLINT_MSIP 0x0000 | ||||||
|  | #define CLINT_MSIP_size   0x4 | ||||||
|  | #define CLINT_MTIMECMP 0x4000 | ||||||
|  | #define CLINT_MTIMECMP_size 0x8 | ||||||
|  | #define CLINT_MTIME 0xBFF8 | ||||||
|  | #define CLINT_MTIME_size 0x8 | ||||||
|  | 
 | ||||||
|  | #endif /* _SIFIVE_CLINT_H */  | ||||||
|  | @ -0,0 +1,24 @@ | ||||||
|  | // See LICENSE for license details.
 | ||||||
|  | 
 | ||||||
|  | #ifndef _SIFIVE_GPIO_H | ||||||
|  | #define _SIFIVE_GPIO_H | ||||||
|  | 
 | ||||||
|  | #define GPIO_INPUT_VAL  (0x00) | ||||||
|  | #define GPIO_INPUT_EN   (0x04) | ||||||
|  | #define GPIO_OUTPUT_EN  (0x08) | ||||||
|  | #define GPIO_OUTPUT_VAL (0x0C) | ||||||
|  | #define GPIO_PULLUP_EN  (0x10) | ||||||
|  | #define GPIO_DRIVE      (0x14) | ||||||
|  | #define GPIO_RISE_IE    (0x18) | ||||||
|  | #define GPIO_RISE_IP    (0x1C) | ||||||
|  | #define GPIO_FALL_IE    (0x20) | ||||||
|  | #define GPIO_FALL_IP    (0x24) | ||||||
|  | #define GPIO_HIGH_IE    (0x28) | ||||||
|  | #define GPIO_HIGH_IP    (0x2C) | ||||||
|  | #define GPIO_LOW_IE     (0x30) | ||||||
|  | #define GPIO_LOW_IP     (0x34) | ||||||
|  | #define GPIO_IOF_EN     (0x38) | ||||||
|  | #define GPIO_IOF_SEL    (0x3C) | ||||||
|  | #define GPIO_OUTPUT_XOR    (0x40) | ||||||
|  | 
 | ||||||
|  | #endif /* _SIFIVE_GPIO_H */ | ||||||
|  | @ -0,0 +1,23 @@ | ||||||
|  | // See LICENSE for license details.
 | ||||||
|  | 
 | ||||||
|  | #ifndef _SIFIVE_OTP_H | ||||||
|  | #define _SIFIVE_OTP_H | ||||||
|  | 
 | ||||||
|  | /* Register offsets */ | ||||||
|  | 
 | ||||||
|  | #define OTP_LOCK         0x00 | ||||||
|  | #define OTP_CK           0x04 | ||||||
|  | #define OTP_OE           0x08 | ||||||
|  | #define OTP_SEL          0x0C | ||||||
|  | #define OTP_WE           0x10 | ||||||
|  | #define OTP_MR           0x14 | ||||||
|  | #define OTP_MRR          0x18 | ||||||
|  | #define OTP_MPP          0x1C | ||||||
|  | #define OTP_VRREN        0x20 | ||||||
|  | #define OTP_VPPEN        0x24 | ||||||
|  | #define OTP_A            0x28 | ||||||
|  | #define OTP_D            0x2C | ||||||
|  | #define OTP_Q            0x30 | ||||||
|  | #define OTP_READ_TIMINGS 0x34 | ||||||
|  | 
 | ||||||
|  | #endif | ||||||
|  | @ -0,0 +1,31 @@ | ||||||
|  | // See LICENSE for license details.
 | ||||||
|  | 
 | ||||||
|  | #ifndef PLIC_H | ||||||
|  | #define PLIC_H | ||||||
|  | 
 | ||||||
|  | #include <sifive/const.h> | ||||||
|  | 
 | ||||||
|  | // 32 bits per source
 | ||||||
|  | #define PLIC_PRIORITY_OFFSET            _AC(0x0000,UL) | ||||||
|  | #define PLIC_PRIORITY_SHIFT_PER_SOURCE  2 | ||||||
|  | // 1 bit per source (1 address)
 | ||||||
|  | #define PLIC_PENDING_OFFSET             _AC(0x1000,UL) | ||||||
|  | #define PLIC_PENDING_SHIFT_PER_SOURCE   0 | ||||||
|  | 
 | ||||||
|  | //0x80 per target
 | ||||||
|  | #define PLIC_ENABLE_OFFSET              _AC(0x2000,UL) | ||||||
|  | #define PLIC_ENABLE_SHIFT_PER_TARGET    7 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | #define PLIC_THRESHOLD_OFFSET           _AC(0x200000,UL) | ||||||
|  | #define PLIC_CLAIM_OFFSET               _AC(0x200004,UL) | ||||||
|  | #define PLIC_THRESHOLD_SHIFT_PER_TARGET 12 | ||||||
|  | #define PLIC_CLAIM_SHIFT_PER_TARGET     12 | ||||||
|  | 
 | ||||||
|  | #define PLIC_MAX_SOURCE                 1023 | ||||||
|  | #define PLIC_SOURCE_MASK                0x3FF | ||||||
|  | 
 | ||||||
|  | #define PLIC_MAX_TARGET                 15871 | ||||||
|  | #define PLIC_TARGET_MASK                0x3FFF | ||||||
|  | 
 | ||||||
|  | #endif /* PLIC_H */ | ||||||
|  | @ -0,0 +1,56 @@ | ||||||
|  | // See LICENSE for license details.
 | ||||||
|  | 
 | ||||||
|  | #ifndef _SIFIVE_PRCI_H | ||||||
|  | #define _SIFIVE_PRCI_H | ||||||
|  | 
 | ||||||
|  | /* Register offsets */ | ||||||
|  | 
 | ||||||
|  | #define PRCI_HFROSCCFG   (0x0000) | ||||||
|  | #define PRCI_HFXOSCCFG   (0x0004) | ||||||
|  | #define PRCI_PLLCFG      (0x0008) | ||||||
|  | #define PRCI_PLLDIV      (0x000C) | ||||||
|  | #define PRCI_PROCMONCFG  (0x00F0) | ||||||
|  | 
 | ||||||
|  | /* Fields */ | ||||||
|  | #define ROSC_DIV(x)    (((x) & 0x2F) << 0 )  | ||||||
|  | #define ROSC_TRIM(x)   (((x) & 0x1F) << 16) | ||||||
|  | #define ROSC_EN(x)     (((x) & 0x1 ) << 30)  | ||||||
|  | #define ROSC_RDY(x)    (((x) & 0x1 ) << 31) | ||||||
|  | 
 | ||||||
|  | #define XOSC_EN(x)     (((x) & 0x1) << 30) | ||||||
|  | #define XOSC_RDY(x)    (((x) & 0x1) << 31) | ||||||
|  | 
 | ||||||
|  | #define PLL_R(x)       (((x) & 0x7)  << 0) | ||||||
|  | // single reserved bit for F LSB.
 | ||||||
|  | #define PLL_F(x)       (((x) & 0x3F) << 4) | ||||||
|  | #define PLL_Q(x)       (((x) & 0x3)  << 10) | ||||||
|  | #define PLL_SEL(x)     (((x) & 0x1)  << 16) | ||||||
|  | #define PLL_REFSEL(x)  (((x) & 0x1)  << 17) | ||||||
|  | #define PLL_BYPASS(x)  (((x) & 0x1)  << 18) | ||||||
|  | #define PLL_LOCK(x)    (((x) & 0x1)  << 31) | ||||||
|  | 
 | ||||||
|  | #define PLL_R_default 0x1 | ||||||
|  | #define PLL_F_default 0x1F | ||||||
|  | #define PLL_Q_default 0x3 | ||||||
|  | 
 | ||||||
|  | #define PLL_REFSEL_HFROSC 0x0 | ||||||
|  | #define PLL_REFSEL_HFXOSC 0x1 | ||||||
|  | 
 | ||||||
|  | #define PLL_SEL_HFROSC 0x0 | ||||||
|  | #define PLL_SEL_PLL    0x1 | ||||||
|  | 
 | ||||||
|  | #define PLL_FINAL_DIV(x)      (((x) & 0x3F) << 0) | ||||||
|  | #define PLL_FINAL_DIV_BY_1(x) (((x) & 0x1 ) << 8) | ||||||
|  | 
 | ||||||
|  | #define PROCMON_DIV(x)   (((x) & 0x1F) << 0) | ||||||
|  | #define PROCMON_TRIM(x)  (((x) & 0x1F) << 8) | ||||||
|  | #define PROCMON_EN(x)    (((x) & 0x1)  << 16) | ||||||
|  | #define PROCMON_SEL(x)   (((x) & 0x3)  << 24) | ||||||
|  | #define PROCMON_NT_EN(x) (((x) & 0x1)  << 28) | ||||||
|  | 
 | ||||||
|  | #define PROCMON_SEL_HFCLK     0 | ||||||
|  | #define PROCMON_SEL_HFXOSCIN  1 | ||||||
|  | #define PROCMON_SEL_PLLOUTDIV 2 | ||||||
|  | #define PROCMON_SEL_PROCMON   3 | ||||||
|  | 
 | ||||||
|  | #endif // _SIFIVE_PRCI_H
 | ||||||
|  | @ -0,0 +1,37 @@ | ||||||
|  | // See LICENSE for license details.
 | ||||||
|  | 
 | ||||||
|  | #ifndef _SIFIVE_PWM_H | ||||||
|  | #define _SIFIVE_PWM_H | ||||||
|  | 
 | ||||||
|  | /* Register offsets */ | ||||||
|  | 
 | ||||||
|  | #define PWM_CFG   0x00 | ||||||
|  | #define PWM_COUNT 0x08 | ||||||
|  | #define PWM_S     0x10 | ||||||
|  | #define PWM_CMP0  0x20 | ||||||
|  | #define PWM_CMP1  0x24 | ||||||
|  | #define PWM_CMP2  0x28 | ||||||
|  | #define PWM_CMP3  0x2C | ||||||
|  | 
 | ||||||
|  | /* Constants */ | ||||||
|  | 
 | ||||||
|  | #define PWM_CFG_SCALE       0x0000000F | ||||||
|  | #define PWM_CFG_STICKY      0x00000100 | ||||||
|  | #define PWM_CFG_ZEROCMP     0x00000200 | ||||||
|  | #define PWM_CFG_DEGLITCH    0x00000400 | ||||||
|  | #define PWM_CFG_ENALWAYS    0x00001000 | ||||||
|  | #define PWM_CFG_ONESHOT     0x00002000 | ||||||
|  | #define PWM_CFG_CMP0CENTER  0x00010000 | ||||||
|  | #define PWM_CFG_CMP1CENTER  0x00020000 | ||||||
|  | #define PWM_CFG_CMP2CENTER  0x00040000 | ||||||
|  | #define PWM_CFG_CMP3CENTER  0x00080000 | ||||||
|  | #define PWM_CFG_CMP0GANG    0x01000000 | ||||||
|  | #define PWM_CFG_CMP1GANG    0x02000000 | ||||||
|  | #define PWM_CFG_CMP2GANG    0x04000000 | ||||||
|  | #define PWM_CFG_CMP3GANG    0x08000000 | ||||||
|  | #define PWM_CFG_CMP0IP      0x10000000 | ||||||
|  | #define PWM_CFG_CMP1IP      0x20000000 | ||||||
|  | #define PWM_CFG_CMP2IP      0x40000000 | ||||||
|  | #define PWM_CFG_CMP3IP      0x80000000 | ||||||
|  | 
 | ||||||
|  | #endif /* _SIFIVE_PWM_H */ | ||||||
|  | @ -0,0 +1,80 @@ | ||||||
|  | // See LICENSE for license details.
 | ||||||
|  | 
 | ||||||
|  | #ifndef _SIFIVE_SPI_H | ||||||
|  | #define _SIFIVE_SPI_H | ||||||
|  | 
 | ||||||
|  | /* Register offsets */ | ||||||
|  | 
 | ||||||
|  | #define SPI_REG_SCKDIV          0x00 | ||||||
|  | #define SPI_REG_SCKMODE         0x04 | ||||||
|  | #define SPI_REG_CSID            0x10 | ||||||
|  | #define SPI_REG_CSDEF           0x14 | ||||||
|  | #define SPI_REG_CSMODE          0x18 | ||||||
|  | 
 | ||||||
|  | #define SPI_REG_DCSSCK          0x28 | ||||||
|  | #define SPI_REG_DSCKCS          0x2a | ||||||
|  | #define SPI_REG_DINTERCS        0x2c | ||||||
|  | #define SPI_REG_DINTERXFR       0x2e | ||||||
|  | 
 | ||||||
|  | #define SPI_REG_FMT             0x40 | ||||||
|  | #define SPI_REG_TXFIFO          0x48 | ||||||
|  | #define SPI_REG_RXFIFO          0x4c | ||||||
|  | #define SPI_REG_TXCTRL          0x50 | ||||||
|  | #define SPI_REG_RXCTRL          0x54 | ||||||
|  | 
 | ||||||
|  | #define SPI_REG_FCTRL           0x60 | ||||||
|  | #define SPI_REG_FFMT            0x64 | ||||||
|  | 
 | ||||||
|  | #define SPI_REG_IE              0x70 | ||||||
|  | #define SPI_REG_IP              0x74 | ||||||
|  | 
 | ||||||
|  | /* Fields */ | ||||||
|  | 
 | ||||||
|  | #define SPI_SCK_PHA             0x1 | ||||||
|  | #define SPI_SCK_POL             0x2 | ||||||
|  | 
 | ||||||
|  | #define SPI_FMT_PROTO(x)        ((x) & 0x3) | ||||||
|  | #define SPI_FMT_ENDIAN(x)       (((x) & 0x1) << 2) | ||||||
|  | #define SPI_FMT_DIR(x)          (((x) & 0x1) << 3) | ||||||
|  | #define SPI_FMT_LEN(x)          (((x) & 0xf) << 16) | ||||||
|  | 
 | ||||||
|  | /* TXCTRL register */ | ||||||
|  | #define SPI_TXWM(x)             ((x) & 0xffff) | ||||||
|  | /* RXCTRL register */ | ||||||
|  | #define SPI_RXWM(x)             ((x) & 0xffff) | ||||||
|  | 
 | ||||||
|  | #define SPI_IP_TXWM             0x1 | ||||||
|  | #define SPI_IP_RXWM             0x2 | ||||||
|  | 
 | ||||||
|  | #define SPI_FCTRL_EN            0x1 | ||||||
|  | 
 | ||||||
|  | #define SPI_INSN_CMD_EN         0x1 | ||||||
|  | #define SPI_INSN_ADDR_LEN(x)    (((x) & 0x7) << 1) | ||||||
|  | #define SPI_INSN_PAD_CNT(x)     (((x) & 0xf) << 4) | ||||||
|  | #define SPI_INSN_CMD_PROTO(x)   (((x) & 0x3) << 8) | ||||||
|  | #define SPI_INSN_ADDR_PROTO(x)  (((x) & 0x3) << 10) | ||||||
|  | #define SPI_INSN_DATA_PROTO(x)  (((x) & 0x3) << 12) | ||||||
|  | #define SPI_INSN_CMD_CODE(x)    (((x) & 0xff) << 16) | ||||||
|  | #define SPI_INSN_PAD_CODE(x)    (((x) & 0xff) << 24) | ||||||
|  | 
 | ||||||
|  | #define SPI_TXFIFO_FULL  (1 << 31)    | ||||||
|  | #define SPI_RXFIFO_EMPTY (1 << 31)    | ||||||
|  | 
 | ||||||
|  | /* Values */ | ||||||
|  | 
 | ||||||
|  | #define SPI_CSMODE_AUTO         0 | ||||||
|  | #define SPI_CSMODE_HOLD         2 | ||||||
|  | #define SPI_CSMODE_OFF          3 | ||||||
|  | 
 | ||||||
|  | #define SPI_DIR_RX              0 | ||||||
|  | #define SPI_DIR_TX              1 | ||||||
|  | 
 | ||||||
|  | #define SPI_PROTO_S             0 | ||||||
|  | #define SPI_PROTO_D             1 | ||||||
|  | #define SPI_PROTO_Q             2 | ||||||
|  | 
 | ||||||
|  | #define SPI_ENDIAN_MSB          0 | ||||||
|  | #define SPI_ENDIAN_LSB          1 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | #endif /* _SIFIVE_SPI_H */ | ||||||
|  | @ -0,0 +1,27 @@ | ||||||
|  | // See LICENSE for license details.
 | ||||||
|  | 
 | ||||||
|  | #ifndef _SIFIVE_UART_H | ||||||
|  | #define _SIFIVE_UART_H | ||||||
|  | 
 | ||||||
|  | /* Register offsets */ | ||||||
|  | #define UART_REG_TXFIFO         0x00 | ||||||
|  | #define UART_REG_RXFIFO         0x04 | ||||||
|  | #define UART_REG_TXCTRL         0x08 | ||||||
|  | #define UART_REG_RXCTRL         0x0c | ||||||
|  | #define UART_REG_IE             0x10 | ||||||
|  | #define UART_REG_IP             0x14 | ||||||
|  | #define UART_REG_DIV            0x18 | ||||||
|  | 
 | ||||||
|  | /* TXCTRL register */ | ||||||
|  | #define UART_TXEN               0x1 | ||||||
|  | #define UART_TXWM(x)            (((x) & 0xffff) << 16) | ||||||
|  | 
 | ||||||
|  | /* RXCTRL register */ | ||||||
|  | #define UART_RXEN               0x1 | ||||||
|  | #define UART_RXWM(x)            (((x) & 0xffff) << 16) | ||||||
|  | 
 | ||||||
|  | /* IP register */ | ||||||
|  | #define UART_IP_TXWM            0x1 | ||||||
|  | #define UART_IP_RXWM            0x2 | ||||||
|  | 
 | ||||||
|  | #endif /* _SIFIVE_UART_H */ | ||||||
|  | @ -0,0 +1,17 @@ | ||||||
|  | // See LICENSE for license details.
 | ||||||
|  | #ifndef _SECTIONS_H | ||||||
|  | #define _SECTIONS_H | ||||||
|  | 
 | ||||||
|  | extern unsigned char _rom[]; | ||||||
|  | extern unsigned char _rom_end[]; | ||||||
|  | 
 | ||||||
|  | extern unsigned char _ram[]; | ||||||
|  | extern unsigned char _ram_end[]; | ||||||
|  | 
 | ||||||
|  | extern unsigned char _ftext[]; | ||||||
|  | extern unsigned char _etext[]; | ||||||
|  | extern unsigned char _fbss[]; | ||||||
|  | extern unsigned char _ebss[]; | ||||||
|  | extern unsigned char _end[]; | ||||||
|  | 
 | ||||||
|  | #endif /* _SECTIONS_H */ | ||||||
|  | @ -0,0 +1,65 @@ | ||||||
|  | #ifndef SIFIVE_SMP | ||||||
|  | #define SIFIVE_SMP | ||||||
|  | 
 | ||||||
|  | // The maximum number of HARTs this code supports
 | ||||||
|  | #ifndef MAX_HARTS | ||||||
|  | #define MAX_HARTS 32 | ||||||
|  | #endif | ||||||
|  | #define CLINT_END_HART_IPI CLINT_CTRL_ADDR + (MAX_HARTS*4) | ||||||
|  | 
 | ||||||
|  | // The hart that non-SMP tests should run on
 | ||||||
|  | #ifndef NONSMP_HART | ||||||
|  | #define NONSMP_HART 0 | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | /* If your test cannot handle multiple-threads, use this: 
 | ||||||
|  |  *   smp_disable(reg1) | ||||||
|  |  */ | ||||||
|  | #define smp_disable(reg1, reg2)			 \ | ||||||
|  |   csrr reg1, mhartid				;\ | ||||||
|  |   li   reg2, NONSMP_HART			;\ | ||||||
|  |   beq  reg1, reg2, hart0_entry			;\ | ||||||
|  | 42:						;\ | ||||||
|  |   wfi    					;\ | ||||||
|  |   j 42b						;\ | ||||||
|  | hart0_entry: | ||||||
|  | 
 | ||||||
|  | /* If your test needs to temporarily block multiple-threads, do this:
 | ||||||
|  |  *    smp_pause(reg1, reg2) | ||||||
|  |  *    ... single-threaded work ... | ||||||
|  |  *    smp_resume(reg1, reg2) | ||||||
|  |  *    ... multi-threaded work ... | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | #define smp_pause(reg1, reg2)	 \ | ||||||
|  |   li reg2, 0x8			;\ | ||||||
|  |   csrw mie, reg2		;\ | ||||||
|  |   csrr reg2, mhartid		;\ | ||||||
|  |   bnez reg2, 42f | ||||||
|  | 
 | ||||||
|  | #define smp_resume(reg1, reg2)	 \ | ||||||
|  |   li reg1, CLINT_CTRL_ADDR	;\ | ||||||
|  | 41:				;\ | ||||||
|  |   li reg2, 1			;\ | ||||||
|  |   sw reg2, 0(reg1)		;\ | ||||||
|  |   addi reg1, reg1, 4		;\ | ||||||
|  |   li reg2, CLINT_END_HART_IPI	;\ | ||||||
|  |   blt reg1, reg2, 41b		;\ | ||||||
|  | 42:				;\ | ||||||
|  |   wfi    			;\ | ||||||
|  |   csrr reg2, mip		;\ | ||||||
|  |   andi reg2, reg2, 0x8		;\ | ||||||
|  |   beqz reg2, 42b		;\ | ||||||
|  |   li reg1, CLINT_CTRL_ADDR	;\ | ||||||
|  |   csrr reg2, mhartid		;\ | ||||||
|  |   slli reg2, reg2, 2		;\ | ||||||
|  |   add reg2, reg2, reg1		;\ | ||||||
|  |   sw zero, 0(reg2)		;\ | ||||||
|  | 41:				;\ | ||||||
|  |   lw reg2, 0(reg1)		;\ | ||||||
|  |   bnez reg2, 41b		;\ | ||||||
|  |   addi reg1, reg1, 4		;\ | ||||||
|  |   li reg2, CLINT_END_HART_IPI	;\ | ||||||
|  |   blt reg1, reg2, 41b | ||||||
|  | 
 | ||||||
|  | #endif | ||||||
|  | @ -0,0 +1,19 @@ | ||||||
|  | /* See LICENSE of license details. */ | ||||||
|  | 
 | ||||||
|  | #include <stdint.h> | ||||||
|  | #include <unistd.h> | ||||||
|  | #include "platform.h" | ||||||
|  | 
 | ||||||
|  | void write_hex(int fd, unsigned long int hex) | ||||||
|  | { | ||||||
|  |   uint8_t ii; | ||||||
|  |   uint8_t jj; | ||||||
|  |   char towrite; | ||||||
|  |   write(fd , "0x", 2); | ||||||
|  |   for (ii = sizeof(unsigned long int) * 2 ; ii > 0; ii--) { | ||||||
|  |     jj = ii - 1; | ||||||
|  |     uint8_t digit = ((hex & (0xF << (jj*4))) >> (jj*4)); | ||||||
|  |     towrite = digit < 0xA ? ('0' + digit) : ('A' +  (digit - 0xA)); | ||||||
|  |     write(fd, &towrite, 1); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | @ -0,0 +1,17 @@ | ||||||
|  | /* See LICENSE for license details. */ | ||||||
|  | 
 | ||||||
|  | /* These functions are intended for embedded RV32 systems and are
 | ||||||
|  |    obviously incorrect in general. */ | ||||||
|  | 
 | ||||||
|  | void* __wrap_malloc(unsigned long sz) | ||||||
|  | { | ||||||
|  |   extern void* sbrk(long); | ||||||
|  |   void* res = sbrk(sz); | ||||||
|  |   if ((long)res == -1) | ||||||
|  |     return 0; | ||||||
|  |   return res; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void __wrap_free(void* ptr) | ||||||
|  | { | ||||||
|  | } | ||||||
|  | @ -0,0 +1,17 @@ | ||||||
|  | /* See LICENSE of license details. */ | ||||||
|  | 
 | ||||||
|  | #include <unistd.h> | ||||||
|  | #include "platform.h" | ||||||
|  | #include "weak_under_alias.h" | ||||||
|  | 
 | ||||||
|  | void __wrap_exit(int code) | ||||||
|  | { | ||||||
|  |   const char message[] = "\nProgam has exited with code:"; | ||||||
|  | 
 | ||||||
|  |   write(STDERR_FILENO, message, sizeof(message) - 1); | ||||||
|  |   write_hex(STDERR_FILENO, code); | ||||||
|  |   write(STDERR_FILENO, "\n", 1); | ||||||
|  | 
 | ||||||
|  |   for (;;); | ||||||
|  | } | ||||||
|  | weak_under_alias(exit); | ||||||
|  | @ -0,0 +1,11 @@ | ||||||
|  | /* See LICENSE of license details. */ | ||||||
|  | 
 | ||||||
|  | #include <errno.h> | ||||||
|  | #include "stub.h" | ||||||
|  | #include "weak_under_alias.h" | ||||||
|  | 
 | ||||||
|  | int __wrap_close(int fd) | ||||||
|  | { | ||||||
|  |   return _stub(EBADF); | ||||||
|  | } | ||||||
|  | weak_under_alias(close); | ||||||
|  | @ -0,0 +1,11 @@ | ||||||
|  | /* See LICENSE of license details. */ | ||||||
|  | 
 | ||||||
|  | #include <errno.h> | ||||||
|  | #include "stub.h" | ||||||
|  | #include "weak_under_alias.h" | ||||||
|  | 
 | ||||||
|  | int __wrap_execve(const char* name, char* const argv[], char* const env[]) | ||||||
|  | { | ||||||
|  |   return _stub(ENOMEM); | ||||||
|  | } | ||||||
|  | weak_under_alias(execve); | ||||||
|  | @ -0,0 +1,9 @@ | ||||||
|  | /* See LICENSE of license details. */ | ||||||
|  | 
 | ||||||
|  | #include <errno.h> | ||||||
|  | #include "stub.h" | ||||||
|  | 
 | ||||||
|  | int fork(void) | ||||||
|  | { | ||||||
|  |   return _stub(EAGAIN); | ||||||
|  | } | ||||||
|  | @ -0,0 +1,18 @@ | ||||||
|  | /* See LICENSE of license details. */ | ||||||
|  | 
 | ||||||
|  | #include <errno.h> | ||||||
|  | #include <unistd.h> | ||||||
|  | #include <sys/stat.h> | ||||||
|  | #include "stub.h" | ||||||
|  | #include "weak_under_alias.h" | ||||||
|  | 
 | ||||||
|  | int __wrap_fstat(int fd, struct stat* st) | ||||||
|  | { | ||||||
|  |   if (isatty(fd)) { | ||||||
|  |     st->st_mode = S_IFCHR; | ||||||
|  |     return 0; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   return _stub(EBADF); | ||||||
|  | } | ||||||
|  | weak_under_alias(fstat); | ||||||
|  | @ -0,0 +1,8 @@ | ||||||
|  | /* See LICENSE of license details. */ | ||||||
|  | #include "weak_under_alias.h" | ||||||
|  | 
 | ||||||
|  | int __wrap_getpid(void) | ||||||
|  | { | ||||||
|  |   return 1; | ||||||
|  | } | ||||||
|  | weak_under_alias(getpid); | ||||||
|  | @ -0,0 +1,13 @@ | ||||||
|  | /* See LICENSE of license details. */ | ||||||
|  | 
 | ||||||
|  | #include <unistd.h> | ||||||
|  | #include "weak_under_alias.h" | ||||||
|  | 
 | ||||||
|  | int __wrap_isatty(int fd) | ||||||
|  | { | ||||||
|  |   if (fd == STDOUT_FILENO || fd == STDERR_FILENO) | ||||||
|  |     return 1; | ||||||
|  | 
 | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
|  | weak_under_alias(isatty); | ||||||
|  | @ -0,0 +1,11 @@ | ||||||
|  | /* See LICENSE of license details. */ | ||||||
|  | 
 | ||||||
|  | #include <errno.h> | ||||||
|  | #include "stub.h" | ||||||
|  | #include "weak_under_alias.h" | ||||||
|  | 
 | ||||||
|  | int __wrap_kill(int pid, int sig) | ||||||
|  | { | ||||||
|  |   return _stub(EINVAL); | ||||||
|  | } | ||||||
|  | weak_under_alias(kill); | ||||||
|  | @ -0,0 +1,11 @@ | ||||||
|  | /* See LICENSE of license details. */ | ||||||
|  | 
 | ||||||
|  | #include <errno.h> | ||||||
|  | #include "stub.h" | ||||||
|  | #include "weak_under_alias.h" | ||||||
|  | 
 | ||||||
|  | int __wrap_link(const char *old_name, const char *new_name) | ||||||
|  | { | ||||||
|  |   return _stub(EMLINK); | ||||||
|  | } | ||||||
|  | weak_under_alias(link); | ||||||
|  | @ -0,0 +1,16 @@ | ||||||
|  | /* See LICENSE of license details. */ | ||||||
|  | 
 | ||||||
|  | #include <errno.h> | ||||||
|  | #include <unistd.h> | ||||||
|  | #include <sys/types.h> | ||||||
|  | #include "stub.h" | ||||||
|  | #include "weak_under_alias.h" | ||||||
|  | 
 | ||||||
|  | off_t __wrap_lseek(int fd, off_t ptr, int dir) | ||||||
|  | { | ||||||
|  |   if (isatty(fd)) | ||||||
|  |     return 0; | ||||||
|  | 
 | ||||||
|  |   return _stub(EBADF); | ||||||
|  | } | ||||||
|  | weak_under_alias(lseek); | ||||||
|  | @ -0,0 +1,11 @@ | ||||||
|  | /* See LICENSE of license details. */ | ||||||
|  | 
 | ||||||
|  | #include <errno.h> | ||||||
|  | #include "stub.h" | ||||||
|  | #include "weak_under_alias.h" | ||||||
|  | 
 | ||||||
|  | int __wrap_open(const char* name, int flags, int mode) | ||||||
|  | { | ||||||
|  |   return _stub(ENOENT); | ||||||
|  | } | ||||||
|  | weak_under_alias(open); | ||||||
|  | @ -0,0 +1,11 @@ | ||||||
|  | /* See LICENSE of license details. */ | ||||||
|  | 
 | ||||||
|  | #include <errno.h> | ||||||
|  | #include "stub.h" | ||||||
|  | #include "weak_under_alias.h" | ||||||
|  | 
 | ||||||
|  | int __wrap_openat(int dirfd, const char* name, int flags, int mode) | ||||||
|  | { | ||||||
|  |   return _stub(ENOENT); | ||||||
|  | } | ||||||
|  | weak_under_alias(openat); | ||||||
|  | @ -0,0 +1,28 @@ | ||||||
|  | /* See LICENSE of license details. */ | ||||||
|  | 
 | ||||||
|  | #include <stdint.h> | ||||||
|  | #include <errno.h> | ||||||
|  | #include <unistd.h> | ||||||
|  | #include <sys/types.h> | ||||||
|  | 
 | ||||||
|  | #include "platform.h" | ||||||
|  | #include "stub.h" | ||||||
|  | #include "weak_under_alias.h" | ||||||
|  | 
 | ||||||
|  | int __wrap_puts(const char *s) | ||||||
|  | { | ||||||
|  |   while (*s != '\0') { | ||||||
|  |     while (UART0_REG(UART_REG_TXFIFO) & 0x80000000) ; | ||||||
|  |     UART0_REG(UART_REG_TXFIFO) = *s; | ||||||
|  | 
 | ||||||
|  |     if (*s == '\n') { | ||||||
|  |       while (UART0_REG(UART_REG_TXFIFO) & 0x80000000) ; | ||||||
|  |       UART0_REG(UART_REG_TXFIFO) = '\r'; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     ++s; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
|  | weak_under_alias(puts); | ||||||
|  | @ -0,0 +1,32 @@ | ||||||
|  | /* See LICENSE of license details. */ | ||||||
|  | 
 | ||||||
|  | #include <stdint.h> | ||||||
|  | #include <errno.h> | ||||||
|  | #include <unistd.h> | ||||||
|  | #include <sys/types.h> | ||||||
|  | 
 | ||||||
|  | #include "platform.h" | ||||||
|  | #include "stub.h" | ||||||
|  | #include "weak_under_alias.h" | ||||||
|  | 
 | ||||||
|  | ssize_t __wrap_read(int fd, void* ptr, size_t len) | ||||||
|  | { | ||||||
|  |   uint8_t * current = (uint8_t *)ptr; | ||||||
|  |   volatile uint32_t * uart_rx = (uint32_t *)(UART0_CTRL_ADDR + UART_REG_RXFIFO); | ||||||
|  |   volatile uint8_t * uart_rx_cnt = (uint8_t *)(UART0_CTRL_ADDR + UART_REG_RXCTRL + 2); | ||||||
|  | 
 | ||||||
|  |   ssize_t result = 0; | ||||||
|  | 
 | ||||||
|  |   if (isatty(fd)) { | ||||||
|  |     for (current = (uint8_t *)ptr; | ||||||
|  |         (current < ((uint8_t *)ptr) + len) && (*uart_rx_cnt > 0); | ||||||
|  |         current ++) { | ||||||
|  |       *current = *uart_rx; | ||||||
|  |       result++; | ||||||
|  |     } | ||||||
|  |     return result; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   return _stub(EBADF); | ||||||
|  | } | ||||||
|  | weak_under_alias(read); | ||||||
|  | @ -0,0 +1,18 @@ | ||||||
|  | /* See LICENSE of license details. */ | ||||||
|  | 
 | ||||||
|  | #include <stddef.h> | ||||||
|  | #include "weak_under_alias.h" | ||||||
|  | 
 | ||||||
|  | void *__wrap_sbrk(ptrdiff_t incr) | ||||||
|  | { | ||||||
|  |   extern char _end[]; | ||||||
|  |   extern char _heap_end[]; | ||||||
|  |   static char *curbrk = _end; | ||||||
|  | 
 | ||||||
|  |   if ((curbrk + incr < _end) || (curbrk + incr > _heap_end)) | ||||||
|  |     return NULL - 1; | ||||||
|  | 
 | ||||||
|  |   curbrk += incr; | ||||||
|  |   return curbrk - incr; | ||||||
|  | } | ||||||
|  | weak_under_alias(sbrk); | ||||||
|  | @ -0,0 +1,12 @@ | ||||||
|  | /* See LICENSE of license details. */ | ||||||
|  | 
 | ||||||
|  | #include <errno.h> | ||||||
|  | #include <sys/stat.h> | ||||||
|  | #include "stub.h" | ||||||
|  | #include "weak_under_alias.h" | ||||||
|  | 
 | ||||||
|  | int __wrap_stat(const char* file, struct stat* st) | ||||||
|  | { | ||||||
|  |   return _stub(EACCES); | ||||||
|  | } | ||||||
|  | weak_under_alias(stat); | ||||||
|  | @ -0,0 +1,10 @@ | ||||||
|  | /* See LICENSE of license details. */ | ||||||
|  | #ifndef _SIFIVE_SYS_STUB_H | ||||||
|  | #define _SIFIVE_SYS_STUB_H | ||||||
|  | 
 | ||||||
|  | static inline int _stub(int err) | ||||||
|  | { | ||||||
|  |   return -1; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #endif /* _SIFIVE_SYS_STUB_H */ | ||||||
|  | @ -0,0 +1,12 @@ | ||||||
|  | /* See LICENSE of license details. */ | ||||||
|  | 
 | ||||||
|  | #include <errno.h> | ||||||
|  | #include <sys/times.h> | ||||||
|  | #include "stub.h" | ||||||
|  | #include "weak_under_alias.h" | ||||||
|  | 
 | ||||||
|  | clock_t __wrap_times(struct tms* buf) | ||||||
|  | { | ||||||
|  |   return _stub(EACCES); | ||||||
|  | } | ||||||
|  | weak_under_alias(times); | ||||||
|  | @ -0,0 +1,11 @@ | ||||||
|  | /* See LICENSE of license details. */ | ||||||
|  | 
 | ||||||
|  | #include <errno.h> | ||||||
|  | #include "stub.h" | ||||||
|  | #include "weak_under_alias.h" | ||||||
|  | 
 | ||||||
|  | int __wrap_unlink(const char* name) | ||||||
|  | { | ||||||
|  |   return _stub(ENOENT); | ||||||
|  | } | ||||||
|  | weak_under_alias(unlink); | ||||||
|  | @ -0,0 +1,9 @@ | ||||||
|  | /* See LICENSE of license details. */ | ||||||
|  | 
 | ||||||
|  | #include <errno.h> | ||||||
|  | #include "stub.h" | ||||||
|  | 
 | ||||||
|  | int wait(int* status) | ||||||
|  | { | ||||||
|  |   return _stub(ECHILD); | ||||||
|  | } | ||||||
|  | @ -0,0 +1,7 @@ | ||||||
|  | #ifndef _BSP_LIBWRAP_WEAK_UNDER_ALIAS_H | ||||||
|  | #define _BSP_LIBWRAP_WEAK_UNDER_ALIAS_H | ||||||
|  | 
 | ||||||
|  | #define weak_under_alias(name) \ | ||||||
|  |   extern __typeof (__wrap_##name) __wrap__##name __attribute__ ((weak, alias ("__wrap_"#name))) | ||||||
|  | 
 | ||||||
|  | #endif | ||||||
|  | @ -0,0 +1,31 @@ | ||||||
|  | /* See LICENSE of license details. */ | ||||||
|  | 
 | ||||||
|  | #include <stdint.h> | ||||||
|  | #include <errno.h> | ||||||
|  | #include <unistd.h> | ||||||
|  | #include <sys/types.h> | ||||||
|  | 
 | ||||||
|  | #include "platform.h" | ||||||
|  | #include "stub.h" | ||||||
|  | #include "weak_under_alias.h" | ||||||
|  | 
 | ||||||
|  | ssize_t __wrap_write(int fd, const void* ptr, size_t len) | ||||||
|  | { | ||||||
|  |   const uint8_t * current = (const char *)ptr; | ||||||
|  | 
 | ||||||
|  |   if (isatty(fd)) { | ||||||
|  |     for (size_t jj = 0; jj < len; jj++) { | ||||||
|  |       while (UART0_REG(UART_REG_TXFIFO) & 0x80000000) ; | ||||||
|  |       UART0_REG(UART_REG_TXFIFO) = current[jj]; | ||||||
|  | 
 | ||||||
|  |       if (current[jj] == '\n') { | ||||||
|  |         while (UART0_REG(UART_REG_TXFIFO) & 0x80000000) ; | ||||||
|  |         UART0_REG(UART_REG_TXFIFO) = '\r'; | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     return len; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   return _stub(EBADF); | ||||||
|  | } | ||||||
|  | weak_under_alias(write); | ||||||
							
								
								
									
										258
									
								
								FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/main.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										258
									
								
								FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/main.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,258 @@ | ||||||
|  | // See LICENSE for license details.
 | ||||||
|  | 
 | ||||||
|  | #include <stdio.h> | ||||||
|  | #include <stdlib.h> | ||||||
|  | #include "platform.h" | ||||||
|  | #include <string.h> | ||||||
|  | #include "plic/plic_driver.h" | ||||||
|  | #include "encoding.h" | ||||||
|  | #include <unistd.h> | ||||||
|  | #include "stdatomic.h" | ||||||
|  | 
 | ||||||
|  | void reset_demo (void); | ||||||
|  | 
 | ||||||
|  | // Structures for registering different interrupt handlers
 | ||||||
|  | // for different parts of the application.
 | ||||||
|  | typedef void (*function_ptr_t) (void); | ||||||
|  | 
 | ||||||
|  | void no_interrupt_handler (void) {}; | ||||||
|  | 
 | ||||||
|  | function_ptr_t g_ext_interrupt_handlers[PLIC_NUM_INTERRUPTS]; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | // Instance data for the PLIC.
 | ||||||
|  | 
 | ||||||
|  | plic_instance_t g_plic; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | /*Entry Point for PLIC Interrupt Handler*/ | ||||||
|  | void handle_m_ext_interrupt(){ | ||||||
|  |   plic_source int_num  = PLIC_claim_interrupt(&g_plic); | ||||||
|  |   if ((int_num >=1 ) && (int_num < PLIC_NUM_INTERRUPTS)) { | ||||||
|  |     g_ext_interrupt_handlers[int_num](); | ||||||
|  |   } | ||||||
|  |   else { | ||||||
|  |     exit(1 + (uintptr_t) int_num); | ||||||
|  |   } | ||||||
|  |   PLIC_complete_interrupt(&g_plic, int_num); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | /*Entry Point for Machine Timer Interrupt Handler*/ | ||||||
|  | void handle_m_time_interrupt(){ | ||||||
|  | 
 | ||||||
|  |   clear_csr(mie, MIP_MTIP); | ||||||
|  | 
 | ||||||
|  |   // Reset the timer for 3s in the future.
 | ||||||
|  |   // This also clears the existing timer interrupt.
 | ||||||
|  | 
 | ||||||
|  |   volatile uint64_t * mtime       = (uint64_t*) (CLINT_CTRL_ADDR + CLINT_MTIME); | ||||||
|  |   volatile uint64_t * mtimecmp    = (uint64_t*) (CLINT_CTRL_ADDR + CLINT_MTIMECMP); | ||||||
|  |   uint64_t now = *mtime; | ||||||
|  |   uint64_t then = now + 2 * RTC_FREQ; | ||||||
|  |   *mtimecmp = then; | ||||||
|  | 
 | ||||||
|  |   // read the current value of the LEDS and invert them.
 | ||||||
|  |   uint32_t leds = GPIO_REG(GPIO_OUTPUT_VAL); | ||||||
|  | 
 | ||||||
|  |   GPIO_REG(GPIO_OUTPUT_VAL) ^= ((0x1 << RED_LED_OFFSET)   | | ||||||
|  | 				(0x1 << GREEN_LED_OFFSET) | | ||||||
|  | 				(0x1 << BLUE_LED_OFFSET)); | ||||||
|  |    | ||||||
|  |   // Re-enable the timer interrupt.
 | ||||||
|  |   set_csr(mie, MIP_MTIP); | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | const char * instructions_msg = " \
 | ||||||
|  | \n\ | ||||||
|  |                 SIFIVE, INC.\n\ | ||||||
|  | \n\ | ||||||
|  |          5555555555555555555555555\n\ | ||||||
|  |         5555                   5555\n\ | ||||||
|  |        5555                     5555\n\ | ||||||
|  |       5555                       5555\n\ | ||||||
|  |      5555       5555555555555555555555\n\ | ||||||
|  |     5555       555555555555555555555555\n\ | ||||||
|  |    5555                             5555\n\ | ||||||
|  |   5555                               5555\n\ | ||||||
|  |  5555                                 5555\n\ | ||||||
|  | 5555555555555555555555555555          55555\n\ | ||||||
|  |  55555           555555555           55555\n\ | ||||||
|  |    55555           55555           55555\n\ | ||||||
|  |      55555           5           55555\n\ | ||||||
|  |        55555                   55555\n\ | ||||||
|  |          55555               55555\n\ | ||||||
|  |            55555           55555\n\ | ||||||
|  |              55555       55555\n\ | ||||||
|  |                55555   55555\n\ | ||||||
|  |                  555555555\n\ | ||||||
|  |                    55555\n\ | ||||||
|  |                      5\n\ | ||||||
|  | \n\ | ||||||
|  | SiFive E-Series Software Development Kit 'demo_gpio' program.\n\ | ||||||
|  | Every 2 second, the Timer Interrupt will invert the LEDs.\n\ | ||||||
|  | (Arty Dev Kit Only): Press Buttons 0, 1, 2 to Set the LEDs.\n\ | ||||||
|  | Pin 19 (HiFive1) or A5 (Arty Dev Kit) is being bit-banged\n\ | ||||||
|  | for GPIO speed demonstration.\n\ | ||||||
|  | \n\ | ||||||
|  |  "; | ||||||
|  | 
 | ||||||
|  | void print_instructions() { | ||||||
|  | 
 | ||||||
|  |   write (STDOUT_FILENO, instructions_msg, strlen(instructions_msg)); | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #ifdef HAS_BOARD_BUTTONS | ||||||
|  | void button_0_handler(void) { | ||||||
|  | 
 | ||||||
|  |   // Red LED on
 | ||||||
|  |   GPIO_REG(GPIO_OUTPUT_VAL) |= (0x1 << RED_LED_OFFSET); | ||||||
|  | 
 | ||||||
|  |   // Clear the GPIO Pending interrupt by writing 1.
 | ||||||
|  |   GPIO_REG(GPIO_RISE_IP) = (0x1 << BUTTON_0_OFFSET); | ||||||
|  | 
 | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | void button_1_handler(void) { | ||||||
|  | 
 | ||||||
|  |   // Green LED On
 | ||||||
|  |   GPIO_REG(GPIO_OUTPUT_VAL) |= (1 << GREEN_LED_OFFSET); | ||||||
|  | 
 | ||||||
|  |   // Clear the GPIO Pending interrupt by writing 1.
 | ||||||
|  |   GPIO_REG(GPIO_RISE_IP) = (0x1 << BUTTON_1_OFFSET); | ||||||
|  | 
 | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | void button_2_handler(void) { | ||||||
|  | 
 | ||||||
|  |   // Blue LED On
 | ||||||
|  |   GPIO_REG(GPIO_OUTPUT_VAL) |= (1 << BLUE_LED_OFFSET); | ||||||
|  | 
 | ||||||
|  |   GPIO_REG(GPIO_RISE_IP) = (0x1 << BUTTON_2_OFFSET); | ||||||
|  | 
 | ||||||
|  | }; | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | void reset_demo (){ | ||||||
|  | 
 | ||||||
|  |   // Disable the machine & timer interrupts until setup is done.
 | ||||||
|  | 
 | ||||||
|  |   clear_csr(mie, MIP_MEIP); | ||||||
|  |   clear_csr(mie, MIP_MTIP); | ||||||
|  | 
 | ||||||
|  |   for (int ii = 0; ii < PLIC_NUM_INTERRUPTS; ii ++){ | ||||||
|  |     g_ext_interrupt_handlers[ii] = no_interrupt_handler; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  | #ifdef HAS_BOARD_BUTTONS | ||||||
|  |   g_ext_interrupt_handlers[INT_DEVICE_BUTTON_0] = button_0_handler; | ||||||
|  |   g_ext_interrupt_handlers[INT_DEVICE_BUTTON_1] = button_1_handler; | ||||||
|  |   g_ext_interrupt_handlers[INT_DEVICE_BUTTON_2] = button_2_handler; | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  |   print_instructions(); | ||||||
|  | 
 | ||||||
|  | #ifdef HAS_BOARD_BUTTONS | ||||||
|  | 
 | ||||||
|  |   // Have to enable the interrupt both at the GPIO level,
 | ||||||
|  |   // and at the PLIC level.
 | ||||||
|  |   PLIC_enable_interrupt (&g_plic, INT_DEVICE_BUTTON_0); | ||||||
|  |   PLIC_enable_interrupt (&g_plic, INT_DEVICE_BUTTON_1); | ||||||
|  |   PLIC_enable_interrupt (&g_plic, INT_DEVICE_BUTTON_2); | ||||||
|  | 
 | ||||||
|  |   // Priority must be set > 0 to trigger the interrupt.
 | ||||||
|  |   PLIC_set_priority(&g_plic, INT_DEVICE_BUTTON_0, 1); | ||||||
|  |   PLIC_set_priority(&g_plic, INT_DEVICE_BUTTON_1, 1); | ||||||
|  |   PLIC_set_priority(&g_plic, INT_DEVICE_BUTTON_2, 1); | ||||||
|  | 
 | ||||||
|  |   GPIO_REG(GPIO_RISE_IE) |= (1 << BUTTON_0_OFFSET); | ||||||
|  |   GPIO_REG(GPIO_RISE_IE) |= (1 << BUTTON_1_OFFSET); | ||||||
|  |   GPIO_REG(GPIO_RISE_IE) |= (1 << BUTTON_2_OFFSET); | ||||||
|  | 
 | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  |     // Set the machine timer to go off in 3 seconds.
 | ||||||
|  |     // The
 | ||||||
|  |     volatile uint64_t * mtime       = (uint64_t*) (CLINT_CTRL_ADDR + CLINT_MTIME); | ||||||
|  |     volatile uint64_t * mtimecmp    = (uint64_t*) (CLINT_CTRL_ADDR + CLINT_MTIMECMP); | ||||||
|  |     uint64_t now = *mtime; | ||||||
|  |     uint64_t then = now + 2*RTC_FREQ; | ||||||
|  |     *mtimecmp = then; | ||||||
|  | 
 | ||||||
|  |     // Enable the Machine-External bit in MIE
 | ||||||
|  |     set_csr(mie, MIP_MEIP); | ||||||
|  | 
 | ||||||
|  |     // Enable the Machine-Timer bit in MIE
 | ||||||
|  |     set_csr(mie, MIP_MTIP); | ||||||
|  | 
 | ||||||
|  |     // Enable interrupts in general.
 | ||||||
|  |     set_csr(mstatus, MSTATUS_MIE); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | int main(int argc, char **argv) | ||||||
|  | { | ||||||
|  |   // Set up the GPIOs such that the LED GPIO
 | ||||||
|  |   // can be used as both Inputs and Outputs.
 | ||||||
|  |    | ||||||
|  | 
 | ||||||
|  | #ifdef HAS_BOARD_BUTTONS | ||||||
|  |   GPIO_REG(GPIO_OUTPUT_EN)  &= ~((0x1 << BUTTON_0_OFFSET) | (0x1 << BUTTON_1_OFFSET) | (0x1 << BUTTON_2_OFFSET)); | ||||||
|  |   GPIO_REG(GPIO_PULLUP_EN)  &= ~((0x1 << BUTTON_0_OFFSET) | (0x1 << BUTTON_1_OFFSET) | (0x1 << BUTTON_2_OFFSET)); | ||||||
|  |   GPIO_REG(GPIO_INPUT_EN)   |=  ((0x1 << BUTTON_0_OFFSET) | (0x1 << BUTTON_1_OFFSET) | (0x1 << BUTTON_2_OFFSET)); | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  |   GPIO_REG(GPIO_INPUT_EN)    &= ~((0x1<< RED_LED_OFFSET) | (0x1<< GREEN_LED_OFFSET) | (0x1 << BLUE_LED_OFFSET)) ; | ||||||
|  |   GPIO_REG(GPIO_OUTPUT_EN)   |=  ((0x1<< RED_LED_OFFSET)| (0x1<< GREEN_LED_OFFSET) | (0x1 << BLUE_LED_OFFSET)) ; | ||||||
|  |   GPIO_REG(GPIO_OUTPUT_VAL)  |=   (0x1 << BLUE_LED_OFFSET) ; | ||||||
|  |   GPIO_REG(GPIO_OUTPUT_VAL)  &=  ~((0x1<< RED_LED_OFFSET) | (0x1<< GREEN_LED_OFFSET)) ; | ||||||
|  | 
 | ||||||
|  |    | ||||||
|  |   // For Bit-banging with Atomics demo.
 | ||||||
|  |    | ||||||
|  |   uint32_t bitbang_mask = 0; | ||||||
|  | #ifdef _SIFIVE_HIFIVE1_H | ||||||
|  |   bitbang_mask = (1 << PIN_19_OFFSET); | ||||||
|  | #else | ||||||
|  | #ifdef _SIFIVE_COREPLEXIP_ARTY_H | ||||||
|  |   bitbang_mask = (0x1 << JA_0_OFFSET); | ||||||
|  | #endif | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  |   GPIO_REG(GPIO_OUTPUT_EN) |= bitbang_mask; | ||||||
|  |    | ||||||
|  |   /**************************************************************************
 | ||||||
|  |    * Set up the PLIC | ||||||
|  |    * | ||||||
|  |    *************************************************************************/ | ||||||
|  |   PLIC_init(&g_plic, | ||||||
|  | 	    PLIC_CTRL_ADDR, | ||||||
|  | 	    PLIC_NUM_INTERRUPTS, | ||||||
|  | 	    PLIC_NUM_PRIORITIES); | ||||||
|  | 
 | ||||||
|  |   reset_demo(); | ||||||
|  | 
 | ||||||
|  |   /**************************************************************************
 | ||||||
|  |    * Demonstrate fast GPIO bit-banging. | ||||||
|  |    * One can bang it faster than this if you know | ||||||
|  |    * the entire OUTPUT_VAL that you want to write, but  | ||||||
|  |    * Atomics give a quick way to control a single bit. | ||||||
|  |    *************************************************************************/ | ||||||
|  |   // For Bit-banging with Atomics demo.
 | ||||||
|  |    | ||||||
|  |   while (1){ | ||||||
|  |     atomic_fetch_xor_explicit(&GPIO_REG(GPIO_OUTPUT_VAL), bitbang_mask, memory_order_relaxed); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   return 0; | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | void trap_entry( void ) | ||||||
|  | { | ||||||
|  | #warning Dummy until kernel code is incldued. | ||||||
|  | } | ||||||
|  | @ -0,0 +1,34 @@ | ||||||
|  | adapter_khz     10000 | ||||||
|  | 
 | ||||||
|  | interface ftdi | ||||||
|  | ftdi_device_desc "Dual RS232-HS" | ||||||
|  | ftdi_vid_pid 0x0403 0x6010 | ||||||
|  | 
 | ||||||
|  | ftdi_layout_init 0x0008 0x001b | ||||||
|  | ftdi_layout_signal nSRST -oe 0x0020 -data 0x0020 | ||||||
|  | 
 | ||||||
|  | #Reset Stretcher logic on FE310 is ~1 second long | ||||||
|  | #This doesn't apply if you use | ||||||
|  | # ftdi_set_signal, but still good to document | ||||||
|  | #adapter_nsrst_delay 1500 | ||||||
|  | 
 | ||||||
|  | set _CHIPNAME riscv | ||||||
|  | jtag newtap $_CHIPNAME cpu -irlen 5 -expected-id 0x10e31913 | ||||||
|  | 
 | ||||||
|  | set _TARGETNAME $_CHIPNAME.cpu | ||||||
|  | target create $_TARGETNAME riscv -chain-position $_TARGETNAME | ||||||
|  | $_TARGETNAME configure -work-area-phys 0x80000000 -work-area-size 10000 -work-area-backup 1 | ||||||
|  | 
 | ||||||
|  | flash bank onboard_spi_flash fespi 0x20000000 0 0 0 $_TARGETNAME | ||||||
|  | init | ||||||
|  | #reset -- This type of reset is not implemented yet | ||||||
|  | if {[ info exists pulse_srst]} { | ||||||
|  |   ftdi_set_signal nSRST 0 | ||||||
|  |   ftdi_set_signal nSRST z | ||||||
|  |   #Wait for the reset stretcher | ||||||
|  |   #It will work without this, but | ||||||
|  |   #will incur lots of delays for later commands. | ||||||
|  |   sleep 1500 | ||||||
|  | }	 | ||||||
|  | halt | ||||||
|  | flash protect 0 64 last off | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue