Compare commits
	
		
			263 Commits
		
	
	
		
			bc4ea30815
			...
			develop
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 937253f7aa | |||
| 98df7d2a74 | |||
| f57f9f9177 | |||
| 6f08f4010c | |||
| c9c47673d9 | |||
| c1aed64a41 | |||
| d5d195845c | |||
| 9fcbeb478b | |||
| a768bde7f2 | |||
| cd866fd74d | |||
| 67f364049c | |||
| 047e2e12b0 | |||
| fe3ed49519 | |||
| 1afd77a942 | |||
| cdf5038e59 | |||
| 651897e1e4 | |||
| a1803c61c1 | |||
| bfa2182f8e | |||
| b01c9b27e5 | |||
| 07f394d5ff | |||
| 7e97329e78 | |||
| 8f5d666b7d | |||
| cc123939ce | |||
| a2e5405e25 | |||
| cd3ec0b79d | |||
| 0e35a2a8c9 | |||
| 8220c00a3d | |||
| ec5fb1e87e | |||
| 453407568c | |||
| 0fe9e6ebc8 | |||
| 484d9dbe08 | |||
| 7a7035f267 | |||
| d9f1e5d31b | |||
| 7b35f45a48 | |||
| ece6f7290f | |||
| 2166a6d81e | |||
| fe9f2a5455 | |||
| 42bf6ee380 | |||
| f0b582df6c | |||
| 6fcb3dbb66 | |||
| c01eb39a76 | |||
| 08280a094f | |||
| ae90adc854 | |||
| cd358198ad | |||
| 8746003d3e | |||
| 60d2b45a81 | |||
| 0264c5d66f | |||
| 528c2536af | |||
| 19e38ec898 | |||
| fd11ce18c4 | |||
| 9b7a9fa273 | |||
| e24c1874c4 | |||
| 221d2ee38c | |||
| 877cad27ba | |||
| a26505cb5c | |||
| c1277b6528 | |||
| 63889b02e7 | |||
| f049d8cbb3 | |||
| 28ac169cfe | |||
| a6f24db83a | |||
| e1911bc450 | |||
| 75d96bf18d | |||
| e59458aa0e | |||
| 77807fec01 | |||
| 6852d1d299 | |||
| ac1322d66b | |||
| 9ba9d2432c | |||
| c9b7962cd3 | |||
| ab31fd27c9 | |||
| b3f189145f | |||
| dd4416ab15 | |||
| 0027946f90 | |||
| feaff8c4a5 | |||
| af3e76cc98 | |||
| b1ceac2c2a | |||
| b5862039e7 | |||
| 51f3802394 | |||
| 6ce0d97e81 | |||
| 69c8fda5d2 | |||
| c1f9328528 | |||
| 2b85748279 | |||
| f7aa51b12e | |||
| 3428745a00 | |||
| 512b79a3e7 | |||
| 7a048f8b93 | |||
| 6f4daf91ed | |||
| 947d353bbf | |||
| b95f518c91 | |||
| 4cef0f57c1 | |||
| 28af695592 | |||
| f6cdd9d07c | |||
| 9e390971d4 | |||
| 2bb2e56310 | |||
| a0eeae7dd6 | |||
| 8f491ef36b | |||
| cbe4c2d62f | |||
| 31c6bb55f4 | |||
| 63d0162119 | |||
| 3b294d9da0 | |||
| 54233b448d | |||
| e238369e18 | |||
| cfc980a069 | |||
| 502f3e8df9 | |||
| 88475bfa55 | |||
| 71260a3ef4 | |||
| 23842742a6 | |||
| a13b7ac6d3 | |||
| aaebeaf023 | |||
| fb0f6255e9 | |||
| 57d5ea92be | |||
| 383d762abc | |||
| 03cbd305c6 | |||
| 9f5326c110 | |||
| f4718c6de3 | |||
| 53de21eef9 | |||
| d443c89c87 | |||
| 9a2df32d57 | |||
| be0f783af8 | |||
| 1089800682 | |||
| a6a6f51f0b | |||
| 21e1f791ad | |||
| be6f5791fa | |||
| d907dc7f54 | |||
| 75e81ce236 | |||
| 82a70efdb8 | |||
| 978c3db06e | |||
| 0e88664ff7 | |||
| ac818f304d | |||
| ad60449073 | |||
| b45b3589fa | |||
| 1fb7e8fcea | |||
| 5f9d0beafb | |||
| 4c0d1c75aa | |||
| 2f3abf2f76 | |||
| 62768bf81e | |||
| f6be8ec006 | |||
| a8f56b6e27 | |||
| 76ea0db25d | |||
| ec1b820c18 | |||
| 64329cf0f6 | |||
| 9de0aed84d | |||
| bb4e2766d1 | |||
| 0996d15bd4 | |||
| 6305efa7c2 | |||
| de79adc50d | |||
| 0473aa5344 | |||
| a45fcd28db | |||
| 0f15032210 | |||
| efc11d87a5 | |||
| 4a19e27926 | |||
| c15cdb0955 | |||
| 6609d12582 | |||
| b5341700aa | |||
| 0b5062d21c | |||
| fbca690b3b | |||
| 235a7e6e24 | |||
| 62d21e1156 | |||
| 9c51d6eade | |||
| 2878dca6b5 | |||
| c28e8fd00c | |||
| b3cc9d2346 | |||
| 933f08494c | |||
| 21f8eab432 | |||
| 6ddb8da07f | |||
| edf456c59f | |||
| 42efced1eb | |||
| c376e34b2b | |||
| f579ec6e48 | |||
| fd20e66f1f | |||
| 5d69b79232 | |||
| 2edd68d1bd | |||
| 7ffa7667b6 | |||
| 93d89e07ca | |||
| 17dcba4b90 | |||
| 39d2518fdd | |||
| a365110054 | |||
| d2efb23ff7 | |||
| 04b7a09b19 | |||
| 72b11beac5 | |||
| e87b7d5fd0 | |||
| 5a2b96ef3e | |||
| c6b99cd155 | |||
| b1306c3a47 | |||
| 0d6bf924ed | |||
| 86de536c8f | |||
| 051dd5e2d3 | |||
| e3942be776 | |||
| 6ee484a771 | |||
| 60808c8649 | |||
| 0432803d82 | |||
| 4f5d9214ed | |||
| d42d2ce533 | |||
| 236d12d7f5 | |||
| e1b6cab890 | |||
| 8361f88718 | |||
| 2ec7ea4b41 | |||
| b24965d321 | |||
| 244bf6d2f2 | |||
| 1a4465a371 | |||
| fa82a50824 | |||
| 6dc17857da | |||
| 11a30caae8 | |||
| ac1a26a10c | |||
| 7a199e122d | |||
| d8c3d2e19c | |||
| 375755999a | |||
| 9996fd4833 | |||
| 149b3136d2 | |||
| ac8f8b0539 | |||
| b2cbf90d0b | |||
| 373145478e | |||
| 55b0cea94f | |||
| 5b17599aa2 | |||
| 4cfb15c7cd | |||
| 63da7f8d57 | |||
| fb4012fbd1 | |||
| 24449f1c0f | |||
| fd303c8343 | |||
| 346b177a87 | |||
| d4ec131fa7 | |||
| 48370a4555 | |||
| 36b076774e | |||
| 482a4ec253 | |||
| 2fb28364c5 | |||
| 8460f4ab7f | |||
| 3fd51cc68c | |||
| 551822916c | |||
| 37db31fb4b | |||
| e2da306eee | |||
| 41051f8f34 | |||
| 2a7449fa1e | |||
|   | a6c48ceaac | ||
| 1e30b68507 | |||
|   | ed793471bb | ||
| 58fb815f32 | |||
| 3cc8bd0854 | |||
| a27850f841 | |||
| fb330cddea | |||
| b76c5bf0d6 | |||
| 001c6349f7 | |||
| ee6a11dae6 | |||
| 2e27b025cc | |||
| f0a004be9d | |||
| 3422c7cd5c | |||
| ad79a28705 | |||
| 9fdbc3ff38 | |||
| 602bc6e06a | |||
| 6cb76fc256 | |||
| fbcd389580 | |||
| b25b7848c6 | |||
| 6c986d38d8 | |||
| a1ebd83d2a | |||
| 8aed551813 | |||
| 1e6a0086e9 | |||
| 119d4a8b43 | |||
| 9841b16122 | |||
| fbda1424f3 | |||
| fe2d5cb2f9 | |||
| 3ff59ba45d | |||
| db5765b342 | |||
| 075e04249a | |||
| 207f778ee6 | |||
| f4f90c5e65 | 
							
								
								
									
										249
									
								
								CMakeLists.txt
									
									
									
									
									
								
							
							
						
						
									
										249
									
								
								CMakeLists.txt
									
									
									
									
									
								
							| @@ -1,8 +1,9 @@ | ||||
| cmake_minimum_required(VERSION 3.12) | ||||
| cmake_minimum_required(VERSION 3.18) | ||||
| list(APPEND CMAKE_MODULE_PATH ${CMAKE_CURRENT_SOURCE_DIR}/cmake) | ||||
| ############################################################################### | ||||
|  | ||||
| # ############################################################################## | ||||
| # | ||||
| ############################################################################### | ||||
| # ############################################################################## | ||||
| project(dbt-rise-tgc VERSION 1.0.0) | ||||
|  | ||||
| include(GNUInstallDirs) | ||||
| @@ -14,59 +15,72 @@ find_package(Boost COMPONENTS coroutine REQUIRED) | ||||
|  | ||||
| add_subdirectory(softfloat) | ||||
|  | ||||
| set(LIB_SOURCES  | ||||
| set(LIB_SOURCES | ||||
|     src/iss/plugin/instruction_count.cpp | ||||
| 	src/iss/arch/tgc5c.cpp | ||||
| 	src/vm/interp/vm_tgc5c.cpp | ||||
| 	src/vm/fp_functions.cpp | ||||
|     src/iss/arch/tgc5c.cpp | ||||
|     src/iss/mem/memory_if.cpp | ||||
|     src/vm/interp/vm_tgc5c.cpp | ||||
|     src/vm/fp_functions.cpp | ||||
|     src/vm/vector_functions.cpp | ||||
|     src/iss/debugger/csr_names.cpp | ||||
|     src/iss/semihosting/semihosting.cpp | ||||
| ) | ||||
|  | ||||
| if(WITH_TCC) | ||||
| 	list(APPEND LIB_SOURCES | ||||
| 	   src/vm/tcc/vm_tgc5c.cpp | ||||
|     list(APPEND LIB_SOURCES | ||||
|         src/vm/tcc/vm_tgc5c.cpp | ||||
|     ) | ||||
| endif() | ||||
|  | ||||
| if(WITH_LLVM) | ||||
| 	list(APPEND LIB_SOURCES | ||||
| 		src/vm/llvm/vm_tgc5c.cpp | ||||
| 		src/vm/llvm/fp_impl.cpp | ||||
| 	) | ||||
| endif() | ||||
| if(WITH_ASMJIT) | ||||
| 	list(APPEND LIB_SOURCES | ||||
| 	   src/vm/asmjit/vm_tgc5c.cpp | ||||
|     list(APPEND LIB_SOURCES | ||||
|         src/vm/llvm/vm_tgc5c.cpp | ||||
|         src/vm/llvm/fp_impl.cpp | ||||
|     ) | ||||
| endif() | ||||
|  | ||||
| if(WITH_ASMJIT) | ||||
|     list(APPEND LIB_SOURCES | ||||
|         src/vm/asmjit/vm_tgc5c.cpp | ||||
|     ) | ||||
| endif() | ||||
|  | ||||
| # library files | ||||
| FILE(GLOB GEN_ISS_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/src-gen/iss/arch/*.cpp) | ||||
| FILE(GLOB GEN_VM_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/src-gen/vm/interp/vm_*.cpp) | ||||
| FILE(GLOB GEN_YAML_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/contrib/instr/*.yaml) | ||||
| list(APPEND LIB_SOURCES ${GEN_ISS_SOURCES} ${GEN_VM_SOURCES}) | ||||
|  | ||||
| foreach(FILEPATH ${GEN_ISS_SOURCES}) | ||||
|     get_filename_component(CORE ${FILEPATH} NAME_WE) | ||||
|     string(TOUPPER ${CORE} CORE) | ||||
|     list(APPEND LIB_DEFINES CORE_${CORE}) | ||||
| endforeach() | ||||
|  | ||||
| message(STATUS "Core defines are ${LIB_DEFINES}") | ||||
|  | ||||
| if(WITH_LLVM) | ||||
| 	FILE(GLOB LLVM_GEN_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/src-gen/vm/llvm/vm_*.cpp) | ||||
| 	list(APPEND LIB_SOURCES ${LLVM_GEN_SOURCES}) | ||||
|     FILE(GLOB LLVM_GEN_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/src-gen/vm/llvm/vm_*.cpp) | ||||
|     list(APPEND LIB_SOURCES ${LLVM_GEN_SOURCES}) | ||||
| endif() | ||||
|  | ||||
| if(WITH_TCC) | ||||
| 	FILE(GLOB TCC_GEN_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/src-gen/vm/tcc/vm_*.cpp) | ||||
| 	list(APPEND LIB_SOURCES ${TCC_GEN_SOURCES}) | ||||
|     FILE(GLOB TCC_GEN_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/src-gen/vm/tcc/vm_*.cpp) | ||||
|     list(APPEND LIB_SOURCES ${TCC_GEN_SOURCES}) | ||||
| endif() | ||||
|  | ||||
| if(WITH_ASMJIT) | ||||
| 	FILE(GLOB TCC_GEN_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/src-gen/vm/asmjit/vm_*.cpp) | ||||
| 	list(APPEND LIB_SOURCES ${TCC_GEN_SOURCES}) | ||||
|     FILE(GLOB TCC_GEN_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/src-gen/vm/asmjit/vm_*.cpp) | ||||
|     list(APPEND LIB_SOURCES ${TCC_GEN_SOURCES}) | ||||
| endif() | ||||
|  | ||||
| if(TARGET yaml-cpp::yaml-cpp) | ||||
|     list(APPEND LIB_SOURCES  | ||||
|     	src/iss/plugin/cycle_estimate.cpp | ||||
| 	    src/iss/plugin/instruction_count.cpp | ||||
|     list(APPEND LIB_SOURCES | ||||
|         src/iss/plugin/cycle_estimate.cpp | ||||
|         src/iss/plugin/instruction_count.cpp | ||||
|     ) | ||||
| endif() | ||||
|  | ||||
| # Define the library | ||||
| add_library(${PROJECT_NAME} SHARED ${LIB_SOURCES}) | ||||
|  | ||||
| @@ -75,60 +89,57 @@ if("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU") | ||||
| elseif("${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC") | ||||
|     target_compile_options(${PROJECT_NAME} PRIVATE /wd4293) | ||||
| endif() | ||||
|  | ||||
| target_include_directories(${PROJECT_NAME} PUBLIC src) | ||||
| target_include_directories(${PROJECT_NAME} PUBLIC src-gen) | ||||
|  | ||||
| target_force_link_libraries(${PROJECT_NAME} PRIVATE dbt-rise-core) | ||||
|  | ||||
| # only re-export the include paths | ||||
| get_target_property(DBT_CORE_INCL dbt-rise-core INTERFACE_INCLUDE_DIRECTORIES) | ||||
| target_include_directories(${PROJECT_NAME} INTERFACE ${DBT_CORE_INCL}) | ||||
| get_target_property(DBT_CORE_DEFS dbt-rise-core INTERFACE_COMPILE_DEFINITIONS) | ||||
| if(NOT (DBT_CORE_DEFS STREQUAL DBT_CORE_DEFS-NOTFOUND)) | ||||
| 	target_compile_definitions(${PROJECT_NAME} INTERFACE ${DBT_CORE_DEFS}) | ||||
|  | ||||
| if(NOT(DBT_CORE_DEFS STREQUAL DBT_CORE_DEFS-NOTFOUND)) | ||||
|     target_compile_definitions(${PROJECT_NAME} INTERFACE ${DBT_CORE_DEFS}) | ||||
| endif() | ||||
|  | ||||
| target_link_libraries(${PROJECT_NAME} PUBLIC elfio::elfio softfloat scc-util Boost::coroutine) | ||||
| if(TARGET yaml-cpp::yaml-cpp) | ||||
| 	target_compile_definitions(${PROJECT_NAME} PUBLIC WITH_PLUGINS) | ||||
| 	target_link_libraries(${PROJECT_NAME} PUBLIC yaml-cpp::yaml-cpp) | ||||
| endif() | ||||
|  | ||||
| if(WITH_LLVM) | ||||
|     find_package(LLVM) | ||||
| 	target_compile_definitions(${PROJECT_NAME} PUBLIC ${LLVM_DEFINITIONS}) | ||||
| 	target_include_directories(${PROJECT_NAME} PUBLIC ${LLVM_INCLUDE_DIRS}) | ||||
| 	if(BUILD_SHARED_LIBS) | ||||
| 		target_link_libraries( ${PROJECT_NAME} PUBLIC ${LLVM_LIBRARIES}) | ||||
| 	endif() | ||||
| if(TARGET yaml-cpp::yaml-cpp) | ||||
|     target_compile_definitions(${PROJECT_NAME} PUBLIC WITH_PLUGINS) | ||||
|     target_link_libraries(${PROJECT_NAME} PUBLIC yaml-cpp::yaml-cpp) | ||||
| endif() | ||||
|  | ||||
| set_target_properties(${PROJECT_NAME} PROPERTIES | ||||
|   VERSION ${PROJECT_VERSION} | ||||
|   FRAMEWORK FALSE | ||||
|     VERSION ${PROJECT_VERSION} | ||||
|     FRAMEWORK FALSE | ||||
| ) | ||||
| install(TARGETS ${PROJECT_NAME} COMPONENT ${PROJECT_NAME} | ||||
|   EXPORT ${PROJECT_NAME}Targets            # for downstream dependencies | ||||
|   ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}  # static lib | ||||
|   RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}  # binaries | ||||
|   LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}  # shared lib | ||||
|   FRAMEWORK DESTINATION ${CMAKE_INSTALL_LIBDIR} # for mac | ||||
|   PUBLIC_HEADER DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME} # headers for mac (note the different component -> different package) | ||||
|   INCLUDES DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}             # headers | ||||
|     EXPORT ${PROJECT_NAME}Targets # for downstream dependencies | ||||
|     ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR} # static lib | ||||
|     RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR} # binaries | ||||
|     LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} # shared lib | ||||
|     FRAMEWORK DESTINATION ${CMAKE_INSTALL_LIBDIR} # for mac | ||||
|     PUBLIC_HEADER DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME} # headers for mac (note the different component -> different package) | ||||
|     INCLUDES DESTINATION ${CMAKE_INSTALL_INCLUDEDIR} # headers | ||||
| ) | ||||
| install(DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/incl/iss COMPONENT ${PROJECT_NAME} | ||||
|         DESTINATION ${CMAKE_INSTALL_INCLUDEDIR} # target directory | ||||
|         FILES_MATCHING # install only matched files | ||||
|         PATTERN "*.h" # select header files | ||||
|         ) | ||||
|     DESTINATION ${CMAKE_INSTALL_INCLUDEDIR} # target directory | ||||
|     FILES_MATCHING # install only matched files | ||||
|     PATTERN "*.h" # select header files | ||||
| ) | ||||
| install(FILES ${GEN_YAML_SOURCES} DESTINATION share/tgc-vp) | ||||
| ############################################################################### | ||||
|  | ||||
| # ############################################################################## | ||||
| # | ||||
| ############################################################################### | ||||
| # ############################################################################## | ||||
| set(CMAKE_INSTALL_RPATH $ORIGIN/../${CMAKE_INSTALL_LIBDIR}) | ||||
| project(tgc-sim) | ||||
| find_package(Boost COMPONENTS program_options thread REQUIRED) | ||||
|  | ||||
| add_executable(${PROJECT_NAME} src/main.cpp) | ||||
|  | ||||
| if(TARGET ${CORE_NAME}_cpp) | ||||
|     list(APPEND TGC_SOURCES ${${CORE_NAME}_OUTPUT_FILES}) | ||||
| else() | ||||
| @@ -140,21 +151,20 @@ else() | ||||
| endif() | ||||
|  | ||||
| foreach(F IN LISTS TGC_SOURCES) | ||||
|     if (${F} MATCHES ".*/arch/([^/]*)\.cpp") | ||||
|         string(REGEX REPLACE  ".*/([^/]*)\.cpp"  "\\1" CORE_NAME_LC ${F}) | ||||
|     if(${F} MATCHES ".*/arch/([^/]*)\.cpp") | ||||
|         string(REGEX REPLACE ".*/([^/]*)\.cpp" "\\1" CORE_NAME_LC ${F}) | ||||
|         string(TOUPPER ${CORE_NAME_LC} CORE_NAME) | ||||
|         target_compile_definitions(${PROJECT_NAME} PRIVATE CORE_${CORE_NAME}) | ||||
|     endif() | ||||
| endforeach() | ||||
|  | ||||
| #if(WITH_LLVM) | ||||
| #    target_compile_definitions(${PROJECT_NAME} PRIVATE WITH_LLVM) | ||||
| #    #target_link_libraries(${PROJECT_NAME} PUBLIC ${llvm_libs}) | ||||
| #endif() | ||||
| #if(WITH_TCC) | ||||
| #    target_compile_definitions(${PROJECT_NAME} PRIVATE WITH_TCC) | ||||
| #endif() | ||||
|  | ||||
| # if(WITH_LLVM) | ||||
| # target_compile_definitions(${PROJECT_NAME} PRIVATE WITH_LLVM) | ||||
| # #target_link_libraries(${PROJECT_NAME} PUBLIC ${llvm_libs}) | ||||
| # endif() | ||||
| # if(WITH_TCC) | ||||
| # target_compile_definitions(${PROJECT_NAME} PRIVATE WITH_TCC) | ||||
| # endif() | ||||
| target_link_libraries(${PROJECT_NAME} PUBLIC dbt-rise-tgc fmt::fmt) | ||||
|  | ||||
| if(TARGET Boost::program_options) | ||||
| @@ -162,78 +172,91 @@ if(TARGET Boost::program_options) | ||||
| else() | ||||
|     target_link_libraries(${PROJECT_NAME} PUBLIC ${BOOST_program_options_LIBRARY}) | ||||
| endif() | ||||
|  | ||||
| target_link_libraries(${PROJECT_NAME} PUBLIC ${CMAKE_DL_LIBS}) | ||||
| if (Tcmalloc_FOUND) | ||||
|  | ||||
| if(Tcmalloc_FOUND) | ||||
|     target_link_libraries(${PROJECT_NAME} PUBLIC ${Tcmalloc_LIBRARIES}) | ||||
| endif(Tcmalloc_FOUND) | ||||
|  | ||||
| install(TARGETS tgc-sim | ||||
|   EXPORT ${PROJECT_NAME}Targets            # for downstream dependencies | ||||
|   ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}  # static lib | ||||
|   RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}  # binaries | ||||
|   LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}  # shared lib | ||||
|   FRAMEWORK DESTINATION ${CMAKE_INSTALL_LIBDIR} # for mac | ||||
|   PUBLIC_HEADER DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}  # headers for mac (note the different component -> different package) | ||||
|   INCLUDES DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}             # headers | ||||
|     EXPORT ${PROJECT_NAME}Targets # for downstream dependencies | ||||
|     ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR} # static lib | ||||
|     RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR} # binaries | ||||
|     LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} # shared lib | ||||
|     FRAMEWORK DESTINATION ${CMAKE_INSTALL_LIBDIR} # for mac | ||||
|     PUBLIC_HEADER DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME} # headers for mac (note the different component -> different package) | ||||
|     INCLUDES DESTINATION ${CMAKE_INSTALL_INCLUDEDIR} # headers | ||||
| ) | ||||
|  | ||||
| if(BUILD_TESTING) | ||||
|   	# ... CMake code to create tests ... | ||||
| 	add_test(NAME tgc-sim-interp | ||||
| 	         COMMAND tgc-sim -f ${CMAKE_BINARY_DIR}/../../Firmwares/hello-world/hello --backend interp) | ||||
| 	if(WITH_TCC) | ||||
| 	add_test(NAME tgc-sim-tcc | ||||
| 	         COMMAND tgc-sim -f ${CMAKE_BINARY_DIR}/../../Firmwares/hello-world/hello --backend tcc) | ||||
| 	endif() | ||||
| 	if(WITH_LLVM) | ||||
| 	add_test(NAME tgc-sim-llvm | ||||
| 	         COMMAND tgc-sim -f ${CMAKE_BINARY_DIR}/../../Firmwares/hello-world/hello --backend llvm) | ||||
| 	endif() | ||||
|     # ... CMake code to create tests ... | ||||
|     add_test(NAME tgc-sim-interp | ||||
|         COMMAND tgc-sim -f ${CMAKE_BINARY_DIR}/../../Firmwares/hello-world/hello --backend interp) | ||||
|  | ||||
|     if(WITH_TCC) | ||||
|         add_test(NAME tgc-sim-tcc | ||||
|             COMMAND tgc-sim -f ${CMAKE_BINARY_DIR}/../../Firmwares/hello-world/hello --backend tcc) | ||||
|     endif() | ||||
|  | ||||
|     if(WITH_LLVM) | ||||
|         add_test(NAME tgc-sim-llvm | ||||
|             COMMAND tgc-sim -f ${CMAKE_BINARY_DIR}/../../Firmwares/hello-world/hello --backend llvm) | ||||
|     endif() | ||||
|  | ||||
|     if(WITH_ASMJIT) | ||||
| 	add_test(NAME tgc-sim-asmjit | ||||
| 	         COMMAND tgc-sim -f ${CMAKE_BINARY_DIR}/../../Firmwares/hello-world/hello --backend asmjit) | ||||
| 	endif() | ||||
|         add_test(NAME tgc-sim-asmjit | ||||
|             COMMAND tgc-sim -f ${CMAKE_BINARY_DIR}/../../Firmwares/hello-world/hello --backend asmjit) | ||||
|     endif() | ||||
| endif() | ||||
| ############################################################################### | ||||
|  | ||||
| # ############################################################################## | ||||
| # | ||||
| ############################################################################### | ||||
| # ############################################################################## | ||||
| if(TARGET scc-sysc) | ||||
| 	project(dbt-rise-tgc_sc VERSION 1.0.0) | ||||
| 	set(LIB_SOURCES  | ||||
|     	src/sysc/core_complex.cpp | ||||
|     	src/sysc/register_tgc_c.cpp | ||||
| 	) | ||||
| 	FILE(GLOB GEN_SC_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/src-gen/sysc/register_*.cpp) | ||||
| 	list(APPEND LIB_SOURCES ${GEN_SC_SOURCES}) | ||||
|     project(dbt-rise-tgc_sc VERSION 1.0.0) | ||||
|     set(LIB_SOURCES | ||||
|         src/sysc/core_complex.cpp | ||||
|         src/sysc/register_tgc_c.cpp | ||||
|     ) | ||||
|     FILE(GLOB GEN_SC_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/src-gen/sysc/register_*.cpp) | ||||
|     list(APPEND LIB_SOURCES ${GEN_SC_SOURCES}) | ||||
|     add_library(${PROJECT_NAME} ${LIB_SOURCES}) | ||||
|     target_compile_definitions(${PROJECT_NAME} PUBLIC WITH_SYSTEMC) | ||||
|     target_compile_definitions(${PROJECT_NAME} PRIVATE CORE_${CORE_NAME}) | ||||
|  | ||||
|     foreach(F IN LISTS TGC_SOURCES) | ||||
|         if (${F} MATCHES ".*/arch/([^/]*)\.cpp") | ||||
|             string(REGEX REPLACE  ".*/([^/]*)\.cpp"  "\\1" CORE_NAME_LC ${F}) | ||||
|         if(${F} MATCHES ".*/arch/([^/]*)\.cpp") | ||||
|             string(REGEX REPLACE ".*/([^/]*)\.cpp" "\\1" CORE_NAME_LC ${F}) | ||||
|             string(TOUPPER ${CORE_NAME_LC} CORE_NAME) | ||||
|             target_compile_definitions(${PROJECT_NAME} PRIVATE CORE_${CORE_NAME}) | ||||
|         endif() | ||||
|     endforeach() | ||||
|  | ||||
|     target_link_libraries(${PROJECT_NAME} PUBLIC dbt-rise-tgc scc-sysc) | ||||
| #    if(WITH_LLVM) | ||||
| #        target_link_libraries(${PROJECT_NAME} PUBLIC ${llvm_libs}) | ||||
| #    endif() | ||||
|      | ||||
| 	set(LIB_HEADERS ${CMAKE_CURRENT_SOURCE_DIR}/src/sysc/core_complex.h) | ||||
|  | ||||
|     # if(WITH_LLVM) | ||||
|     # target_link_libraries(${PROJECT_NAME} PUBLIC ${llvm_libs}) | ||||
|     # endif() | ||||
|     set(LIB_HEADERS ${CMAKE_CURRENT_SOURCE_DIR}/src/sysc/core_complex.h) | ||||
|     set_target_properties(${PROJECT_NAME} PROPERTIES | ||||
|       VERSION ${PROJECT_VERSION} | ||||
|       FRAMEWORK FALSE | ||||
|       PUBLIC_HEADER "${LIB_HEADERS}" # specify the public headers | ||||
|         VERSION ${PROJECT_VERSION} | ||||
|         FRAMEWORK FALSE | ||||
|         PUBLIC_HEADER "${LIB_HEADERS}" # specify the public headers | ||||
|     ) | ||||
|     install(TARGETS ${PROJECT_NAME} COMPONENT ${PROJECT_NAME} | ||||
| 	  EXPORT ${PROJECT_NAME}Targets            # for downstream dependencies | ||||
| 	  ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}  # static lib | ||||
| 	  RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}  # binaries | ||||
| 	  LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}  # shared lib | ||||
| 	  FRAMEWORK DESTINATION ${CMAKE_INSTALL_LIBDIR} # for mac | ||||
| 	  PUBLIC_HEADER DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/sysc   # headers for mac (note the different component -> different package) | ||||
| 	  INCLUDES DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}             # headers | ||||
| 	)     | ||||
|         EXPORT ${PROJECT_NAME}Targets # for downstream dependencies | ||||
|         ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR} # static lib | ||||
|         RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR} # binaries | ||||
|         LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} # shared lib | ||||
|         FRAMEWORK DESTINATION ${CMAKE_INSTALL_LIBDIR} # for mac | ||||
|         PUBLIC_HEADER DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/sysc # headers for mac (note the different component -> different package) | ||||
|         INCLUDES DESTINATION ${CMAKE_INSTALL_INCLUDEDIR} # headers | ||||
|     ) | ||||
| endif() | ||||
|  | ||||
| project(elfio-test) | ||||
| find_package(Boost COMPONENTS program_options thread REQUIRED) | ||||
|  | ||||
| add_executable(${PROJECT_NAME} src/elfio.cpp) | ||||
| target_link_libraries(${PROJECT_NAME} PUBLIC elfio::elfio) | ||||
|   | ||||
| @@ -20,7 +20,7 @@ RVI: | ||||
|     mask: 0b00000000000000000000000001111111 | ||||
|     size:   32 | ||||
|     branch:   true | ||||
|     delay:   1 | ||||
|     delay:   [1,1] | ||||
|   JALR: | ||||
|     index: 3 | ||||
|     encoding: 0b00000000000000000000000001100111 | ||||
| @@ -349,7 +349,7 @@ Zifencei: | ||||
|     size:   32 | ||||
|     branch:   false | ||||
|     delay:   1 | ||||
| RV32M:  | ||||
| RVM:  | ||||
|   MUL: | ||||
|     index: 49 | ||||
|     encoding: 0b00000010000000000000000000110011 | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| /******************************************************************************* | ||||
|  * Copyright (C) 2017 - 2020 MINRES Technologies GmbH | ||||
|  * Copyright (C) 2024 MINRES Technologies GmbH | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
| @@ -47,10 +47,10 @@ def getRegisterSizes(){ | ||||
|  | ||||
| using namespace iss::arch; | ||||
|  | ||||
| constexpr std::array<const char*, ${registers.size}>    iss::arch::traits<iss::arch::${coreDef.name.toLowerCase()}>::reg_names; | ||||
| constexpr std::array<const char*, ${registers.size}>    iss::arch::traits<iss::arch::${coreDef.name.toLowerCase()}>::reg_aliases; | ||||
| constexpr std::array<const uint32_t, ${getRegisterSizes().size}> iss::arch::traits<iss::arch::${coreDef.name.toLowerCase()}>::reg_bit_widths; | ||||
| constexpr std::array<const uint32_t, ${getRegisterSizes().size}> iss::arch::traits<iss::arch::${coreDef.name.toLowerCase()}>::reg_byte_offsets; | ||||
| constexpr std::array<const char*, ${registers.size()}>    iss::arch::traits<iss::arch::${coreDef.name.toLowerCase()}>::reg_names; | ||||
| constexpr std::array<const char*, ${registers.size()}>    iss::arch::traits<iss::arch::${coreDef.name.toLowerCase()}>::reg_aliases; | ||||
| constexpr std::array<const uint32_t, ${getRegisterSizes().size()}> iss::arch::traits<iss::arch::${coreDef.name.toLowerCase()}>::reg_bit_widths; | ||||
| constexpr std::array<const uint32_t, ${getRegisterSizes().size()}> iss::arch::traits<iss::arch::${coreDef.name.toLowerCase()}>::reg_byte_offsets; | ||||
|  | ||||
| ${coreDef.name.toLowerCase()}::${coreDef.name.toLowerCase()}()  = default; | ||||
|  | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| /******************************************************************************* | ||||
|  * Copyright (C) 2017 - 2021 MINRES Technologies GmbH | ||||
|  * Copyright (C) 2024 MINRES Technologies GmbH | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
| @@ -30,11 +30,21 @@ | ||||
|  * | ||||
|  *******************************************************************************/ | ||||
| <% | ||||
| def nativeTypeSize(int size){ | ||||
|     if(size<=8) return 8; else if(size<=16) return 16; else if(size<=32) return 32; else return 64; | ||||
| def nativeSize(int size){ | ||||
|     if(size<=8) return 8; | ||||
|     if(size<=16) return 16; | ||||
|     if(size<=32) return 32; | ||||
|     if(size<=64) return 64; | ||||
|     if(size<=128) return 128; | ||||
|     if(size<=256) return 256; | ||||
|     if(size<=512) return 512; | ||||
|     if(size<=1024) return 1024; | ||||
|     if(size<=2048) return 2048; | ||||
|     if(size<=4096) return 4096; | ||||
|     throw new IllegalArgumentException("Unsupported size in nativeSize in CORENAME.h.gtl"); | ||||
| } | ||||
| def getRegisterSizes(){ | ||||
|     def regs = registers.collect{nativeTypeSize(it.size)} | ||||
|     def regs = registers.collect{nativeSize(it.size)} | ||||
|     regs+=[32,32, 64, 64, 64, 32, 32] // append TRAP_STATE, PENDING_TRAP, ICOUNT, CYCLE, INSTRET, INSTRUCTION, LAST_BRANCH | ||||
|     return regs | ||||
| } | ||||
| @@ -47,13 +57,7 @@ def getRegisterOffsets(){ | ||||
|     } | ||||
|     return offsets | ||||
| } | ||||
| def byteSize(int size){ | ||||
|     if(size<=8) return 8; | ||||
|     if(size<=16) return 16; | ||||
|     if(size<=32) return 32; | ||||
|     if(size<=64) return 64; | ||||
|     return 128; | ||||
| } | ||||
|  | ||||
| def getCString(def val){ | ||||
|     return val.toString()+'ULL' | ||||
| } | ||||
| @@ -75,15 +79,17 @@ template <> struct traits<${coreDef.name.toLowerCase()}> { | ||||
|  | ||||
|     constexpr static char const* const core_type = "${coreDef.name}"; | ||||
|      | ||||
|     static constexpr std::array<const char*, ${registers.size}> reg_names{ | ||||
|     static constexpr std::array<const char*, ${registers.size()}> reg_names{ | ||||
|         {"${registers.collect{it.name.toLowerCase()}.join('", "')}"}}; | ||||
|   | ||||
|     static constexpr std::array<const char*, ${registers.size}> reg_aliases{ | ||||
|     static constexpr std::array<const char*, ${registers.size()}> reg_aliases{ | ||||
|         {"${registers.collect{it.alias.toLowerCase()}.join('", "')}"}}; | ||||
|  | ||||
|     enum constants {${constants.collect{c -> c.name+"="+getCString(c.value)}.join(', ')}}; | ||||
|  | ||||
|     constexpr static unsigned FP_REGS_SIZE = ${constants.find {it.name=='FLEN'}?.value?:0}; | ||||
|     constexpr static unsigned V_REGS_SIZE = ${constants.find {it.name=='VLEN'}?.value?:0}; | ||||
|  | ||||
|  | ||||
|     enum reg_e { | ||||
|         ${registers.collect{it.name}.join(', ')}, NUM_REGS, TRAP_STATE=NUM_REGS, PENDING_TRAP, ICOUNT, CYCLE, INSTRET, INSTRUCTION, LAST_BRANCH | ||||
| @@ -99,17 +105,17 @@ template <> struct traits<${coreDef.name.toLowerCase()}> { | ||||
|  | ||||
|     using phys_addr_t = iss::typed_addr_t<iss::address_type::PHYSICAL>; | ||||
|  | ||||
|     static constexpr std::array<const uint32_t, ${getRegisterSizes().size}> reg_bit_widths{ | ||||
|     static constexpr std::array<const uint32_t, ${getRegisterSizes().size()}> reg_bit_widths{ | ||||
|         {${getRegisterSizes().join(',')}}}; | ||||
|  | ||||
|     static constexpr std::array<const uint32_t, ${getRegisterOffsets().size}> reg_byte_offsets{ | ||||
|     static constexpr std::array<const uint32_t, ${getRegisterOffsets().size()}> reg_byte_offsets{ | ||||
|         {${getRegisterOffsets().join(',')}}}; | ||||
|  | ||||
|     static const uint64_t addr_mask = (reg_t(1) << (XLEN - 1)) | ((reg_t(1) << (XLEN - 1)) - 1); | ||||
|  | ||||
|     enum sreg_flag_e { FLAGS }; | ||||
|  | ||||
|     enum mem_type_e { ${spaces.collect{it.name}.join(', ')} }; | ||||
|     enum mem_type_e { ${spaces.collect{it.name}.join(', ')}, IMEM = MEM }; | ||||
|      | ||||
|     enum class opcode_e {<%instructions.eachWithIndex{instr, index -> %> | ||||
|         ${instr.instruction.name} = ${index},<%}%> | ||||
| @@ -131,8 +137,6 @@ struct ${coreDef.name.toLowerCase()}: public arch_if { | ||||
|  | ||||
|     uint8_t* get_regs_base_ptr() override; | ||||
|  | ||||
|     inline uint64_t get_icount() { return reg.icount; } | ||||
|  | ||||
|     inline bool should_stop() { return interrupt_sim; } | ||||
|  | ||||
|     inline uint64_t stop_code() { return interrupt_sim; } | ||||
| @@ -141,20 +145,20 @@ struct ${coreDef.name.toLowerCase()}: public arch_if { | ||||
|  | ||||
|     virtual iss::sync_type needed_sync() const { return iss::NO_SYNC; } | ||||
|  | ||||
|     inline uint32_t get_last_branch() { return reg.last_branch; } | ||||
|  | ||||
|  | ||||
| #pragma pack(push, 1) | ||||
|     struct ${coreDef.name}_regs {<% | ||||
|         registers.each { reg -> if(reg.size>0) {%>  | ||||
|         uint${byteSize(reg.size)}_t ${reg.name} = 0;<% | ||||
|         registers.each { reg -> if(reg.size>64) {%> | ||||
|         uint8_t ${reg.name}[${reg.size/8}] = {0};<% | ||||
|         }else if(reg.size>0) {%> | ||||
|         uint${nativeSize(reg.size)}_t ${reg.name} = 0;<% | ||||
|         }}%> | ||||
|         uint32_t trap_state = 0, pending_trap = 0; | ||||
|         uint64_t icount = 0; | ||||
|         uint64_t cycle = 0; | ||||
|         uint64_t instret = 0; | ||||
|         uint32_t instruction = 0; | ||||
|         uint32_t last_branch = 0; | ||||
|         uint64_t icount = 0;      // counts number of instructions undisturbed | ||||
|         uint64_t cycle = 0;       // counts number of cycles, in functional mode equals icount | ||||
|         uint64_t instret = 0;     // counts number of instructions, can be reset via CSR write | ||||
|         uint32_t instruction = 0; // holds op code of currently executed instruction | ||||
|         uint32_t last_branch = 0; // indicates if last branch was taken | ||||
|     } reg; | ||||
| #pragma pack(pop) | ||||
|     std::array<address_type, 4> addr_mode; | ||||
| @@ -168,6 +172,31 @@ if(fcsr != null) {%> | ||||
| <%} else { %> | ||||
|     uint32_t get_fcsr(){return 0;} | ||||
|     void set_fcsr(uint32_t val){} | ||||
| <%} | ||||
| def vstart = registers.find {it.name=='vstart'} | ||||
| def vl = registers.find {it.name=='vl'} | ||||
| def vtype = registers.find {it.name=='vtype'} | ||||
| def vxsat = registers.find {it.name=='vxsat'} | ||||
| def vxrm = registers.find {it.name=='vxrm'} | ||||
|  | ||||
| if(vtype != null) {%> | ||||
|     uint${vstart.size}_t get_vstart(){return reg.vstart;} | ||||
|     void set_vstart(uint${vstart.size}_t val){reg.vstart = val;} | ||||
|     uint${vl.size}_t get_vl(){return reg.vl;} | ||||
|     uint${vtype.size}_t get_vtype(){return reg.vtype;} | ||||
|     uint${vxsat.size}_t get_vxsat(){return reg.vxsat;} | ||||
|     void set_vxsat(uint${vxsat.size}_t val){reg.vxsat = val;} | ||||
|     uint${vxrm.size}_t get_vxrm(){return reg.vxrm;} | ||||
|     void set_vxrm(uint${vxrm.size}_t val){reg.vxrm = val;} | ||||
| <%} else { %> | ||||
|     uint32_t get_vstart(){return 0;} | ||||
|     void set_vstart(uint32_t val){} | ||||
|     uint32_t get_vl(){return 0;} | ||||
|     uint32_t get_vtype(){return 0;} | ||||
|     uint32_t get_vxsat(){return 0;} | ||||
|     void set_vxsat(uint32_t val){} | ||||
|     uint32_t get_vxrm(){return 0;} | ||||
|     void set_vxrm(uint32_t val){} | ||||
| <%}%> | ||||
| }; | ||||
|  | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| /******************************************************************************* | ||||
|  * Copyright (C) 2023 MINRES Technologies GmbH | ||||
|  * Copyright (C) 2024 MINRES Technologies GmbH | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
| @@ -45,17 +45,17 @@ namespace interp { | ||||
| using namespace sysc; | ||||
| volatile std::array<bool, ${array_count}> ${coreDef.name.toLowerCase()}_init = { | ||||
|         iss_factory::instance().register_creator("${coreDef.name.toLowerCase()}|m_p|interp", [](unsigned gdb_port, void* data) -> iss_factory::base_t { | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex*>(data); | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex_if*>(data); | ||||
|             auto* cpu = new sc_core_adapter<arch::riscv_hart_m_p<arch::${coreDef.name.toLowerCase()}>>(cc); | ||||
|             return {sysc::sc_cpu_ptr{cpu}, vm_ptr{create(static_cast<arch::${coreDef.name.toLowerCase()}*>(cpu), gdb_port)}}; | ||||
|         }), | ||||
|         iss_factory::instance().register_creator("${coreDef.name.toLowerCase()}|mu_p|interp", [](unsigned gdb_port, void* data) -> iss_factory::base_t { | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex*>(data); | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex_if*>(data); | ||||
|             auto* cpu = new sc_core_adapter<arch::riscv_hart_mu_p<arch::${coreDef.name.toLowerCase()}>>(cc); | ||||
|             return {sysc::sc_cpu_ptr{cpu}, vm_ptr{create(static_cast<arch::${coreDef.name.toLowerCase()}*>(cpu), gdb_port)}}; | ||||
|         })<%if(coreDef.name.toLowerCase()=="tgc5d" || coreDef.name.toLowerCase()=="tgc5e") {%>, | ||||
|         iss_factory::instance().register_creator("${coreDef.name.toLowerCase()}|mu_p_clic_pmp|interp", [](unsigned gdb_port, void* data) -> iss_factory::base_t { | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex*>(data); | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex_if*>(data); | ||||
|             auto* cpu = new sc_core_adapter<arch::riscv_hart_mu_p<arch::${coreDef.name.toLowerCase()}, (iss::arch::features_e)(iss::arch::FEAT_PMP | iss::arch::FEAT_EXT_N | iss::arch::FEAT_CLIC)>>(cc); | ||||
|             return {sysc::sc_cpu_ptr{cpu}, vm_ptr{create(static_cast<arch::${coreDef.name.toLowerCase()}*>(cpu), gdb_port)}}; | ||||
|         })<%}%> | ||||
| @@ -66,17 +66,17 @@ namespace llvm { | ||||
| using namespace sysc; | ||||
| volatile std::array<bool, ${array_count}> ${coreDef.name.toLowerCase()}_init = { | ||||
|         iss_factory::instance().register_creator("${coreDef.name.toLowerCase()}|m_p|llvm", [](unsigned gdb_port, void* data) -> iss_factory::base_t { | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex*>(data); | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex_if*>(data); | ||||
|             auto* cpu = new sc_core_adapter<arch::riscv_hart_m_p<arch::${coreDef.name.toLowerCase()}>>(cc); | ||||
|             return {sysc::sc_cpu_ptr{cpu}, vm_ptr{create(static_cast<arch::${coreDef.name.toLowerCase()}*>(cpu), gdb_port)}}; | ||||
|         }), | ||||
|         iss_factory::instance().register_creator("${coreDef.name.toLowerCase()}|mu_p|llvm", [](unsigned gdb_port, void* data) -> iss_factory::base_t { | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex*>(data); | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex_if*>(data); | ||||
|             auto* cpu = new sc_core_adapter<arch::riscv_hart_mu_p<arch::${coreDef.name.toLowerCase()}>>(cc); | ||||
|             return {sysc::sc_cpu_ptr{cpu}, vm_ptr{create(static_cast<arch::${coreDef.name.toLowerCase()}*>(cpu), gdb_port)}}; | ||||
|         })<%if(coreDef.name.toLowerCase()=="tgc5d" || coreDef.name.toLowerCase()=="tgc5e") {%>, | ||||
|         iss_factory::instance().register_creator("${coreDef.name.toLowerCase()}|mu_p_clic_pmp|llvm", [](unsigned gdb_port, void* data) -> iss_factory::base_t { | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex*>(data); | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex_if*>(data); | ||||
|             auto* cpu = new sc_core_adapter<arch::riscv_hart_mu_p<arch::${coreDef.name.toLowerCase()}, (iss::arch::features_e)(iss::arch::FEAT_PMP | iss::arch::FEAT_EXT_N | iss::arch::FEAT_CLIC)>>(cc); | ||||
|             return {sysc::sc_cpu_ptr{cpu}, vm_ptr{create(static_cast<arch::${coreDef.name.toLowerCase()}*>(cpu), gdb_port)}}; | ||||
|         })<%}%> | ||||
| @@ -88,17 +88,17 @@ namespace tcc { | ||||
| using namespace sysc; | ||||
| volatile std::array<bool, ${array_count}> ${coreDef.name.toLowerCase()}_init = { | ||||
|         iss_factory::instance().register_creator("${coreDef.name.toLowerCase()}|m_p|tcc", [](unsigned gdb_port, void* data) -> iss_factory::base_t { | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex*>(data); | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex_if*>(data); | ||||
|             auto* cpu = new sc_core_adapter<arch::riscv_hart_m_p<arch::${coreDef.name.toLowerCase()}>>(cc); | ||||
|             return {sysc::sc_cpu_ptr{cpu}, vm_ptr{create(static_cast<arch::${coreDef.name.toLowerCase()}*>(cpu), gdb_port)}}; | ||||
|         }), | ||||
|         iss_factory::instance().register_creator("${coreDef.name.toLowerCase()}|mu_p|tcc", [](unsigned gdb_port, void* data) -> iss_factory::base_t { | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex*>(data); | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex_if*>(data); | ||||
|             auto* cpu = new sc_core_adapter<arch::riscv_hart_mu_p<arch::${coreDef.name.toLowerCase()}>>(cc); | ||||
|             return {sysc::sc_cpu_ptr{cpu}, vm_ptr{create(static_cast<arch::${coreDef.name.toLowerCase()}*>(cpu), gdb_port)}}; | ||||
|         })<%if(coreDef.name.toLowerCase()=="tgc5d" || coreDef.name.toLowerCase()=="tgc5e") {%>, | ||||
|         iss_factory::instance().register_creator("${coreDef.name.toLowerCase()}|mu_p_clic_pmp|tcc", [](unsigned gdb_port, void* data) -> iss_factory::base_t { | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex*>(data); | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex_if*>(data); | ||||
|             auto* cpu = new sc_core_adapter<arch::riscv_hart_mu_p<arch::${coreDef.name.toLowerCase()}, (iss::arch::features_e)(iss::arch::FEAT_PMP | iss::arch::FEAT_EXT_N | iss::arch::FEAT_CLIC)>>(cc); | ||||
|             return {sysc::sc_cpu_ptr{cpu}, vm_ptr{create(static_cast<arch::${coreDef.name.toLowerCase()}*>(cpu), gdb_port)}}; | ||||
|         })<%}%> | ||||
| @@ -110,17 +110,17 @@ namespace asmjit { | ||||
| using namespace sysc; | ||||
| volatile std::array<bool, ${array_count}> ${coreDef.name.toLowerCase()}_init = { | ||||
|         iss_factory::instance().register_creator("${coreDef.name.toLowerCase()}|m_p|asmjit", [](unsigned gdb_port, void* data) -> iss_factory::base_t { | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex*>(data); | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex_if*>(data); | ||||
|             auto* cpu = new sc_core_adapter<arch::riscv_hart_m_p<arch::${coreDef.name.toLowerCase()}>>(cc); | ||||
|             return {sysc::sc_cpu_ptr{cpu}, vm_ptr{create(static_cast<arch::${coreDef.name.toLowerCase()}*>(cpu), gdb_port)}}; | ||||
|         }), | ||||
|         iss_factory::instance().register_creator("${coreDef.name.toLowerCase()}|mu_p|asmjit", [](unsigned gdb_port, void* data) -> iss_factory::base_t { | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex*>(data); | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex_if*>(data); | ||||
|             auto* cpu = new sc_core_adapter<arch::riscv_hart_mu_p<arch::${coreDef.name.toLowerCase()}>>(cc); | ||||
|             return {sysc::sc_cpu_ptr{cpu}, vm_ptr{create(static_cast<arch::${coreDef.name.toLowerCase()}*>(cpu), gdb_port)}}; | ||||
|         })<%if(coreDef.name.toLowerCase()=="tgc5d" || coreDef.name.toLowerCase()=="tgc5e") {%>, | ||||
|         iss_factory::instance().register_creator("${coreDef.name.toLowerCase()}|mu_p_clic_pmp|asmjit", [](unsigned gdb_port, void* data) -> iss_factory::base_t { | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex*>(data); | ||||
|             auto* cc = reinterpret_cast<sysc::tgfs::core_complex_if*>(data); | ||||
|             auto* cpu = new sc_core_adapter<arch::riscv_hart_mu_p<arch::${coreDef.name.toLowerCase()}, (iss::arch::features_e)(iss::arch::FEAT_PMP | iss::arch::FEAT_EXT_N | iss::arch::FEAT_CLIC)>>(cc); | ||||
|             return {sysc::sc_cpu_ptr{cpu}, vm_ptr{create(static_cast<arch::${coreDef.name.toLowerCase()}*>(cpu), gdb_port)}}; | ||||
|         })<%}%> | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| /******************************************************************************* | ||||
|  * Copyright (C) 2017, 2023 MINRES Technologies GmbH | ||||
|  * Copyright (C) 2017-2024 MINRES Technologies GmbH | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
| @@ -37,7 +37,14 @@ | ||||
| #include <iss/asmjit/vm_base.h> | ||||
| #include <asmjit/asmjit.h> | ||||
| #include <util/logging.h> | ||||
|  | ||||
| #include <iss/instruction_decoder.h> | ||||
| <%def fcsr = registers.find {it.name=='FCSR'} | ||||
| if(fcsr != null) {%> | ||||
| #include <vm/fp_functions.h><%} | ||||
| def aes = functions.find { it.contains('aes') } | ||||
| if(aes != null) {%> | ||||
| #include <vm/aes_sbox.h> | ||||
| <%}%> | ||||
| #ifndef FMT_HEADER_ONLY | ||||
| #define FMT_HEADER_ONLY | ||||
| #endif | ||||
| @@ -46,6 +53,22 @@ | ||||
| #include <array> | ||||
| #include <iss/debugger/riscv_target_adapter.h> | ||||
|  | ||||
| #ifndef _MSC_VER | ||||
| using int128_t = __int128; | ||||
| using uint128_t = unsigned __int128; | ||||
| namespace std { | ||||
| template <> struct make_unsigned<__int128> { typedef unsigned __int128 type; }; | ||||
| template <> class __make_unsigned_selector<__int128 unsigned, false, false> { | ||||
| public: | ||||
|     typedef unsigned __int128 __type; | ||||
| }; | ||||
| template <> struct is_signed<int128_t> { static constexpr bool value = true; }; | ||||
| template <> struct is_signed<uint128_t> { static constexpr bool value = false; }; | ||||
| template <> struct is_unsigned<int128_t> { static constexpr bool value = false; }; | ||||
| template <> struct is_unsigned<uint128_t> { static constexpr bool value = true; }; | ||||
| } // namespace std | ||||
| #endif | ||||
|  | ||||
| namespace iss { | ||||
| namespace asmjit { | ||||
|  | ||||
| @@ -79,47 +102,68 @@ public: | ||||
|     } | ||||
|  | ||||
| protected: | ||||
|     using vm_base<ARCH>::get_reg_ptr; | ||||
|     using super::get_ptr_for; | ||||
|     using super::get_reg_for; | ||||
|     using super::get_reg_for_Gp; | ||||
|     using super::load_reg_from_mem; | ||||
|     using super::load_reg_from_mem_Gp; | ||||
|     using super::write_reg_to_mem; | ||||
|     using super::gen_read_mem; | ||||
|     using super::gen_write_mem; | ||||
|     using super::gen_leave; | ||||
|     using super::gen_sync; | ||||
|     | ||||
|     using this_class = vm_impl<ARCH>; | ||||
|     using compile_func = continuation_e (this_class::*)(virt_addr_t&, code_word_t, jit_holder&); | ||||
|  | ||||
|     continuation_e gen_single_inst_behavior(virt_addr_t&, unsigned int &, jit_holder&) override; | ||||
|     continuation_e gen_single_inst_behavior(virt_addr_t&, jit_holder&) override; | ||||
|     enum globals_e {TVAL = 0, GLOBALS_SIZE}; | ||||
|     void gen_block_prologue(jit_holder& jh) override; | ||||
|     void gen_block_epilogue(jit_holder& jh) override; | ||||
|     inline const char *name(size_t index){return traits::reg_aliases.at(index);} | ||||
| <%if(fcsr != null) {%> | ||||
|     inline const char *fname(size_t index){return index < 32?name(index+traits::F0):"illegal";}    | ||||
| <%}%> | ||||
|     void gen_instr_prologue(jit_holder& jh); | ||||
|     void gen_instr_epilogue(jit_holder& jh); | ||||
|     inline void gen_raise(jit_holder& jh, uint16_t trap_id, uint16_t cause); | ||||
|     template <typename T, typename = typename std::enable_if<std::is_integral<T>::value>::type> void gen_set_tval(jit_holder& jh, T new_tval) ; | ||||
|     void gen_set_tval(jit_holder& jh, x86_reg_t _new_tval) ; | ||||
|  | ||||
|     template<unsigned W, typename U, typename S = typename std::make_signed<U>::type> | ||||
|     inline S sext(U from) { | ||||
|         auto mask = (1ULL<<W) - 1; | ||||
|         auto sign_mask = 1ULL<<(W-1); | ||||
|         return (from & mask) | ((from & sign_mask) ? ~mask : 0); | ||||
|     }  | ||||
| #include <vm/asmjit/helper_func.h> | ||||
|     } | ||||
|     inline void raise(uint16_t trap_id, uint16_t cause){ | ||||
|         auto trap_val =  0x80ULL << 24 | (cause << 16) | trap_id; | ||||
|         this->core.reg.trap_state = trap_val; | ||||
|     } | ||||
|  | ||||
| <%functions.each{ it.eachLine { %> | ||||
|     ${it}<%} | ||||
| }%> | ||||
| private: | ||||
|     /**************************************************************************** | ||||
|      * start opcode definitions | ||||
|      ****************************************************************************/ | ||||
|     struct instruction_descriptor { | ||||
|         size_t length; | ||||
|         uint32_t length; | ||||
|         uint32_t value; | ||||
|         uint32_t mask; | ||||
|         compile_func op; | ||||
|     }; | ||||
|     struct decoding_tree_node{ | ||||
|         std::vector<instruction_descriptor> instrs; | ||||
|         std::vector<decoding_tree_node*> children; | ||||
|         uint32_t submask = std::numeric_limits<uint32_t>::max(); | ||||
|         uint32_t value; | ||||
|         decoding_tree_node(uint32_t value) : value(value){} | ||||
|     }; | ||||
|  | ||||
|     decoding_tree_node* root {nullptr}; | ||||
|  | ||||
|     const std::array<instruction_descriptor, ${instructions.size}> instr_descr = {{ | ||||
|     const std::array<instruction_descriptor, ${instructions.size()}> instr_descr = {{ | ||||
|          /* entries are: size, valid value, valid mask, function ptr */<%instructions.each{instr -> %> | ||||
|         /* instruction ${instr.instruction.name}, encoding '${instr.encoding}' */ | ||||
|         {${instr.length}, ${instr.encoding}, ${instr.mask}, &this_class::__${generator.functionName(instr.name)}},<%}%> | ||||
|     }}; | ||||
|   | ||||
|  | ||||
|     //needs to be declared after instr_descr | ||||
|     decoder instr_decoder; | ||||
|  | ||||
|     /* instruction definitions */<%instructions.eachWithIndex{instr, idx -> %> | ||||
|     /* instruction ${idx}: ${instr.name} */ | ||||
|     continuation_e __${generator.functionName(instr.name)}(virt_addr_t& pc, code_word_t instr, jit_holder& jh){ | ||||
| @@ -127,126 +171,183 @@ private: | ||||
|         <%instr.fields.eachLine{%>${it} | ||||
|         <%}%>if(this->disass_enabled){ | ||||
|             /* generate disass */ | ||||
|             <%instr.disass.eachLine{%> | ||||
|             ${it}<%}%> | ||||
|             InvokeNode* call_print_disass; | ||||
|             char* mnemonic_ptr = strdup(mnemonic.c_str()); | ||||
|             jh.disass_collection.push_back(mnemonic_ptr); | ||||
|             jh.cc.invoke(&call_print_disass, &print_disass, FuncSignature::build<void, void *, uint64_t, char *>()); | ||||
|             call_print_disass->setArg(0, jh.arch_if_ptr); | ||||
|             call_print_disass->setArg(1, pc.val); | ||||
|             call_print_disass->setArg(2, mnemonic_ptr); | ||||
|  | ||||
|         } | ||||
|         x86::Compiler& cc = jh.cc; | ||||
|         //ideally only do this if necessary (someone / plugin needs it) | ||||
|         cc.mov(jh.pc,PC); | ||||
|         cc.comment(fmt::format("\\n${instr.name}_{:#x}:",pc.val).c_str()); | ||||
|         this->gen_sync(jh, PRE_SYNC, ${idx}); | ||||
|         pc=pc+ ${instr.length/8}; | ||||
|         | ||||
|         gen_instr_prologue(jh, pc.val); | ||||
|         cc.comment("\\n//behavior:"); | ||||
|         cc.comment(fmt::format("${instr.name}_{:#x}:",pc.val).c_str()); | ||||
|         gen_sync(jh, PRE_SYNC, ${idx}); | ||||
|         mov(cc, jh.pc, pc.val); | ||||
|         gen_set_tval(jh, instr); | ||||
|         pc = pc+${instr.length/8}; | ||||
|         mov(cc, jh.next_pc, pc.val); | ||||
|  | ||||
|         gen_instr_prologue(jh); | ||||
|         /*generate behavior*/ | ||||
|         <%instr.behavior.eachLine{%>${it} | ||||
|         <%}%> | ||||
|         gen_sync(jh, POST_SYNC, ${idx}); | ||||
|         gen_instr_epilogue(jh); | ||||
|         this->gen_sync(jh, POST_SYNC, ${idx}); | ||||
|     	return returnValue;         | ||||
|     } | ||||
|     <%}%> | ||||
|     /**************************************************************************** | ||||
|      * end opcode definitions | ||||
|      ****************************************************************************/ | ||||
|     continuation_e illegal_intruction(virt_addr_t &pc, code_word_t instr, jit_holder& jh ) { | ||||
|  | ||||
|         return BRANCH; | ||||
|     }     | ||||
|     //decoding functionality | ||||
|  | ||||
|     void populate_decoding_tree(decoding_tree_node* root){ | ||||
|         //create submask | ||||
|         for(auto instr: root->instrs){ | ||||
|             root->submask &= instr.mask; | ||||
|     continuation_e illegal_instruction(virt_addr_t &pc, code_word_t instr, jit_holder& jh ) { | ||||
|         x86::Compiler& cc = jh.cc; | ||||
|         if(this->disass_enabled){           | ||||
|             auto mnemonic = std::string("illegal_instruction"); | ||||
|             InvokeNode* call_print_disass; | ||||
|             char* mnemonic_ptr = strdup(mnemonic.c_str()); | ||||
|             jh.disass_collection.push_back(mnemonic_ptr); | ||||
|             jh.cc.invoke(&call_print_disass, &print_disass, FuncSignature::build<void, void *, uint64_t, char *>()); | ||||
|             call_print_disass->setArg(0, jh.arch_if_ptr); | ||||
|             call_print_disass->setArg(1, pc.val); | ||||
|             call_print_disass->setArg(2, mnemonic_ptr); | ||||
|         } | ||||
|         //put each instr according to submask&encoding into children | ||||
|         for(auto instr: root->instrs){ | ||||
|             bool foundMatch = false; | ||||
|             for(auto child: root->children){ | ||||
|                 //use value as identifying trait | ||||
|                 if(child->value == (instr.value&root->submask)){ | ||||
|                     child->instrs.push_back(instr); | ||||
|                     foundMatch = true; | ||||
|                 } | ||||
|             } | ||||
|             if(!foundMatch){ | ||||
|                 decoding_tree_node* child = new decoding_tree_node(instr.value&root->submask); | ||||
|                 child->instrs.push_back(instr); | ||||
|                 root->children.push_back(child); | ||||
|             } | ||||
|         } | ||||
|         root->instrs.clear(); | ||||
|         //call populate_decoding_tree for all children | ||||
|         if(root->children.size() >1) | ||||
|             for(auto child: root->children){ | ||||
|                 populate_decoding_tree(child);       | ||||
|             } | ||||
|         else{ | ||||
|             //sort instrs by value of the mask, this works bc we want to have the least restrictive one last | ||||
|             std::sort(root->children[0]->instrs.begin(), root->children[0]->instrs.end(), [](const instruction_descriptor& instr1, const instruction_descriptor& instr2) { | ||||
|             return instr1.mask > instr2.mask; | ||||
|             });  | ||||
|         } | ||||
|     } | ||||
|     compile_func decode_instr(decoding_tree_node* node, code_word_t word){ | ||||
|         if(!node->children.size()){ | ||||
|             if(node->instrs.size() == 1) return node->instrs[0].op; | ||||
|             for(auto instr : node->instrs){ | ||||
|                 if((instr.mask&word) == instr.value) return instr.op; | ||||
|             } | ||||
|         } | ||||
|         else{ | ||||
|             for(auto child : node->children){ | ||||
|                 if (child->value == (node->submask&word)){ | ||||
|                     return decode_instr(child, word); | ||||
|                 }   | ||||
|             }   | ||||
|         } | ||||
|         return nullptr; | ||||
|         cc.comment(fmt::format("illegal_instruction{:#x}:",pc.val).c_str()); | ||||
|         gen_sync(jh, PRE_SYNC, instr_descr.size()); | ||||
|         mov(cc, jh.pc, pc.val); | ||||
|         gen_set_tval(jh, instr); | ||||
|         pc = pc + ((instr & 3) == 3 ? 4 : 2); | ||||
|         mov(cc, jh.next_pc, pc.val); | ||||
|         gen_instr_prologue(jh); | ||||
|         gen_raise(jh, 0, 2); | ||||
|         gen_sync(jh, POST_SYNC, instr_descr.size()); | ||||
|         gen_instr_epilogue(jh); | ||||
|         return ILLEGAL_INSTR; | ||||
|     } | ||||
| }; | ||||
|  | ||||
| template <typename CODE_WORD> void debug_fn(CODE_WORD instr) { | ||||
|     volatile CODE_WORD x = instr; | ||||
|     instr = 2 * x; | ||||
| } | ||||
|  | ||||
| template <typename ARCH> vm_impl<ARCH>::vm_impl() { this(new ARCH()); } | ||||
|  | ||||
| template <typename ARCH> | ||||
| vm_impl<ARCH>::vm_impl(ARCH &core, unsigned core_id, unsigned cluster_id) | ||||
| : vm_base<ARCH>(core, core_id, cluster_id) { | ||||
|     root = new decoding_tree_node(std::numeric_limits<uint32_t>::max()); | ||||
|     for(auto instr: instr_descr){ | ||||
|         root->instrs.push_back(instr); | ||||
|     } | ||||
|     populate_decoding_tree(root); | ||||
| } | ||||
| : vm_base<ARCH>(core, core_id, cluster_id) | ||||
| , instr_decoder([this]() { | ||||
|         std::vector<generic_instruction_descriptor> g_instr_descr; | ||||
|         g_instr_descr.reserve(instr_descr.size()); | ||||
|         for (uint32_t i = 0; i < instr_descr.size(); ++i) { | ||||
|             generic_instruction_descriptor new_instr_descr {instr_descr[i].value, instr_descr[i].mask, i}; | ||||
|             g_instr_descr.push_back(new_instr_descr); | ||||
|         } | ||||
|         return std::move(g_instr_descr); | ||||
|     }()) {} | ||||
|  | ||||
| template <typename ARCH> | ||||
| continuation_e | ||||
| vm_impl<ARCH>::gen_single_inst_behavior(virt_addr_t &pc, unsigned int &inst_cnt, jit_holder& jh) { | ||||
| continuation_e vm_impl<ARCH>::gen_single_inst_behavior(virt_addr_t &pc, jit_holder& jh) { | ||||
|     enum {TRAP_ID=1<<16}; | ||||
|     code_word_t instr = 0; | ||||
|     phys_addr_t paddr(pc); | ||||
|     auto *const data = (uint8_t *)&instr; | ||||
|     if(this->core.has_mmu()) | ||||
|         paddr = this->core.virt2phys(pc); | ||||
|     auto res = this->core.read(paddr, 4, data); | ||||
|     if (res != iss::Ok) | ||||
|         throw trap_access(TRAP_ID, pc.val); | ||||
|         return ILLEGAL_FETCH; | ||||
|     if (instr == 0x0000006f || (instr&0xffff)==0xa001) | ||||
|         throw simulation_stopped(0); // 'J 0' or 'C.J 0' | ||||
|     ++inst_cnt; | ||||
|     auto f = decode_instr(root, instr); | ||||
|         return JUMP_TO_SELF; | ||||
|     uint32_t inst_index = instr_decoder.decode_instr(instr); | ||||
|     compile_func f = nullptr; | ||||
|     if(inst_index < instr_descr.size()) | ||||
|         f = instr_descr[inst_index].op; | ||||
|     if (f == nullptr)  | ||||
|         f = &this_class::illegal_intruction; | ||||
|         f = &this_class::illegal_instruction; | ||||
|     return (this->*f)(pc, instr, jh); | ||||
| } | ||||
| template <typename ARCH> | ||||
| void vm_impl<ARCH>::gen_instr_prologue(jit_holder& jh) { | ||||
|     auto& cc = jh.cc; | ||||
|  | ||||
|     x86_reg_t current_trap_state = get_reg_for(cc, traits::TRAP_STATE); | ||||
|     mov(cc, current_trap_state, get_ptr_for(jh, traits::TRAP_STATE)); | ||||
|     mov(cc, get_ptr_for(jh, traits::PENDING_TRAP), current_trap_state); | ||||
|     cc.comment("//Instruction prologue end"); | ||||
|  | ||||
| } | ||||
| template <typename ARCH> | ||||
| void vm_impl<ARCH>::gen_instr_epilogue(jit_holder& jh) { | ||||
|     auto& cc = jh.cc; | ||||
|  | ||||
| } // namespace ${coreDef.name.toLowerCase()} | ||||
|     cc.comment("//Instruction epilogue begin"); | ||||
|     x86_reg_t current_trap_state = get_reg_for(cc, traits::TRAP_STATE); | ||||
|     mov(cc, current_trap_state, get_ptr_for(jh, traits::TRAP_STATE)); | ||||
|     cmp(cc, current_trap_state, 0); | ||||
|     cc.jne(jh.trap_entry); | ||||
|     cc.inc(get_ptr_for(jh, traits::ICOUNT)); | ||||
|     cc.inc(get_ptr_for(jh, traits::CYCLE)); | ||||
|     cc.comment("//Instruction epilogue end"); | ||||
|  | ||||
| } | ||||
| template <typename ARCH> | ||||
| void vm_impl<ARCH>::gen_block_prologue(jit_holder& jh){ | ||||
|     jh.pc = load_reg_from_mem_Gp(jh, traits::PC); | ||||
|     jh.next_pc = load_reg_from_mem_Gp(jh, traits::NEXT_PC); | ||||
|     jh.globals.resize(GLOBALS_SIZE); | ||||
|     jh.globals[TVAL] = get_reg_Gp(jh.cc, 64, false); | ||||
| } | ||||
| template <typename ARCH> | ||||
| void vm_impl<ARCH>::gen_block_epilogue(jit_holder& jh){ | ||||
|     x86::Compiler& cc = jh.cc; | ||||
|     cc.comment("//block epilogue begin"); | ||||
|     cc.ret(jh.next_pc); | ||||
|  | ||||
|     cc.bind(jh.trap_entry); | ||||
|     this->write_back(jh); | ||||
|  | ||||
|     x86::Gp current_trap_state = get_reg_for_Gp(cc, traits::TRAP_STATE); | ||||
|     mov(cc, current_trap_state, get_ptr_for(jh, traits::TRAP_STATE)); | ||||
|  | ||||
|     x86::Gp current_pc = get_reg_for_Gp(cc, traits::PC); | ||||
|     mov(cc, current_pc, get_ptr_for(jh, traits::PC)); | ||||
|  | ||||
|     InvokeNode* call_enter_trap; | ||||
|     cc.invoke(&call_enter_trap, &enter_trap, FuncSignature::build<uint64_t, void*, uint64_t, uint64_t, uint64_t>()); | ||||
|     call_enter_trap->setArg(0, jh.arch_if_ptr); | ||||
|     call_enter_trap->setArg(1, current_trap_state); | ||||
|     call_enter_trap->setArg(2, current_pc); | ||||
|     call_enter_trap->setArg(3, jh.globals[TVAL]); | ||||
|  | ||||
|     x86_reg_t current_next_pc = get_reg_for(cc, traits::NEXT_PC); | ||||
|     mov(cc, current_next_pc, get_ptr_for(jh, traits::NEXT_PC)); | ||||
|     mov(cc, jh.next_pc, current_next_pc); | ||||
|  | ||||
|     mov(cc, get_ptr_for(jh, traits::LAST_BRANCH), static_cast<int>(UNKNOWN_JUMP)); | ||||
|     cc.ret(jh.next_pc); | ||||
| } | ||||
| template <typename ARCH> | ||||
| inline void vm_impl<ARCH>::gen_raise(jit_holder& jh, uint16_t trap_id, uint16_t cause) { | ||||
|     auto& cc = jh.cc; | ||||
|     auto tmp1 = get_reg_for(cc, traits::TRAP_STATE); | ||||
|     mov(cc, tmp1, 0x80ULL << 24 | (cause << 16) | trap_id); | ||||
|     mov(cc, get_ptr_for(jh, traits::TRAP_STATE), tmp1); | ||||
|     cc.jmp(jh.trap_entry); | ||||
| } | ||||
| template <typename ARCH> | ||||
| template <typename T, typename> | ||||
| void vm_impl<ARCH>::gen_set_tval(jit_holder& jh, T new_tval) { | ||||
|         mov(jh.cc, jh.globals[TVAL], new_tval); | ||||
|     } | ||||
| template <typename ARCH> | ||||
| void vm_impl<ARCH>::gen_set_tval(jit_holder& jh, x86_reg_t _new_tval) { | ||||
|     if(nonstd::holds_alternative<x86::Gp>(_new_tval)) { | ||||
|         x86::Gp new_tval = nonstd::get<x86::Gp>(_new_tval); | ||||
|         if(new_tval.size() < 8) | ||||
|             new_tval = gen_ext_Gp(jh.cc, new_tval, 64, false); | ||||
|         mov(jh.cc, jh.globals[TVAL], new_tval); | ||||
|     } else { | ||||
|         throw std::runtime_error("Variant not supported in gen_set_tval"); | ||||
|     } | ||||
| } | ||||
|  | ||||
| } // namespace tgc5c | ||||
|  | ||||
| template <> | ||||
| std::unique_ptr<vm_if> create<arch::${coreDef.name.toLowerCase()}>(arch::${coreDef.name.toLowerCase()} *core, unsigned short port, bool dump) { | ||||
| @@ -257,22 +358,30 @@ std::unique_ptr<vm_if> create<arch::${coreDef.name.toLowerCase()}>(arch::${coreD | ||||
| } // namespace asmjit | ||||
| } // namespace iss | ||||
|  | ||||
| #include <iss/factory.h> | ||||
| #include <iss/arch/riscv_hart_m_p.h> | ||||
| #include <iss/arch/riscv_hart_mu_p.h> | ||||
| #include <iss/factory.h> | ||||
| namespace iss { | ||||
| namespace { | ||||
| volatile std::array<bool, 2> dummy = { | ||||
|         core_factory::instance().register_creator("${coreDef.name.toLowerCase()}|m_p|asmjit", [](unsigned port, void*) -> std::tuple<cpu_ptr, vm_ptr>{ | ||||
|         core_factory::instance().register_creator("${coreDef.name.toLowerCase()}|m_p|asmjit", [](unsigned port, void* init_data) -> std::tuple<cpu_ptr, vm_ptr>{ | ||||
|             auto* cpu = new iss::arch::riscv_hart_m_p<iss::arch::${coreDef.name.toLowerCase()}>(); | ||||
|             auto* vm = new asmjit::${coreDef.name.toLowerCase()}::vm_impl<arch::${coreDef.name.toLowerCase()}>(*cpu, false); | ||||
|             if (port != 0) debugger::server<debugger::gdb_session>::run_server(vm, port); | ||||
| 		    auto vm = new asmjit::${coreDef.name.toLowerCase()}::vm_impl<arch::${coreDef.name.toLowerCase()}>(*cpu, false); | ||||
| 		    if (port != 0) debugger::server<debugger::gdb_session>::run_server(vm, port); | ||||
|             if(init_data){ | ||||
|                 auto* cb = reinterpret_cast<semihosting_cb_t<arch::traits<arch::${coreDef.name.toLowerCase()}>::reg_t>*>(init_data); | ||||
|                 cpu->set_semihosting_callback(*cb); | ||||
|             } | ||||
|             return {cpu_ptr{cpu}, vm_ptr{vm}}; | ||||
|         }), | ||||
|         core_factory::instance().register_creator("${coreDef.name.toLowerCase()}|mu_p|asmjit", [](unsigned port, void*) -> std::tuple<cpu_ptr, vm_ptr>{ | ||||
|         core_factory::instance().register_creator("${coreDef.name.toLowerCase()}|mu_p|asmjit", [](unsigned port, void* init_data) -> std::tuple<cpu_ptr, vm_ptr>{ | ||||
|             auto* cpu = new iss::arch::riscv_hart_mu_p<iss::arch::${coreDef.name.toLowerCase()}>(); | ||||
|             auto* vm = new asmjit::${coreDef.name.toLowerCase()}::vm_impl<arch::${coreDef.name.toLowerCase()}>(*cpu, false); | ||||
|             if (port != 0) debugger::server<debugger::gdb_session>::run_server(vm, port); | ||||
| 		    auto vm = new asmjit::${coreDef.name.toLowerCase()}::vm_impl<arch::${coreDef.name.toLowerCase()}>(*cpu, false); | ||||
| 		    if (port != 0) debugger::server<debugger::gdb_session>::run_server(vm, port); | ||||
|             if(init_data){ | ||||
|                 auto* cb = reinterpret_cast<semihosting_cb_t<arch::traits<arch::${coreDef.name.toLowerCase()}>::reg_t>*>(init_data); | ||||
|                 cpu->set_semihosting_callback(*cb); | ||||
|             } | ||||
|             return {cpu_ptr{cpu}, vm_ptr{vm}}; | ||||
|         }) | ||||
| }; | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,5 +1,5 @@ | ||||
| /******************************************************************************* | ||||
|  * Copyright (C) 2017, 2018 MINRES Technologies GmbH | ||||
|  * Copyright (C) 2017-2024 MINRES Technologies GmbH | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
| @@ -31,12 +31,17 @@ | ||||
|  *******************************************************************************/ | ||||
| // clang-format off | ||||
| #include <iss/arch/${coreDef.name.toLowerCase()}.h> | ||||
| // vm_base needs to be included before gdb_session as termios.h (via boost and gdb_server) has a define which clashes with a variable | ||||
| // name in ConstantRange.h | ||||
| #include <iss/llvm/vm_base.h> | ||||
| #include <iss/iss.h> | ||||
| #include <iss/debugger/gdb_session.h> | ||||
| #include <iss/debugger/server.h> | ||||
| #include <iss/iss.h> | ||||
| #include <iss/llvm/vm_base.h> | ||||
| #include <iss/instruction_decoder.h> | ||||
| #include <util/logging.h> | ||||
|  | ||||
| <%def fcsr = registers.find {it.name=='FCSR'} | ||||
| if(fcsr != null) {%> | ||||
| #include <vm/fp_functions.h><%}%> | ||||
| #ifndef FMT_HEADER_ONLY | ||||
| #define FMT_HEADER_ONLY | ||||
| #endif | ||||
| @@ -82,7 +87,9 @@ protected: | ||||
|     using vm_base<ARCH>::get_reg_ptr; | ||||
|  | ||||
|     inline const char *name(size_t index){return traits::reg_aliases.at(index);} | ||||
|  | ||||
| <%if(fcsr != null) {%> | ||||
|     inline const char *fname(size_t index){return index < 32?name(index+traits::F0):"illegal";}    | ||||
| <%}%> | ||||
|     template <typename T> inline ConstantInt *size(T type) { | ||||
|         return ConstantInt::get(getContext(), APInt(32, type->getType()->getScalarSizeInBits())); | ||||
|     } | ||||
| @@ -96,19 +103,17 @@ protected: | ||||
|         return super::gen_cond_assign(cond, this->gen_ext(trueVal, size), this->gen_ext(falseVal, size)); | ||||
|     } | ||||
|  | ||||
|     std::tuple<continuation_e, BasicBlock *> gen_single_inst_behavior(virt_addr_t &, unsigned int &, BasicBlock *) override; | ||||
|     std::tuple<continuation_e, BasicBlock *> gen_single_inst_behavior(virt_addr_t &, BasicBlock *) override; | ||||
|  | ||||
|     void gen_leave_behavior(BasicBlock *leave_blk) override; | ||||
|  | ||||
|     void gen_raise_trap(uint16_t trap_id, uint16_t cause); | ||||
|  | ||||
|     void gen_leave_trap(unsigned lvl); | ||||
|  | ||||
|     void gen_wait(unsigned type); | ||||
|  | ||||
|     void set_tval(uint64_t new_tval); | ||||
|     void set_tval(Value* new_tval); | ||||
|     void gen_trap_behavior(BasicBlock *) override; | ||||
|  | ||||
|     void gen_trap_check(BasicBlock *bb); | ||||
|     void gen_instr_prologue(); | ||||
|     void gen_instr_epilogue(BasicBlock *bb); | ||||
|  | ||||
|     inline Value *gen_reg_load(unsigned i, unsigned level = 0) { | ||||
|         return this->builder.CreateLoad(this->get_typeptr(i), get_reg_ptr(i), false); | ||||
| @@ -131,52 +136,80 @@ protected: | ||||
|         auto mask = (1ULL<<W) - 1; | ||||
|         auto sign_mask = 1ULL<<(W-1); | ||||
|         return (from & mask) | ((from & sign_mask) ? ~mask : 0); | ||||
|     }    | ||||
|     } | ||||
| <%functions.each{ it.eachLine { %> | ||||
|     ${it}<%} | ||||
| } | ||||
| if(fcsr != null) {%> | ||||
|     Value* NaNBox16(BasicBlock* bb, Value* NaNBox16_val){ | ||||
|         if(static_cast<uint32_t>(traits::FLEN) == 16) | ||||
|             return this->gen_ext(NaNBox16_val, traits::FLEN, false); | ||||
|         auto box = this->builder.CreateNot((this->gen_ext(0, 32, false))); | ||||
|         return this->gen_ext((this->builder.CreateOr(this->builder.CreateShl(this->gen_ext(box, traits::FLEN), 16), this->gen_ext(NaNBox16_val, traits::FLEN))), traits::FLEN, false); | ||||
|     } | ||||
|     Value* NaNBox32(BasicBlock* bb, Value* NaNBox32_val){ | ||||
|         if(static_cast<uint32_t>(traits::FLEN) == 32) | ||||
|             return this->gen_ext(NaNBox32_val, traits::FLEN, false); | ||||
|         auto box = this->builder.CreateNot((this->gen_ext(0, 64, false))); | ||||
|         return this->gen_ext((this->builder.CreateOr(this->builder.CreateShl(this->gen_ext(box, traits::FLEN), 32), this->gen_ext(NaNBox32_val, traits::FLEN))), traits::FLEN, false); | ||||
|     } | ||||
|     Value* NaNBox64(BasicBlock* bb, Value* NaNBox64_val){ | ||||
|         if(static_cast<uint32_t>(traits::FLEN) == 64) | ||||
|             return this->gen_ext(NaNBox64_val, traits::FLEN, false); | ||||
|         auto box = this->builder.CreateNot((this->gen_ext(0, 128, false))); | ||||
|         return this->gen_ext((this->builder.CreateOr(this->builder.CreateShl(this->gen_ext(box, traits::FLEN), 64), this->gen_ext(NaNBox64_val, traits::FLEN))), traits::FLEN, false); | ||||
|     } | ||||
|  | ||||
| <%}%> | ||||
| private: | ||||
|     /**************************************************************************** | ||||
|      * start opcode definitions | ||||
|      ****************************************************************************/ | ||||
|     struct instruction_descriptor { | ||||
|         size_t length; | ||||
|         uint32_t length; | ||||
|         uint32_t value; | ||||
|         uint32_t mask; | ||||
|         compile_func op; | ||||
|     }; | ||||
|     struct decoding_tree_node{ | ||||
|         std::vector<instruction_descriptor> instrs; | ||||
|         std::vector<decoding_tree_node*> children; | ||||
|         uint32_t submask = std::numeric_limits<uint32_t>::max(); | ||||
|         uint32_t value; | ||||
|         decoding_tree_node(uint32_t value) : value(value){} | ||||
|     }; | ||||
|  | ||||
|     decoding_tree_node* root {nullptr}; | ||||
|  | ||||
|     const std::array<instruction_descriptor, ${instructions.size}> instr_descr = {{ | ||||
|     const std::array<instruction_descriptor, ${instructions.size()}> instr_descr = {{ | ||||
|          /* entries are: size, valid value, valid mask, function ptr */<%instructions.each{instr -> %> | ||||
|         /* instruction ${instr.instruction.name}, encoding '${instr.encoding}' */ | ||||
|         {${instr.length}, ${instr.encoding}, ${instr.mask}, &this_class::__${generator.functionName(instr.name)}},<%}%> | ||||
|     }}; | ||||
|   | ||||
|  | ||||
|     //needs to be declared after instr_descr | ||||
|     decoder instr_decoder; | ||||
|  | ||||
|     /* instruction definitions */<%instructions.eachWithIndex{instr, idx -> %> | ||||
|     /* instruction ${idx}: ${instr.name} */ | ||||
|     std::tuple<continuation_e, BasicBlock*> __${generator.functionName(instr.name)}(virt_addr_t& pc, code_word_t instr, BasicBlock* bb){ | ||||
|         bb->setName(fmt::format("${instr.name}_0x{:X}",pc.val)); | ||||
|         this->gen_sync(PRE_SYNC,${idx}); | ||||
|         uint64_t PC = pc.val; | ||||
|         <%instr.fields.eachLine{%>${it} | ||||
|         <%}%>if(this->disass_enabled){ | ||||
|             /* generate console output when executing the command */<%instr.disass.eachLine{%> | ||||
|             ${it}<%}%> | ||||
|             std::vector<Value*> args { | ||||
|                 this->core_ptr, | ||||
|                 this->gen_const(64, pc.val), | ||||
|                 this->builder.CreateGlobalStringPtr(mnemonic), | ||||
|             }; | ||||
|             this->builder.CreateCall(this->mod->getFunction("print_disass"), args); | ||||
|         } | ||||
|         auto cur_pc_val = this->gen_const(32,pc.val); | ||||
|         bb->setName(fmt::format("${instr.name}_0x{:X}",pc.val)); | ||||
|         this->gen_sync(PRE_SYNC,${idx}); | ||||
|          | ||||
|         this->gen_set_pc(pc, traits::PC); | ||||
|         this->set_tval(instr); | ||||
|         pc=pc+ ${instr.length/8}; | ||||
|         this->gen_set_pc(pc, traits::NEXT_PC); | ||||
|          | ||||
|         this->gen_instr_prologue(); | ||||
|         /*generate behavior*/ | ||||
|         <%instr.behavior.eachLine{%>${it} | ||||
|         <%}%> | ||||
|         this->gen_trap_check(bb); | ||||
|     	this->gen_sync(POST_SYNC, ${idx}); | ||||
|         this->gen_sync(POST_SYNC, ${idx}); | ||||
|         this->gen_instr_epilogue(bb); | ||||
|         this->builder.CreateBr(bb); | ||||
|     	return returnValue;         | ||||
|     } | ||||
| @@ -184,8 +217,17 @@ private: | ||||
|     /**************************************************************************** | ||||
|      * end opcode definitions | ||||
|      ****************************************************************************/ | ||||
|     std::tuple<continuation_e, BasicBlock *> illegal_intruction(virt_addr_t &pc, code_word_t instr, BasicBlock *bb) { | ||||
| 		this->gen_sync(iss::PRE_SYNC, instr_descr.size()); | ||||
|     std::tuple<continuation_e, BasicBlock *> illegal_instruction(virt_addr_t &pc, code_word_t instr, BasicBlock *bb) { | ||||
|         if(this->disass_enabled){ | ||||
|             auto mnemonic = std::string("illegal_instruction"); | ||||
|             std::vector<Value*> args { | ||||
|                 this->core_ptr, | ||||
|                 this->gen_const(64, pc.val), | ||||
|                 this->builder.CreateGlobalStringPtr(mnemonic), | ||||
|             }; | ||||
|             this->builder.CreateCall(this->mod->getFunction("print_disass"), args); | ||||
|         } | ||||
|         this->gen_sync(iss::PRE_SYNC, instr_descr.size()); | ||||
|         this->builder.CreateStore(this->builder.CreateLoad(this->get_typeptr(traits::NEXT_PC), get_reg_ptr(traits::NEXT_PC), true), | ||||
|                                    get_reg_ptr(traits::PC), true); | ||||
|         this->builder.CreateStore( | ||||
| @@ -193,63 +235,14 @@ private: | ||||
|                                      this->gen_const(64U, 1)), | ||||
|             get_reg_ptr(traits::ICOUNT), true); | ||||
|         pc = pc + ((instr & 3) == 3 ? 4 : 2); | ||||
|         this->set_tval(instr); | ||||
|         this->gen_raise_trap(0, 2);     // illegal instruction trap | ||||
| 		this->gen_sync(iss::POST_SYNC, instr_descr.size()); | ||||
|         this->gen_trap_check(this->leave_blk); | ||||
|         return std::make_tuple(BRANCH, nullptr); | ||||
|         bb = this->leave_blk; | ||||
|         this->gen_instr_epilogue(bb); | ||||
|         this->builder.CreateBr(bb); | ||||
|         return std::make_tuple(ILLEGAL_INSTR, nullptr); | ||||
|     }     | ||||
|     //decoding functionality | ||||
|  | ||||
|     void populate_decoding_tree(decoding_tree_node* root){ | ||||
|         //create submask | ||||
|         for(auto instr: root->instrs){ | ||||
|             root->submask &= instr.mask; | ||||
|         } | ||||
|         //put each instr according to submask&encoding into children | ||||
|         for(auto instr: root->instrs){ | ||||
|             bool foundMatch = false; | ||||
|             for(auto child: root->children){ | ||||
|                 //use value as identifying trait | ||||
|                 if(child->value == (instr.value&root->submask)){ | ||||
|                     child->instrs.push_back(instr); | ||||
|                     foundMatch = true; | ||||
|                 } | ||||
|             } | ||||
|             if(!foundMatch){ | ||||
|                 decoding_tree_node* child = new decoding_tree_node(instr.value&root->submask); | ||||
|                 child->instrs.push_back(instr); | ||||
|                 root->children.push_back(child); | ||||
|             } | ||||
|         } | ||||
|         root->instrs.clear(); | ||||
|         //call populate_decoding_tree for all children | ||||
|         if(root->children.size() >1) | ||||
|             for(auto child: root->children){ | ||||
|                 populate_decoding_tree(child);       | ||||
|             } | ||||
|         else{ | ||||
|             //sort instrs by value of the mask, this works bc we want to have the least restrictive one last | ||||
|             std::sort(root->children[0]->instrs.begin(), root->children[0]->instrs.end(), [](const instruction_descriptor& instr1, const instruction_descriptor& instr2) { | ||||
|             return instr1.mask > instr2.mask; | ||||
|             });  | ||||
|         } | ||||
|     } | ||||
|     compile_func decode_instr(decoding_tree_node* node, code_word_t word){ | ||||
|         if(!node->children.size()){ | ||||
|             if(node->instrs.size() == 1) return node->instrs[0].op; | ||||
|             for(auto instr : node->instrs){ | ||||
|                 if((instr.mask&word) == instr.value) return instr.op; | ||||
|             } | ||||
|         } | ||||
|         else{ | ||||
|             for(auto child : node->children){ | ||||
|                 if (child->value == (node->submask&word)){ | ||||
|                     return decode_instr(child, word); | ||||
|                 }   | ||||
|             }   | ||||
|         } | ||||
|         return nullptr; | ||||
|     } | ||||
| }; | ||||
|  | ||||
| template <typename CODE_WORD> void debug_fn(CODE_WORD instr) { | ||||
| @@ -261,84 +254,103 @@ template <typename ARCH> vm_impl<ARCH>::vm_impl() { this(new ARCH()); } | ||||
|  | ||||
| template <typename ARCH> | ||||
| vm_impl<ARCH>::vm_impl(ARCH &core, unsigned core_id, unsigned cluster_id) | ||||
| : vm_base<ARCH>(core, core_id, cluster_id) { | ||||
|     root = new decoding_tree_node(std::numeric_limits<uint32_t>::max()); | ||||
|     for(auto instr:instr_descr){ | ||||
|         root->instrs.push_back(instr); | ||||
|     } | ||||
|     populate_decoding_tree(root); | ||||
| } | ||||
| : vm_base<ARCH>(core, core_id, cluster_id) | ||||
| , instr_decoder([this]() { | ||||
|         std::vector<generic_instruction_descriptor> g_instr_descr; | ||||
|         g_instr_descr.reserve(instr_descr.size()); | ||||
|         for (uint32_t i = 0; i < instr_descr.size(); ++i) { | ||||
|             generic_instruction_descriptor new_instr_descr {instr_descr[i].value, instr_descr[i].mask, i}; | ||||
|             g_instr_descr.push_back(new_instr_descr); | ||||
|         } | ||||
|         return std::move(g_instr_descr); | ||||
|     }()) {} | ||||
|  | ||||
| template <typename ARCH> | ||||
| std::tuple<continuation_e, BasicBlock *> | ||||
| vm_impl<ARCH>::gen_single_inst_behavior(virt_addr_t &pc, unsigned int &inst_cnt, BasicBlock *this_block) { | ||||
| vm_impl<ARCH>::gen_single_inst_behavior(virt_addr_t &pc, BasicBlock *this_block) { | ||||
|     // we fetch at max 4 byte, alignment is 2 | ||||
|     enum {TRAP_ID=1<<16}; | ||||
|     code_word_t instr = 0; | ||||
|     // const typename traits::addr_t upper_bits = ~traits::PGMASK; | ||||
|     phys_addr_t paddr(pc); | ||||
|     auto *const data = (uint8_t *)&instr; | ||||
|     if(this->core.has_mmu()) | ||||
|         paddr = this->core.virt2phys(pc); | ||||
|     //TODO: re-add page handling | ||||
| //    if ((pc.val & upper_bits) != ((pc.val + 2) & upper_bits)) { // we may cross a page boundary | ||||
| //        auto res = this->core.read(paddr, 2, data); | ||||
| //        if (res != iss::Ok) throw trap_access(TRAP_ID, pc.val); | ||||
| //        if ((instr & 0x3) == 0x3) { // this is a 32bit instruction | ||||
| //            res = this->core.read(this->core.v2p(pc + 2), 2, data + 2); | ||||
| //        } | ||||
| //    } else { | ||||
|         auto res = this->core.read(paddr, 4, data); | ||||
|         if (res != iss::Ok) throw trap_access(TRAP_ID, pc.val); | ||||
| //    } | ||||
|     if (instr == 0x0000006f || (instr&0xffff)==0xa001) throw simulation_stopped(0); // 'J 0' or 'C.J 0' | ||||
|     // curr pc on stack | ||||
|     ++inst_cnt; | ||||
|     auto f = decode_instr(root, instr); | ||||
|     auto res = this->core.read(paddr, 4, data); | ||||
|     if (res != iss::Ok)  | ||||
|         return std::make_tuple(ILLEGAL_FETCH, nullptr); | ||||
|     if (instr == 0x0000006f || (instr&0xffff)==0xa001){ | ||||
|         this->builder.CreateBr(this->leave_blk); | ||||
|         return std::make_tuple(JUMP_TO_SELF, nullptr); | ||||
|         } | ||||
|     uint32_t inst_index = instr_decoder.decode_instr(instr); | ||||
|     compile_func f = nullptr; | ||||
|     if(inst_index < instr_descr.size()) | ||||
|         f = instr_descr[inst_index].op; | ||||
|     if (f == nullptr) { | ||||
|         f = &this_class::illegal_intruction; | ||||
|         f = &this_class::illegal_instruction; | ||||
|     } | ||||
|     return (this->*f)(pc, instr, this_block); | ||||
| } | ||||
|  | ||||
| template <typename ARCH> void vm_impl<ARCH>::gen_leave_behavior(BasicBlock *leave_blk) { | ||||
| template <typename ARCH> | ||||
| void vm_impl<ARCH>::gen_leave_behavior(BasicBlock *leave_blk) { | ||||
|     this->builder.SetInsertPoint(leave_blk); | ||||
|     this->builder.CreateRet(this->builder.CreateLoad(this->get_typeptr(traits::NEXT_PC),get_reg_ptr(traits::NEXT_PC), false)); | ||||
| } | ||||
|  | ||||
| template <typename ARCH> void vm_impl<ARCH>::gen_raise_trap(uint16_t trap_id, uint16_t cause) { | ||||
| template <typename ARCH> | ||||
| void vm_impl<ARCH>::gen_raise_trap(uint16_t trap_id, uint16_t cause) { | ||||
|     auto *TRAP_val = this->gen_const(32, 0x80 << 24 | (cause << 16) | trap_id); | ||||
|     this->builder.CreateStore(TRAP_val, get_reg_ptr(traits::TRAP_STATE), true); | ||||
|     this->builder.CreateStore(this->gen_const(32U, std::numeric_limits<uint32_t>::max()), get_reg_ptr(traits::LAST_BRANCH), false); | ||||
|     this->builder.CreateBr(this->trap_blk); | ||||
| } | ||||
|  | ||||
| template <typename ARCH> void vm_impl<ARCH>::gen_leave_trap(unsigned lvl) { | ||||
| template <typename ARCH> | ||||
| void vm_impl<ARCH>::gen_leave_trap(unsigned lvl) { | ||||
|     std::vector<Value *> args{ this->core_ptr, ConstantInt::get(getContext(), APInt(64, lvl)) }; | ||||
|     this->builder.CreateCall(this->mod->getFunction("leave_trap"), args); | ||||
|     auto *PC_val = this->gen_read_mem(traits::CSR, (lvl << 8) + 0x41, traits::XLEN / 8); | ||||
|     this->builder.CreateStore(PC_val, get_reg_ptr(traits::NEXT_PC), false); | ||||
|     this->builder.CreateStore(this->gen_const(32U, std::numeric_limits<uint32_t>::max()), get_reg_ptr(traits::LAST_BRANCH), false); | ||||
|     this->builder.CreateStore(this->gen_const(32U, static_cast<int>(UNKNOWN_JUMP)), get_reg_ptr(traits::LAST_BRANCH), false); | ||||
| } | ||||
|  | ||||
| template <typename ARCH> void vm_impl<ARCH>::gen_wait(unsigned type) { | ||||
| template <typename ARCH> | ||||
| void vm_impl<ARCH>::gen_wait(unsigned type) { | ||||
|     std::vector<Value *> args{ this->core_ptr, ConstantInt::get(getContext(), APInt(64, type)) }; | ||||
|     this->builder.CreateCall(this->mod->getFunction("wait"), args); | ||||
| } | ||||
|  | ||||
| template <typename ARCH> void vm_impl<ARCH>::gen_trap_behavior(BasicBlock *trap_blk) { | ||||
| template <typename ARCH> | ||||
| inline void vm_impl<ARCH>::set_tval(uint64_t tval) { | ||||
|     auto tmp_tval = this->gen_const(64, tval); | ||||
|     this->set_tval(tmp_tval); | ||||
| } | ||||
| template <typename ARCH> | ||||
| inline void vm_impl<ARCH>::set_tval(Value* new_tval) { | ||||
|     this->builder.CreateStore(this->gen_ext(new_tval, 64, false), this->tval); | ||||
| } | ||||
| template <typename ARCH>  | ||||
| void vm_impl<ARCH>::gen_trap_behavior(BasicBlock *trap_blk) { | ||||
|     this->builder.SetInsertPoint(trap_blk); | ||||
|     this->gen_sync(POST_SYNC, -1); //TODO get right InstrId | ||||
|     auto *trap_state_val = this->builder.CreateLoad(this->get_typeptr(traits::TRAP_STATE), get_reg_ptr(traits::TRAP_STATE), true); | ||||
|     this->builder.CreateStore(this->gen_const(32U, std::numeric_limits<uint32_t>::max()), | ||||
|                               get_reg_ptr(traits::LAST_BRANCH), false); | ||||
|     std::vector<Value *> args{this->core_ptr, this->adj_to64(trap_state_val), | ||||
|                               this->adj_to64(this->builder.CreateLoad(this->get_typeptr(traits::PC), get_reg_ptr(traits::PC), false))}; | ||||
|     auto *cur_pc_val = this->builder.CreateLoad(this->get_typeptr(traits::PC), get_reg_ptr(traits::PC), true); | ||||
|     std::vector<Value *> args{this->core_ptr, | ||||
|                                 this->adj_to64(trap_state_val), | ||||
|                                 this->adj_to64(cur_pc_val), | ||||
|                               this->adj_to64(this->builder.CreateLoad(this->get_type(64),this->tval))}; | ||||
|     this->builder.CreateCall(this->mod->getFunction("enter_trap"), args); | ||||
|     this->builder.CreateStore(this->gen_const(32U, static_cast<int>(UNKNOWN_JUMP)), get_reg_ptr(traits::LAST_BRANCH), false); | ||||
|  | ||||
|     auto *trap_addr_val = this->builder.CreateLoad(this->get_typeptr(traits::NEXT_PC), get_reg_ptr(traits::NEXT_PC), false); | ||||
|     this->builder.CreateRet(trap_addr_val); | ||||
| } | ||||
| template <typename ARCH> | ||||
| void vm_impl<ARCH>::gen_instr_prologue() { | ||||
|     auto* trap_val = | ||||
|         this->builder.CreateLoad(this->get_typeptr(arch::traits<ARCH>::PENDING_TRAP), get_reg_ptr(arch::traits<ARCH>::PENDING_TRAP)); | ||||
|     this->builder.CreateStore(trap_val, get_reg_ptr(arch::traits<ARCH>::TRAP_STATE), false); | ||||
| } | ||||
|              | ||||
|  | ||||
| template <typename ARCH> inline void vm_impl<ARCH>::gen_trap_check(BasicBlock *bb) { | ||||
| template <typename ARCH> | ||||
| void vm_impl<ARCH>::gen_instr_epilogue(BasicBlock *bb) { | ||||
|     auto* target_bb = BasicBlock::Create(this->mod->getContext(), "", this->func, bb); | ||||
|     auto *v = this->builder.CreateLoad(this->get_typeptr(traits::TRAP_STATE), get_reg_ptr(traits::TRAP_STATE), true); | ||||
|     this->gen_cond_branch(this->builder.CreateICmp( | ||||
| @@ -346,6 +358,14 @@ template <typename ARCH> inline void vm_impl<ARCH>::gen_trap_check(BasicBlock *b | ||||
|                               ConstantInt::get(getContext(), APInt(v->getType()->getIntegerBitWidth(), 0))), | ||||
|                           target_bb, this->trap_blk, 1); | ||||
|     this->builder.SetInsertPoint(target_bb); | ||||
|     // update icount | ||||
|     auto* icount_val = this->builder.CreateAdd( | ||||
|         this->builder.CreateLoad(this->get_typeptr(arch::traits<ARCH>::ICOUNT), get_reg_ptr(arch::traits<ARCH>::ICOUNT)), this->gen_const(64U, 1)); | ||||
|     this->builder.CreateStore(icount_val, get_reg_ptr(arch::traits<ARCH>::ICOUNT), false); | ||||
|     //increment cyclecount | ||||
|     auto* cycle_val = this->builder.CreateAdd( | ||||
|         this->builder.CreateLoad(this->get_typeptr(arch::traits<ARCH>::CYCLE), get_reg_ptr(arch::traits<ARCH>::CYCLE)), this->gen_const(64U, 1)); | ||||
|     this->builder.CreateStore(cycle_val, get_reg_ptr(arch::traits<ARCH>::CYCLE), false); | ||||
| } | ||||
|  | ||||
| } // namespace ${coreDef.name.toLowerCase()} | ||||
| @@ -359,25 +379,33 @@ std::unique_ptr<vm_if> create<arch::${coreDef.name.toLowerCase()}>(arch::${coreD | ||||
| } // namespace llvm | ||||
| } // namespace iss | ||||
|  | ||||
| #include <iss/factory.h> | ||||
| #include <iss/arch/riscv_hart_m_p.h> | ||||
| #include <iss/arch/riscv_hart_mu_p.h> | ||||
| #include <iss/factory.h> | ||||
| namespace iss { | ||||
| namespace { | ||||
| volatile std::array<bool, 2> dummy = { | ||||
|         core_factory::instance().register_creator("${coreDef.name.toLowerCase()}|m_p|llvm", [](unsigned port, void*) -> std::tuple<cpu_ptr, vm_ptr>{ | ||||
|         core_factory::instance().register_creator("${coreDef.name.toLowerCase()}|m_p|llvm", [](unsigned port, void* init_data) -> std::tuple<cpu_ptr, vm_ptr>{ | ||||
|             auto* cpu = new iss::arch::riscv_hart_m_p<iss::arch::${coreDef.name.toLowerCase()}>(); | ||||
|             auto* vm = new llvm::${coreDef.name.toLowerCase()}::vm_impl<arch::${coreDef.name.toLowerCase()}>(*cpu, false); | ||||
|             if (port != 0) debugger::server<debugger::gdb_session>::run_server(vm, port); | ||||
| 		    auto vm = new llvm::${coreDef.name.toLowerCase()}::vm_impl<arch::${coreDef.name.toLowerCase()}>(*cpu, false); | ||||
| 		    if (port != 0) debugger::server<debugger::gdb_session>::run_server(vm, port); | ||||
|             if(init_data){ | ||||
|                 auto* cb = reinterpret_cast<std::function<void(arch_if*, arch::traits<arch::${coreDef.name.toLowerCase()}>::reg_t*, arch::traits<arch::${coreDef.name.toLowerCase()}>::reg_t*)>*>(init_data); | ||||
|                 cpu->set_semihosting_callback(*cb); | ||||
|             } | ||||
|             return {cpu_ptr{cpu}, vm_ptr{vm}}; | ||||
|         }), | ||||
|         core_factory::instance().register_creator("${coreDef.name.toLowerCase()}|mu_p|llvm", [](unsigned port, void*) -> std::tuple<cpu_ptr, vm_ptr>{ | ||||
|         core_factory::instance().register_creator("${coreDef.name.toLowerCase()}|mu_p|llvm", [](unsigned port, void* init_data) -> std::tuple<cpu_ptr, vm_ptr>{ | ||||
|             auto* cpu = new iss::arch::riscv_hart_mu_p<iss::arch::${coreDef.name.toLowerCase()}>(); | ||||
|             auto* vm = new llvm::${coreDef.name.toLowerCase()}::vm_impl<arch::${coreDef.name.toLowerCase()}>(*cpu, false); | ||||
|             if (port != 0) debugger::server<debugger::gdb_session>::run_server(vm, port); | ||||
| 		    auto vm = new llvm::${coreDef.name.toLowerCase()}::vm_impl<arch::${coreDef.name.toLowerCase()}>(*cpu, false); | ||||
| 		    if (port != 0) debugger::server<debugger::gdb_session>::run_server(vm, port); | ||||
|             if(init_data){ | ||||
|                 auto* cb = reinterpret_cast<std::function<void(arch_if*, arch::traits<arch::${coreDef.name.toLowerCase()}>::reg_t*, arch::traits<arch::${coreDef.name.toLowerCase()}>::reg_t*)>*>(init_data); | ||||
|                 cpu->set_semihosting_callback(*cb); | ||||
|             } | ||||
|             return {cpu_ptr{cpu}, vm_ptr{vm}}; | ||||
|         }) | ||||
| }; | ||||
| } | ||||
| } | ||||
| // clang-format on | ||||
| // clang-format on | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| /******************************************************************************* | ||||
|  * Copyright (C) 2020 MINRES Technologies GmbH | ||||
|  * Copyright (C) 2020-2024 MINRES Technologies GmbH | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
| @@ -37,7 +37,10 @@ | ||||
| #include <iss/tcc/vm_base.h> | ||||
| #include <util/logging.h> | ||||
| #include <sstream> | ||||
|  | ||||
| #include <iss/instruction_decoder.h> | ||||
| <%def fcsr = registers.find {it.name=='FCSR'} | ||||
| if(fcsr != null) {%> | ||||
| #include <vm/fp_functions.h><%}%> | ||||
| #ifndef FMT_HEADER_ONLY | ||||
| #define FMT_HEADER_ONLY | ||||
| #endif | ||||
| @@ -80,16 +83,21 @@ protected: | ||||
|     using vm_base<ARCH>::get_reg_ptr; | ||||
|  | ||||
|     using this_class = vm_impl<ARCH>; | ||||
|     using compile_ret_t = std::tuple<continuation_e>; | ||||
|     using compile_ret_t = continuation_e; | ||||
|     using compile_func = compile_ret_t (this_class::*)(virt_addr_t &pc, code_word_t instr, tu_builder&); | ||||
|  | ||||
|     inline const char *name(size_t index){return traits::reg_aliases.at(index);} | ||||
| <% | ||||
| if(fcsr != null) {%> | ||||
|     inline const char *fname(size_t index){return index < 32?name(index+traits::F0):"illegal";}    | ||||
| <%}%> | ||||
|     void add_prologue(tu_builder& tu) override; | ||||
|  | ||||
|     void setup_module(std::string m) override { | ||||
|         super::setup_module(m); | ||||
|     } | ||||
|  | ||||
|     compile_ret_t gen_single_inst_behavior(virt_addr_t &, unsigned int &, tu_builder&) override; | ||||
|     compile_ret_t gen_single_inst_behavior(virt_addr_t &, tu_builder&) override; | ||||
|  | ||||
|     void gen_trap_behavior(tu_builder& tu) override; | ||||
|  | ||||
| @@ -97,7 +105,9 @@ protected: | ||||
|  | ||||
|     void gen_leave_trap(tu_builder& tu, unsigned lvl); | ||||
|  | ||||
|     void gen_wait(tu_builder& tu, unsigned type); | ||||
|     inline void gen_set_tval(tu_builder& tu, uint64_t new_tval); | ||||
|  | ||||
|     inline void gen_set_tval(tu_builder& tu, value new_tval); | ||||
|  | ||||
|     inline void gen_trap_check(tu_builder& tu) { | ||||
|         tu("if(*trap_state!=0) goto trap_entry;"); | ||||
| @@ -126,34 +136,58 @@ protected: | ||||
|         auto mask = (1ULL<<W) - 1; | ||||
|         auto sign_mask = 1ULL<<(W-1); | ||||
|         return (from & mask) | ((from & sign_mask) ? ~mask : 0); | ||||
|     }     | ||||
|     } | ||||
|  | ||||
| <%functions.each{ it.eachLine { %> | ||||
|     ${it}<%} | ||||
| } | ||||
| if(fcsr != null) {%> | ||||
|     value NaNBox16(tu_builder& tu, value NaNBox16_val){ | ||||
|         if(static_cast<uint32_t>(traits::FLEN) == 16) | ||||
|             return tu.ext(NaNBox16_val, traits::FLEN, false); | ||||
|         else {          | ||||
|             auto box = tu.assignment(tu.logical_neg((tu.ext(0, 32, false))), traits::FLEN) ; | ||||
|             return tu.ext((tu.bitwise_or(tu.shl(box, 16), NaNBox16_val)), traits::FLEN, false); | ||||
|         }  | ||||
|     } | ||||
|     value NaNBox32(tu_builder& tu, value NaNBox32_val){ | ||||
|         if(static_cast<uint32_t>(traits::FLEN) == 32) | ||||
|             return tu.ext(NaNBox32_val, traits::FLEN, false); | ||||
|         else {          | ||||
|             auto box = tu.assignment(tu.logical_neg((tu.ext(0, 64, false))), traits::FLEN) ; | ||||
|             return tu.ext((tu.bitwise_or(tu.shl(box, 32), NaNBox32_val)), traits::FLEN, false); | ||||
|         }  | ||||
|     } | ||||
|     value NaNBox64(tu_builder& tu, value NaNBox64_val){ | ||||
|         if(static_cast<uint32_t>(traits::FLEN) == 64) | ||||
|             return tu.ext(NaNBox64_val, traits::FLEN, false); | ||||
|         else { | ||||
|             throw new std::runtime_error("tcc does not support Registers wider than 64 bits");      | ||||
|             auto box = tu.assignment(tu.logical_neg((tu.ext(0, 128, false))), traits::FLEN) ; | ||||
|             return tu.ext((tu.bitwise_or(tu.shl(box, 64), NaNBox64_val)), traits::FLEN, false); | ||||
|         } | ||||
|     } | ||||
| <%}%> | ||||
| private: | ||||
|     /**************************************************************************** | ||||
|      * start opcode definitions | ||||
|      ****************************************************************************/ | ||||
|     struct instruction_descriptor { | ||||
|         size_t length; | ||||
|         uint32_t length; | ||||
|         uint32_t value; | ||||
|         uint32_t mask; | ||||
|         compile_func op; | ||||
|     }; | ||||
|     struct decoding_tree_node{ | ||||
|         std::vector<instruction_descriptor> instrs; | ||||
|         std::vector<decoding_tree_node*> children; | ||||
|         uint32_t submask = std::numeric_limits<uint32_t>::max(); | ||||
|         uint32_t value; | ||||
|         decoding_tree_node(uint32_t value) : value(value){} | ||||
|     }; | ||||
|  | ||||
|     decoding_tree_node* root {nullptr}; | ||||
|  | ||||
|     const std::array<instruction_descriptor, ${instructions.size}> instr_descr = {{ | ||||
|     const std::array<instruction_descriptor, ${instructions.size()}> instr_descr = {{ | ||||
|          /* entries are: size, valid value, valid mask, function ptr */<%instructions.each{instr -> %> | ||||
|         /* instruction ${instr.instruction.name}, encoding '${instr.encoding}' */ | ||||
|         {${instr.length}, ${instr.encoding}, ${instr.mask}, &this_class::__${generator.functionName(instr.name)}},<%}%> | ||||
|     }}; | ||||
|   | ||||
|  | ||||
|     //needs to be declared after instr_descr | ||||
|     decoder instr_decoder; | ||||
|  | ||||
|     /* instruction definitions */<%instructions.eachWithIndex{instr, idx -> %> | ||||
|     /* instruction ${idx}: ${instr.name} */ | ||||
|     compile_ret_t __${generator.functionName(instr.name)}(virt_addr_t& pc, code_word_t instr, tu_builder& tu){ | ||||
| @@ -164,82 +198,39 @@ private: | ||||
|         <%}%>if(this->disass_enabled){ | ||||
|             /* generate console output when executing the command */<%instr.disass.eachLine{%> | ||||
|             ${it}<%}%> | ||||
|             tu("print_disass(core_ptr, {:#x}, \"{}\");", pc.val, mnemonic); | ||||
|         } | ||||
|         auto cur_pc_val = tu.constant(pc.val, traits::reg_bit_widths[traits::PC]); | ||||
|         pc=pc+ ${instr.length/8}; | ||||
|         gen_set_pc(tu, pc, traits::NEXT_PC); | ||||
|         tu("(*cycle)++;"); | ||||
|         tu.open_scope(); | ||||
|         this->gen_set_tval(tu, instr); | ||||
|         <%instr.behavior.eachLine{%>${it} | ||||
|         <%}%> | ||||
|         tu("(*icount)++;"); | ||||
|         tu("(*instret)++;"); | ||||
|         tu.close_scope(); | ||||
|         gen_trap_check(tu);         | ||||
|         vm_base<ARCH>::gen_sync(tu, POST_SYNC,${idx}); | ||||
|         gen_trap_check(tu);         | ||||
|         return returnValue; | ||||
|     } | ||||
|     <%}%> | ||||
|     /**************************************************************************** | ||||
|      * end opcode definitions | ||||
|      ****************************************************************************/ | ||||
|     compile_ret_t illegal_intruction(virt_addr_t &pc, code_word_t instr, tu_builder& tu) { | ||||
|     compile_ret_t illegal_instruction(virt_addr_t &pc, code_word_t instr, tu_builder& tu) { | ||||
|         vm_impl::gen_sync(tu, iss::PRE_SYNC, instr_descr.size()); | ||||
|         if(this->disass_enabled){ | ||||
|             /* generate console output when executing the command */ | ||||
|             tu("print_disass(core_ptr, {:#x}, \"{}\");", pc.val, std::string("illegal_instruction")); | ||||
|         } | ||||
|         pc = pc + ((instr & 3) == 3 ? 4 : 2); | ||||
|         gen_raise_trap(tu, 0, 2);     // illegal instruction trap | ||||
|         gen_raise_trap(tu, 0, static_cast<int32_t>(traits:: RV_CAUSE_ILLEGAL_INSTRUCTION)); | ||||
|         this->gen_set_tval(tu, instr); | ||||
|         vm_impl::gen_sync(tu, iss::POST_SYNC, instr_descr.size()); | ||||
|         vm_impl::gen_trap_check(tu); | ||||
|         return BRANCH; | ||||
|     } | ||||
|      | ||||
|     //decoding functionality | ||||
|  | ||||
|     void populate_decoding_tree(decoding_tree_node* root){ | ||||
|         //create submask | ||||
|         for(auto instr: root->instrs){ | ||||
|             root->submask &= instr.mask; | ||||
|         } | ||||
|         //put each instr according to submask&encoding into children | ||||
|         for(auto instr: root->instrs){ | ||||
|             bool foundMatch = false; | ||||
|             for(auto child: root->children){ | ||||
|                 //use value as identifying trait | ||||
|                 if(child->value == (instr.value&root->submask)){ | ||||
|                     child->instrs.push_back(instr); | ||||
|                     foundMatch = true; | ||||
|                 } | ||||
|             } | ||||
|             if(!foundMatch){ | ||||
|                 decoding_tree_node* child = new decoding_tree_node(instr.value&root->submask); | ||||
|                 child->instrs.push_back(instr); | ||||
|                 root->children.push_back(child); | ||||
|             } | ||||
|         } | ||||
|         root->instrs.clear(); | ||||
|         //call populate_decoding_tree for all children | ||||
|         if(root->children.size() >1) | ||||
|             for(auto child: root->children){ | ||||
|                 populate_decoding_tree(child);       | ||||
|             } | ||||
|         else{ | ||||
|             //sort instrs by value of the mask, this works bc we want to have the least restrictive one last | ||||
|             std::sort(root->children[0]->instrs.begin(), root->children[0]->instrs.end(), [](const instruction_descriptor& instr1, const instruction_descriptor& instr2) { | ||||
|             return instr1.mask > instr2.mask; | ||||
|             });  | ||||
|         } | ||||
|     } | ||||
|     compile_func decode_instr(decoding_tree_node* node, code_word_t word){ | ||||
|         if(!node->children.size()){ | ||||
|             if(node->instrs.size() == 1) return node->instrs[0].op; | ||||
|             for(auto instr : node->instrs){ | ||||
|                 if((instr.mask&word) == instr.value) return instr.op; | ||||
|             } | ||||
|         } | ||||
|         else{ | ||||
|             for(auto child : node->children){ | ||||
|                 if (child->value == (node->submask&word)){ | ||||
|                     return decode_instr(child, word); | ||||
|                 }   | ||||
|             }   | ||||
|         } | ||||
|         return nullptr; | ||||
|         return ILLEGAL_INSTR; | ||||
|     } | ||||
| }; | ||||
|  | ||||
| @@ -252,65 +243,139 @@ template <typename ARCH> vm_impl<ARCH>::vm_impl() { this(new ARCH()); } | ||||
|  | ||||
| template <typename ARCH> | ||||
| vm_impl<ARCH>::vm_impl(ARCH &core, unsigned core_id, unsigned cluster_id) | ||||
| : vm_base<ARCH>(core, core_id, cluster_id) { | ||||
|     root = new decoding_tree_node(std::numeric_limits<uint32_t>::max()); | ||||
|     for(auto instr:instr_descr){ | ||||
|         root->instrs.push_back(instr); | ||||
|     } | ||||
|     populate_decoding_tree(root); | ||||
| } | ||||
| : vm_base<ARCH>(core, core_id, cluster_id) | ||||
| , instr_decoder([this]() { | ||||
|         std::vector<generic_instruction_descriptor> g_instr_descr; | ||||
|         g_instr_descr.reserve(instr_descr.size()); | ||||
|         for (uint32_t i = 0; i < instr_descr.size(); ++i) { | ||||
|             generic_instruction_descriptor new_instr_descr {instr_descr[i].value, instr_descr[i].mask, i}; | ||||
|             g_instr_descr.push_back(new_instr_descr); | ||||
|         } | ||||
|         return std::move(g_instr_descr); | ||||
|     }()) {} | ||||
|  | ||||
| template <typename ARCH> | ||||
| std::tuple<continuation_e> | ||||
| vm_impl<ARCH>::gen_single_inst_behavior(virt_addr_t &pc, unsigned int &inst_cnt, tu_builder& tu) { | ||||
| continuation_e | ||||
| vm_impl<ARCH>::gen_single_inst_behavior(virt_addr_t &pc, tu_builder& tu) { | ||||
|     // we fetch at max 4 byte, alignment is 2 | ||||
|     enum {TRAP_ID=1<<16}; | ||||
|     code_word_t instr = 0; | ||||
|     phys_addr_t paddr(pc); | ||||
|     if(this->core.has_mmu()) | ||||
|         paddr = this->core.virt2phys(pc); | ||||
|     //TODO: re-add page handling | ||||
| //    if ((pc.val & upper_bits) != ((pc.val + 2) & upper_bits)) { // we may cross a page boundary | ||||
| //        auto res = this->core.read(paddr, 2, data); | ||||
| //        if (res != iss::Ok) throw trap_access(TRAP_ID, pc.val); | ||||
| //        if ((insn & 0x3) == 0x3) { // this is a 32bit instruction | ||||
| //            res = this->core.read(this->core.v2p(pc + 2), 2, data + 2); | ||||
| //        } | ||||
| //    } else { | ||||
|         auto res = this->core.read(paddr, 4, reinterpret_cast<uint8_t*>(&instr)); | ||||
|         if (res != iss::Ok) throw trap_access(TRAP_ID, pc.val); | ||||
| //    } | ||||
|     if (instr == 0x0000006f || (instr&0xffff)==0xa001) throw simulation_stopped(0); // 'J 0' or 'C.J 0' | ||||
|     // curr pc on stack | ||||
|     ++inst_cnt; | ||||
|     auto f = decode_instr(root, instr); | ||||
|     auto res = this->core.read(paddr, 4, reinterpret_cast<uint8_t*>(&instr)); | ||||
|     if (res != iss::Ok) | ||||
|         return ILLEGAL_FETCH; | ||||
|     if (instr == 0x0000006f || (instr&0xffff)==0xa001)  | ||||
|         return JUMP_TO_SELF; | ||||
|     uint32_t inst_index = instr_decoder.decode_instr(instr); | ||||
|     compile_func f = nullptr; | ||||
|     if(inst_index < instr_descr.size()) | ||||
|         f = instr_descr[inst_index].op; | ||||
|     if (f == nullptr) { | ||||
|         f = &this_class::illegal_intruction; | ||||
|         f = &this_class::illegal_instruction; | ||||
|     } | ||||
|     return (this->*f)(pc, instr, tu); | ||||
| } | ||||
|  | ||||
| template <typename ARCH> void vm_impl<ARCH>::gen_raise_trap(tu_builder& tu, uint16_t trap_id, uint16_t cause) { | ||||
|     tu("  *trap_state = {:#x};", 0x80 << 24 | (cause << 16) | trap_id); | ||||
|     tu.store(traits::LAST_BRANCH, tu.constant(std::numeric_limits<uint32_t>::max(), 32)); | ||||
| } | ||||
|  | ||||
| template <typename ARCH> void vm_impl<ARCH>::gen_leave_trap(tu_builder& tu, unsigned lvl) { | ||||
|     tu("leave_trap(core_ptr, {});", lvl); | ||||
|     tu.store(traits::NEXT_PC, tu.read_mem(traits::CSR, (lvl << 8) + 0x41, traits::XLEN)); | ||||
|     tu.store(traits::LAST_BRANCH, tu.constant(std::numeric_limits<uint32_t>::max(), 32)); | ||||
|     tu.store(traits::LAST_BRANCH, tu.constant(static_cast<int>(UNKNOWN_JUMP), 32)); | ||||
| } | ||||
|  | ||||
| template <typename ARCH> void vm_impl<ARCH>::gen_wait(tu_builder& tu, unsigned type) { | ||||
| template <typename ARCH> void vm_impl<ARCH>::gen_set_tval(tu_builder& tu, uint64_t new_tval) { | ||||
|     tu(fmt::format("tval = {};", new_tval)); | ||||
| } | ||||
| template <typename ARCH> void vm_impl<ARCH>::gen_set_tval(tu_builder& tu, value new_tval) { | ||||
|     tu(fmt::format("tval = {};", new_tval.str)); | ||||
| } | ||||
|  | ||||
| template <typename ARCH> void vm_impl<ARCH>::gen_trap_behavior(tu_builder& tu) { | ||||
|     tu("trap_entry:"); | ||||
|     this->gen_sync(tu, POST_SYNC, -1);     | ||||
|     tu("enter_trap(core_ptr, *trap_state, *pc, 0);"); | ||||
|     tu.store(traits::LAST_BRANCH, tu.constant(std::numeric_limits<uint32_t>::max(),32)); | ||||
|     tu("enter_trap(core_ptr, *trap_state, *pc, tval);"); | ||||
|     tu.store(traits::LAST_BRANCH, tu.constant(static_cast<int>(UNKNOWN_JUMP),32)); | ||||
|     tu("return *next_pc;"); | ||||
| } | ||||
| template <typename ARCH> void vm_impl<ARCH>::add_prologue(tu_builder& tu){ | ||||
|     std::ostringstream os; | ||||
|     os << tu.add_reg_ptr("trap_state", arch::traits<ARCH>::TRAP_STATE, this->regs_base_ptr); | ||||
|     os << tu.add_reg_ptr("pending_trap", arch::traits<ARCH>::PENDING_TRAP, this->regs_base_ptr); | ||||
|     os << tu.add_reg_ptr("cycle", arch::traits<ARCH>::CYCLE, this->regs_base_ptr); | ||||
| <%if(fcsr != null) { | ||||
|     def flen = constants.find { it.name == 'FLEN' }?.value ?: 0 | ||||
|     %> | ||||
|     os << "uint32_t (*fget_flags)()=" << (uintptr_t)&fget_flags << ";\\n"; | ||||
|  | ||||
|     os << "uint16_t (*fadd_h)(uint16_t v1, uint16_t v2, uint8_t mode)=" << (uintptr_t)&fadd_h << ";\\n"; | ||||
|     os << "uint16_t (*fsub_h)(uint16_t v1, uint16_t v2, uint8_t mode)=" << (uintptr_t)&fsub_h << ";\\n"; | ||||
|     os << "uint16_t (*fmul_h)(uint16_t v1, uint16_t v2, uint8_t mode)=" << (uintptr_t)&fmul_h << ";\\n"; | ||||
|     os << "uint16_t (*fdiv_h)(uint16_t v1, uint16_t v2, uint8_t mode)=" << (uintptr_t)&fdiv_h << ";\\n"; | ||||
|     os << "uint16_t (*fsqrt_h)(uint16_t v1, uint8_t mode)=" << (uintptr_t)&fsqrt_h << ";\\n"; | ||||
|     os << "uint16_t (*fcmp_h)(uint16_t v1, uint16_t v2, uint16_t op)=" << (uintptr_t)&fcmp_h << ";\\n"; | ||||
|     os << "uint16_t (*fmadd_h)(uint16_t v1, uint16_t v2, uint16_t v3, uint16_t op, uint8_t mode)=" << (uintptr_t)&fmadd_h << ";\\n"; | ||||
|     os << "uint16_t (*fsel_h)(uint16_t v1, uint16_t v2, uint16_t op)=" << (uintptr_t)&fsel_h << ";\\n"; | ||||
|     os << "uint16_t (*fclass_h)(uint16_t v1)=" << (uintptr_t)&fclass_h << ";\\n"; | ||||
|     os << "uint16_t (*unbox_h)(uint8_t FLEN, uint64_t v)=" << (uintptr_t)&unbox_h << ";\\n"; | ||||
|  | ||||
|     os << "uint32_t (*f16toi32)(uint32_t v1, uint8_t mode)=" << (uintptr_t)&f16toi32 << ";\\n"; | ||||
|     os << "uint32_t (*f16toui32)(uint32_t v1, uint8_t mode)=" << (uintptr_t)&f16toui32 << ";\\n"; | ||||
|     os << "uint16_t (*i32tof16)(uint32_t v1, uint8_t mode)=" << (uintptr_t)&i32tof16 << ";\\n"; | ||||
|     os << "uint16_t (*ui32tof16)(uint32_t v1, uint8_t mode)=" << (uintptr_t)&ui32tof16 << ";\\n"; | ||||
|     os << "uint64_t (*f16toi64)(uint32_t v1, uint8_t mode)=" << (uintptr_t)&f16toi64 <<";\\n"; | ||||
|     os << "uint64_t (*f16toui64)(uint32_t v1, uint8_t mode)=" << (uintptr_t)&f16toui64 <<";\\n"; | ||||
|     os << "uint16_t (*i64tof16)(uint64_t v1, uint8_t mode)=" << (uintptr_t)&i64tof16 <<";\\n"; | ||||
|     os << "uint16_t (*ui64tof16)(uint64_t v1, uint8_t mode)=" << (uintptr_t)&ui64tof16 <<";\\n"; | ||||
|  | ||||
|     os << "uint32_t (*fadd_s)(uint32_t v1, uint32_t v2, uint8_t mode)=" << (uintptr_t)&fadd_s << ";\\n"; | ||||
|     os << "uint32_t (*fsub_s)(uint32_t v1, uint32_t v2, uint8_t mode)=" << (uintptr_t)&fsub_s << ";\\n"; | ||||
|     os << "uint32_t (*fmul_s)(uint32_t v1, uint32_t v2, uint8_t mode)=" << (uintptr_t)&fmul_s << ";\\n"; | ||||
|     os << "uint32_t (*fdiv_s)(uint32_t v1, uint32_t v2, uint8_t mode)=" << (uintptr_t)&fdiv_s << ";\\n"; | ||||
|     os << "uint32_t (*fsqrt_s)(uint32_t v1, uint8_t mode)=" << (uintptr_t)&fsqrt_s << ";\\n"; | ||||
|     os << "uint32_t (*fcmp_s)(uint32_t v1, uint32_t v2, uint32_t op)=" << (uintptr_t)&fcmp_s << ";\\n"; | ||||
|     os << "uint32_t (*fmadd_s)(uint32_t v1, uint32_t v2, uint32_t v3, uint32_t op, uint8_t mode)=" << (uintptr_t)&fmadd_s << ";\\n"; | ||||
|     os << "uint32_t (*fsel_s)(uint32_t v1, uint32_t v2, uint32_t op)=" << (uintptr_t)&fsel_s << ";\\n"; | ||||
|     os << "uint32_t (*fclass_s)( uint32_t v1 )=" << (uintptr_t)&fclass_s << ";\\n"; | ||||
|     os << "uint32_t (*unbox_s)(uint8_t FLEN, uint64_t v)=" << (uintptr_t)&unbox_s << ";\\n"; | ||||
|  | ||||
|     os << "uint32_t (*f32toi32)(uint32_t v1, uint8_t mode)=" << (uintptr_t)&f32toi32 << ";\\n"; | ||||
|     os << "uint32_t (*f32toui32)(uint32_t v1, uint8_t mode)=" << (uintptr_t)&f32toui32 << ";\\n"; | ||||
|     os << "uint32_t (*i32tof32)(uint32_t v1, uint8_t mode)=" << (uintptr_t)&i32tof32 << ";\\n"; | ||||
|     os << "uint32_t (*ui32tof32)(uint32_t v1, uint8_t mode)=" << (uintptr_t)&ui32tof32 << ";\\n"; | ||||
|     os << "uint64_t (*f32toi64)(uint32_t v1, uint8_t mode)=" << (uintptr_t)&f32toi64 <<";\\n"; | ||||
|     os << "uint64_t (*f32toui64)(uint32_t v1, uint8_t mode)=" << (uintptr_t)&f32toui64 <<";\\n"; | ||||
|     os << "uint32_t (*i64tof32)(uint64_t v1, uint8_t mode)=" << (uintptr_t)&i64tof32 <<";\\n"; | ||||
|     os << "uint32_t (*ui64tof32)(uint64_t v1, uint8_t mode)=" << (uintptr_t)&ui64tof32 <<";\\n"; | ||||
|     <%if(flen > 32) {%> | ||||
|  | ||||
|     os << "uint64_t (*fadd_d)(uint64_t v1, uint64_t v2, uint8_t mode)=" << (uintptr_t)&fadd_d << ";\\n"; | ||||
|     os << "uint64_t (*fsub_d)(uint64_t v1, uint64_t v2, uint8_t mode)=" << (uintptr_t)&fsub_d << ";\\n"; | ||||
|     os << "uint64_t (*fmul_d)(uint64_t v1, uint64_t v2, uint8_t mode)=" << (uintptr_t)&fmul_d << ";\\n"; | ||||
|     os << "uint64_t (*fdiv_d)(uint64_t v1, uint64_t v2, uint8_t mode)=" << (uintptr_t)&fdiv_d << ";\\n"; | ||||
|     os << "uint64_t (*fsqrt_d)(uint64_t v1, uint8_t mode)=" << (uintptr_t)&fsqrt_d << ";\\n"; | ||||
|     os << "uint64_t (*fcmp_d)(uint64_t v1, uint64_t v2, uint32_t op)=" << (uintptr_t)&fcmp_d << ";\\n"; | ||||
|     os << "uint64_t (*fmadd_d)(uint64_t v1, uint64_t v2, uint64_t v3, uint32_t op, uint8_t mode)=" << (uintptr_t)&fmadd_d << ";\\n"; | ||||
|     os << "uint64_t (*fsel_d)(uint64_t v1, uint64_t v2, uint32_t op)=" << (uintptr_t)&fsel_d << ";\\n"; | ||||
|     os << "uint64_t (*fclass_d)(uint64_t v1  )=" << (uintptr_t)&fclass_d << ";\\n"; | ||||
|     os << "uint64_t (*unbox_d)(uint8_t FLEN, uint64_t v)=" << (uintptr_t)&unbox_d << ";\\n"; | ||||
|  | ||||
|     os << "uint32_t (*f64tof32)(uint64_t v1, uint8_t mode)=" << (uintptr_t)&f64tof32 << ";\\n"; | ||||
|     os << "uint64_t (*f32tof64)(uint32_t v1, uint8_t mode)=" << (uintptr_t)&f32tof64 << ";\\n"; | ||||
|     os << "uint64_t (*f64toi64)(uint64_t v1, uint8_t mode)=" << (uintptr_t)&f64toi64 <<";\\n"; | ||||
|     os << "uint64_t (*f64toui64)(uint64_t v1, uint8_t mode)=" << (uintptr_t)&f64toui64 <<";\\n"; | ||||
|     os << "uint64_t (*i64tof64)(uint64_t v1, uint8_t mode)=" << (uintptr_t)&i64tof64 <<";\\n"; | ||||
|     os << "uint64_t (*ui64tof64)(uint64_t v1, uint8_t mode)=" << (uintptr_t)&ui64tof64 <<";\\n"; | ||||
|     os << "uint64_t (*i32tof64)(uint32_t v1, uint8_t mode)=" << (uintptr_t)&i32tof64 <<";\\n"; | ||||
|     os << "uint64_t (*ui32tof64)(uint32_t v1, uint8_t mode)=" << (uintptr_t)&ui32tof64 <<";\\n"; | ||||
|     os << "uint32_t (*f64toi32)(uint64_t v1, uint8_t mode)=" << (uintptr_t)&f64toi32 <<";\\n"; | ||||
|     os << "uint32_t (*f64toui32)(uint64_t v1, uint8_t mode)=" << (uintptr_t)&f64toui32 <<";\\n"; | ||||
|     <%} | ||||
|     }%> | ||||
|     tu.add_prologue(os.str()); | ||||
| } | ||||
|  | ||||
| } // namespace ${coreDef.name.toLowerCase()} | ||||
|  | ||||
| @@ -323,22 +388,30 @@ std::unique_ptr<vm_if> create<arch::${coreDef.name.toLowerCase()}>(arch::${coreD | ||||
| } // namesapce tcc | ||||
| } // namespace iss | ||||
|  | ||||
| #include <iss/factory.h> | ||||
| #include <iss/arch/riscv_hart_m_p.h> | ||||
| #include <iss/arch/riscv_hart_mu_p.h> | ||||
| #include <iss/factory.h> | ||||
| namespace iss { | ||||
| namespace { | ||||
| volatile std::array<bool, 2> dummy = { | ||||
|         core_factory::instance().register_creator("${coreDef.name.toLowerCase()}|m_p|tcc", [](unsigned port, void*) -> std::tuple<cpu_ptr, vm_ptr>{ | ||||
|         core_factory::instance().register_creator("${coreDef.name.toLowerCase()}|m_p|tcc", [](unsigned port, void* init_data) -> std::tuple<cpu_ptr, vm_ptr>{ | ||||
|             auto* cpu = new iss::arch::riscv_hart_m_p<iss::arch::${coreDef.name.toLowerCase()}>(); | ||||
| 		    auto vm = new tcc::${coreDef.name.toLowerCase()}::vm_impl<arch::${coreDef.name.toLowerCase()}>(*cpu, false); | ||||
| 		    if (port != 0) debugger::server<debugger::gdb_session>::run_server(vm, port); | ||||
|             if(init_data){ | ||||
|                 auto* cb = reinterpret_cast<semihosting_cb_t<arch::traits<arch::${coreDef.name.toLowerCase()}>::reg_t>*>(init_data); | ||||
|                 cpu->set_semihosting_callback(*cb); | ||||
|             } | ||||
|             return {cpu_ptr{cpu}, vm_ptr{vm}}; | ||||
|         }), | ||||
|         core_factory::instance().register_creator("${coreDef.name.toLowerCase()}|mu_p|tcc", [](unsigned port, void*) -> std::tuple<cpu_ptr, vm_ptr>{ | ||||
|         core_factory::instance().register_creator("${coreDef.name.toLowerCase()}|mu_p|tcc", [](unsigned port, void* init_data) -> std::tuple<cpu_ptr, vm_ptr>{ | ||||
|             auto* cpu = new iss::arch::riscv_hart_mu_p<iss::arch::${coreDef.name.toLowerCase()}>(); | ||||
| 		    auto vm = new tcc::${coreDef.name.toLowerCase()}::vm_impl<arch::${coreDef.name.toLowerCase()}>(*cpu, false); | ||||
| 		    if (port != 0) debugger::server<debugger::gdb_session>::run_server(vm, port); | ||||
|             if(init_data){ | ||||
|                 auto* cb = reinterpret_cast<semihosting_cb_t<arch::traits<arch::${coreDef.name.toLowerCase()}>::reg_t>*>(init_data); | ||||
|                 cpu->set_semihosting_callback(*cb); | ||||
|             } | ||||
|             return {cpu_ptr{cpu}, vm_ptr{vm}}; | ||||
|         }) | ||||
| }; | ||||
|   | ||||
							
								
								
									
										2
									
								
								softfloat/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								softfloat/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | ||||
| build/*/*.o | ||||
| build/*/*.a | ||||
| @@ -327,7 +327,7 @@ set(OTHERS | ||||
|  | ||||
| set(LIB_SOURCES ${PRIMITIVES} ${SPECIALIZE} ${OTHERS}) | ||||
|  | ||||
| add_library(softfloat ${LIB_SOURCES}) | ||||
| add_library(softfloat STATIC ${LIB_SOURCES}) | ||||
| set_property(TARGET softfloat PROPERTY C_STANDARD 99) | ||||
| target_compile_definitions(softfloat PRIVATE  | ||||
| 	SOFTFLOAT_ROUND_ODD  | ||||
| @@ -347,7 +347,7 @@ set_target_properties(softfloat PROPERTIES | ||||
|  | ||||
| install(TARGETS softfloat | ||||
|   EXPORT ${PROJECT_NAME}Targets            # for downstream dependencies | ||||
|   ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR} COMPONENT libs   # static lib | ||||
|   ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}/static COMPONENT libs   # static lib | ||||
|   LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} COMPONENT libs   # shared lib | ||||
|   FRAMEWORK DESTINATION ${CMAKE_INSTALL_LIBDIR} COMPONENT libs # for mac | ||||
|   PUBLIC_HEADER DESTINATION ${CMAKE_INSTALL_INCLUDEDIR} COMPONENT devel   # headers for mac (note the different component -> different package) | ||||
|   | ||||
| @@ -1,37 +1,37 @@ | ||||
|  | ||||
| License for Berkeley SoftFloat Release 3e | ||||
|  | ||||
| John R. Hauser | ||||
| 2018 January 20 | ||||
|  | ||||
| The following applies to the whole of SoftFloat Release 3e as well as to | ||||
| each source file individually. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017, 2018 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright | ||||
|     notice, this list of conditions, and the following disclaimer in the | ||||
|     documentation and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors | ||||
|     may be used to endorse or promote products derived from this software | ||||
|     without specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||||
| THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
|  | ||||
| License for Berkeley SoftFloat Release 3e | ||||
|  | ||||
| John R. Hauser | ||||
| 2018 January 20 | ||||
|  | ||||
| The following applies to the whole of SoftFloat Release 3e as well as to | ||||
| each source file individually. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017, 2018 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright | ||||
|     notice, this list of conditions, and the following disclaimer in the | ||||
|     documentation and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors | ||||
|     may be used to endorse or promote products derived from this software | ||||
|     without specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||||
| THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
|   | ||||
| @@ -1,49 +1,49 @@ | ||||
|  | ||||
| <HTML> | ||||
|  | ||||
| <HEAD> | ||||
| <TITLE>Berkeley SoftFloat Package Overview</TITLE> | ||||
| </HEAD> | ||||
|  | ||||
| <BODY> | ||||
|  | ||||
| <H1>Package Overview for Berkeley SoftFloat Release 3e</H1> | ||||
|  | ||||
| <P> | ||||
| John R. Hauser<BR> | ||||
| 2018 January 20<BR> | ||||
| </P> | ||||
|  | ||||
| <P> | ||||
| Berkeley SoftFloat is a software implementation of binary floating-point that | ||||
| conforms to the IEEE Standard for Floating-Point Arithmetic. | ||||
| SoftFloat is distributed in the form of C source code. | ||||
| Building the SoftFloat sources generates a library file (typically | ||||
| <CODE>softfloat.a</CODE> or <CODE>libsoftfloat.a</CODE>) containing the | ||||
| floating-point subroutines. | ||||
| </P> | ||||
|  | ||||
| <P> | ||||
| The SoftFloat package is documented in the following files in the | ||||
| <CODE>doc</CODE> subdirectory: | ||||
| <BLOCKQUOTE> | ||||
| <TABLE> | ||||
| <TR> | ||||
| <TD><A HREF="doc/SoftFloat.html"><NOBR><CODE>SoftFloat.html</CODE></NOBR></A></TD> | ||||
| <TD>Documentation for using the SoftFloat functions.</TD> | ||||
| </TR> | ||||
| <TR> | ||||
| <TD><A HREF="doc/SoftFloat-source.html"><NOBR><CODE>SoftFloat-source.html</CODE></NOBR></A></TD> | ||||
| <TD>Documentation for building SoftFloat.</TD> | ||||
| </TR> | ||||
| <TR> | ||||
| <TD><A HREF="doc/SoftFloat-history.html"><NOBR><CODE>SoftFloat-history.html</CODE></A><CODE>   </CODE></NOBR></TD> | ||||
| <TD>History of the major changes to SoftFloat.</TD> | ||||
| </TR> | ||||
| </TABLE> | ||||
| </BLOCKQUOTE> | ||||
| Other files in the package comprise the source code for SoftFloat. | ||||
| </P> | ||||
|  | ||||
| </BODY> | ||||
|  | ||||
|  | ||||
| <HTML> | ||||
|  | ||||
| <HEAD> | ||||
| <TITLE>Berkeley SoftFloat Package Overview</TITLE> | ||||
| </HEAD> | ||||
|  | ||||
| <BODY> | ||||
|  | ||||
| <H1>Package Overview for Berkeley SoftFloat Release 3e</H1> | ||||
|  | ||||
| <P> | ||||
| John R. Hauser<BR> | ||||
| 2018 January 20<BR> | ||||
| </P> | ||||
|  | ||||
| <P> | ||||
| Berkeley SoftFloat is a software implementation of binary floating-point that | ||||
| conforms to the IEEE Standard for Floating-Point Arithmetic. | ||||
| SoftFloat is distributed in the form of C source code. | ||||
| Building the SoftFloat sources generates a library file (typically | ||||
| <CODE>softfloat.a</CODE> or <CODE>libsoftfloat.a</CODE>) containing the | ||||
| floating-point subroutines. | ||||
| </P> | ||||
|  | ||||
| <P> | ||||
| The SoftFloat package is documented in the following files in the | ||||
| <CODE>doc</CODE> subdirectory: | ||||
| <BLOCKQUOTE> | ||||
| <TABLE> | ||||
| <TR> | ||||
| <TD><A HREF="doc/SoftFloat.html"><NOBR><CODE>SoftFloat.html</CODE></NOBR></A></TD> | ||||
| <TD>Documentation for using the SoftFloat functions.</TD> | ||||
| </TR> | ||||
| <TR> | ||||
| <TD><A HREF="doc/SoftFloat-source.html"><NOBR><CODE>SoftFloat-source.html</CODE></NOBR></A></TD> | ||||
| <TD>Documentation for building SoftFloat.</TD> | ||||
| </TR> | ||||
| <TR> | ||||
| <TD><A HREF="doc/SoftFloat-history.html"><NOBR><CODE>SoftFloat-history.html</CODE></A><CODE>   </CODE></NOBR></TD> | ||||
| <TD>History of the major changes to SoftFloat.</TD> | ||||
| </TR> | ||||
| </TABLE> | ||||
| </BLOCKQUOTE> | ||||
| Other files in the package comprise the source code for SoftFloat. | ||||
| </P> | ||||
|  | ||||
| </BODY> | ||||
|  | ||||
|   | ||||
							
								
								
									
										24
									
								
								softfloat/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								softfloat/README.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,24 @@ | ||||
|  | ||||
| Package Overview for Berkeley SoftFloat Release 3e | ||||
| ================================================== | ||||
|  | ||||
| John R. Hauser<br> | ||||
| 2018 January 20 | ||||
|  | ||||
|  | ||||
| Berkeley SoftFloat is a software implementation of binary floating-point | ||||
| that conforms to the IEEE Standard for Floating-Point Arithmetic.  SoftFloat | ||||
| is distributed in the form of C source code.  Building the SoftFloat sources | ||||
| generates a library file (typically `softfloat.a` or `libsoftfloat.a`) | ||||
| containing the floating-point subroutines. | ||||
|  | ||||
|  | ||||
| The SoftFloat package is documented in the following files in the `doc` | ||||
| subdirectory: | ||||
|  | ||||
| * [SoftFloat.html](http://www.jhauser.us/arithmetic/SoftFloat-3/doc/SoftFloat.html) Documentation for using the SoftFloat functions. | ||||
| * [SoftFloat-source.html](http://www.jhauser.us/arithmetic/SoftFloat-3/doc/SoftFloat-source.html) Documentation for building SoftFloat. | ||||
| * [SoftFloat-history.html](http://www.jhauser.us/arithmetic/SoftFloat-3/doc/SoftFloat-history.html) History of the major changes to SoftFloat. | ||||
|  | ||||
| Other files in the package comprise the source code for SoftFloat. | ||||
|  | ||||
| @@ -1,21 +1,21 @@ | ||||
|  | ||||
| Package Overview for Berkeley SoftFloat Release 3e | ||||
|  | ||||
| John R. Hauser | ||||
| 2018 January 20 | ||||
|  | ||||
| Berkeley SoftFloat is a software implementation of binary floating-point | ||||
| that conforms to the IEEE Standard for Floating-Point Arithmetic.  SoftFloat | ||||
| is distributed in the form of C source code.  Building the SoftFloat sources | ||||
| generates a library file (typically "softfloat.a" or "libsoftfloat.a") | ||||
| containing the floating-point subroutines. | ||||
|  | ||||
| The SoftFloat package is documented in the following files in the "doc" | ||||
| subdirectory: | ||||
|  | ||||
|     SoftFloat.html          Documentation for using the SoftFloat functions. | ||||
|     SoftFloat-source.html   Documentation for building SoftFloat. | ||||
|     SoftFloat-history.html  History of the major changes to SoftFloat. | ||||
|  | ||||
| Other files in the package comprise the source code for SoftFloat. | ||||
|  | ||||
|  | ||||
| Package Overview for Berkeley SoftFloat Release 3e | ||||
|  | ||||
| John R. Hauser | ||||
| 2018 January 20 | ||||
|  | ||||
| Berkeley SoftFloat is a software implementation of binary floating-point | ||||
| that conforms to the IEEE Standard for Floating-Point Arithmetic.  SoftFloat | ||||
| is distributed in the form of C source code.  Building the SoftFloat sources | ||||
| generates a library file (typically "softfloat.a" or "libsoftfloat.a") | ||||
| containing the floating-point subroutines. | ||||
|  | ||||
| The SoftFloat package is documented in the following files in the "doc" | ||||
| subdirectory: | ||||
|  | ||||
|     SoftFloat.html          Documentation for using the SoftFloat functions. | ||||
|     SoftFloat-source.html   Documentation for building SoftFloat. | ||||
|     SoftFloat-history.html  History of the major changes to SoftFloat. | ||||
|  | ||||
| Other files in the package comprise the source code for SoftFloat. | ||||
|  | ||||
|   | ||||
| @@ -1,325 +1,325 @@ | ||||
|  | ||||
| #============================================================================= | ||||
| # | ||||
| # This Makefile is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| # Package, Release 3e, by John R. Hauser. | ||||
| # | ||||
| # Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| # University of California.  All rights reserved. | ||||
| # | ||||
| # Redistribution and use in source and binary forms, with or without | ||||
| # modification, are permitted provided that the following conditions are met: | ||||
| # | ||||
| #  1. Redistributions of source code must retain the above copyright notice, | ||||
| #     this list of conditions, and the following disclaimer. | ||||
| # | ||||
| #  2. Redistributions in binary form must reproduce the above copyright | ||||
| #     notice, this list of conditions, and the following disclaimer in the | ||||
| #     documentation and/or other materials provided with the distribution. | ||||
| # | ||||
| #  3. Neither the name of the University nor the names of its contributors | ||||
| #     may be used to endorse or promote products derived from this software | ||||
| #     without specific prior written permission. | ||||
| # | ||||
| # THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| # DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||||
| # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| # | ||||
| #============================================================================= | ||||
|  | ||||
| SOURCE_DIR ?= ../../source | ||||
| SPECIALIZE_TYPE ?= 8086 | ||||
|  | ||||
| SOFTFLOAT_OPTS ?= \ | ||||
|   -DSOFTFLOAT_ROUND_ODD -DINLINE_LEVEL=5 -DSOFTFLOAT_FAST_DIV32TO16 \ | ||||
|   -DSOFTFLOAT_FAST_DIV64TO32 | ||||
|  | ||||
| DELETE = rm -f | ||||
| C_INCLUDES = -I. -I$(SOURCE_DIR)/$(SPECIALIZE_TYPE) -I$(SOURCE_DIR)/include | ||||
| COMPILE_C = \ | ||||
|   gcc -c -Werror-implicit-function-declaration $(SOFTFLOAT_OPTS) \ | ||||
|     $(C_INCLUDES) -O2 -o $@ | ||||
| MAKELIB = ar crs $@ | ||||
|  | ||||
| OBJ = .o | ||||
| LIB = .a | ||||
|  | ||||
| OTHER_HEADERS = | ||||
|  | ||||
| .PHONY: all | ||||
| all: softfloat$(LIB) | ||||
|  | ||||
| OBJS_PRIMITIVES = \ | ||||
|   s_compare96M$(OBJ) \ | ||||
|   s_compare128M$(OBJ) \ | ||||
|   s_shortShiftLeft64To96M$(OBJ) \ | ||||
|   s_shortShiftLeftM$(OBJ) \ | ||||
|   s_shiftLeftM$(OBJ) \ | ||||
|   s_shortShiftRightM$(OBJ) \ | ||||
|   s_shortShiftRightJam64$(OBJ) \ | ||||
|   s_shortShiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightJam32$(OBJ) \ | ||||
|   s_shiftRightJam64$(OBJ) \ | ||||
|   s_shiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightM$(OBJ) \ | ||||
|   s_countLeadingZeros8$(OBJ) \ | ||||
|   s_countLeadingZeros16$(OBJ) \ | ||||
|   s_countLeadingZeros32$(OBJ) \ | ||||
|   s_countLeadingZeros64$(OBJ) \ | ||||
|   s_addM$(OBJ) \ | ||||
|   s_addCarryM$(OBJ) \ | ||||
|   s_addComplCarryM$(OBJ) \ | ||||
|   s_negXM$(OBJ) \ | ||||
|   s_sub1XM$(OBJ) \ | ||||
|   s_subM$(OBJ) \ | ||||
|   s_mul64To128M$(OBJ) \ | ||||
|   s_mul128MTo256M$(OBJ) \ | ||||
|   s_approxRecip_1Ks$(OBJ) \ | ||||
|   s_approxRecip32_1$(OBJ) \ | ||||
|   s_approxRecipSqrt_1Ks$(OBJ) \ | ||||
|   s_approxRecipSqrt32_1$(OBJ) \ | ||||
|   s_remStepMBy32$(OBJ) \ | ||||
|  | ||||
| OBJS_SPECIALIZE = \ | ||||
|   softfloat_raiseFlags$(OBJ) \ | ||||
|   s_f16UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF16UI$(OBJ) \ | ||||
|   s_propagateNaNF16UI$(OBJ) \ | ||||
|   s_f32UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF32UI$(OBJ) \ | ||||
|   s_propagateNaNF32UI$(OBJ) \ | ||||
|   s_f64UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF64UI$(OBJ) \ | ||||
|   s_propagateNaNF64UI$(OBJ) \ | ||||
|   extF80M_isSignalingNaN$(OBJ) \ | ||||
|   s_extF80MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToExtF80M$(OBJ) \ | ||||
|   s_propagateNaNExtF80M$(OBJ) \ | ||||
|   f128M_isSignalingNaN$(OBJ) \ | ||||
|   s_f128MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF128M$(OBJ) \ | ||||
|   s_propagateNaNF128M$(OBJ) \ | ||||
|  | ||||
| OBJS_OTHERS = \ | ||||
|   s_roundToUI32$(OBJ) \ | ||||
|   s_roundMToUI64$(OBJ) \ | ||||
|   s_roundToI32$(OBJ) \ | ||||
|   s_roundMToI64$(OBJ) \ | ||||
|   s_normSubnormalF16Sig$(OBJ) \ | ||||
|   s_roundPackToF16$(OBJ) \ | ||||
|   s_normRoundPackToF16$(OBJ) \ | ||||
|   s_addMagsF16$(OBJ) \ | ||||
|   s_subMagsF16$(OBJ) \ | ||||
|   s_mulAddF16$(OBJ) \ | ||||
|   s_normSubnormalF32Sig$(OBJ) \ | ||||
|   s_roundPackToF32$(OBJ) \ | ||||
|   s_normRoundPackToF32$(OBJ) \ | ||||
|   s_addMagsF32$(OBJ) \ | ||||
|   s_subMagsF32$(OBJ) \ | ||||
|   s_mulAddF32$(OBJ) \ | ||||
|   s_normSubnormalF64Sig$(OBJ) \ | ||||
|   s_roundPackToF64$(OBJ) \ | ||||
|   s_normRoundPackToF64$(OBJ) \ | ||||
|   s_addMagsF64$(OBJ) \ | ||||
|   s_subMagsF64$(OBJ) \ | ||||
|   s_mulAddF64$(OBJ) \ | ||||
|   s_tryPropagateNaNExtF80M$(OBJ) \ | ||||
|   s_invalidExtF80M$(OBJ) \ | ||||
|   s_normExtF80SigM$(OBJ) \ | ||||
|   s_roundPackMToExtF80M$(OBJ) \ | ||||
|   s_normRoundPackMToExtF80M$(OBJ) \ | ||||
|   s_addExtF80M$(OBJ) \ | ||||
|   s_compareNonnormExtF80M$(OBJ) \ | ||||
|   s_isNaNF128M$(OBJ) \ | ||||
|   s_tryPropagateNaNF128M$(OBJ) \ | ||||
|   s_invalidF128M$(OBJ) \ | ||||
|   s_shiftNormSigF128M$(OBJ) \ | ||||
|   s_roundPackMToF128M$(OBJ) \ | ||||
|   s_normRoundPackMToF128M$(OBJ) \ | ||||
|   s_addF128M$(OBJ) \ | ||||
|   s_mulAddF128M$(OBJ) \ | ||||
|   softfloat_state$(OBJ) \ | ||||
|   ui32_to_f16$(OBJ) \ | ||||
|   ui32_to_f32$(OBJ) \ | ||||
|   ui32_to_f64$(OBJ) \ | ||||
|   ui32_to_extF80M$(OBJ) \ | ||||
|   ui32_to_f128M$(OBJ) \ | ||||
|   ui64_to_f16$(OBJ) \ | ||||
|   ui64_to_f32$(OBJ) \ | ||||
|   ui64_to_f64$(OBJ) \ | ||||
|   ui64_to_extF80M$(OBJ) \ | ||||
|   ui64_to_f128M$(OBJ) \ | ||||
|   i32_to_f16$(OBJ) \ | ||||
|   i32_to_f32$(OBJ) \ | ||||
|   i32_to_f64$(OBJ) \ | ||||
|   i32_to_extF80M$(OBJ) \ | ||||
|   i32_to_f128M$(OBJ) \ | ||||
|   i64_to_f16$(OBJ) \ | ||||
|   i64_to_f32$(OBJ) \ | ||||
|   i64_to_f64$(OBJ) \ | ||||
|   i64_to_extF80M$(OBJ) \ | ||||
|   i64_to_f128M$(OBJ) \ | ||||
|   f16_to_ui32$(OBJ) \ | ||||
|   f16_to_ui64$(OBJ) \ | ||||
|   f16_to_i32$(OBJ) \ | ||||
|   f16_to_i64$(OBJ) \ | ||||
|   f16_to_ui32_r_minMag$(OBJ) \ | ||||
|   f16_to_ui64_r_minMag$(OBJ) \ | ||||
|   f16_to_i32_r_minMag$(OBJ) \ | ||||
|   f16_to_i64_r_minMag$(OBJ) \ | ||||
|   f16_to_f32$(OBJ) \ | ||||
|   f16_to_f64$(OBJ) \ | ||||
|   f16_to_extF80M$(OBJ) \ | ||||
|   f16_to_f128M$(OBJ) \ | ||||
|   f16_roundToInt$(OBJ) \ | ||||
|   f16_add$(OBJ) \ | ||||
|   f16_sub$(OBJ) \ | ||||
|   f16_mul$(OBJ) \ | ||||
|   f16_mulAdd$(OBJ) \ | ||||
|   f16_div$(OBJ) \ | ||||
|   f16_rem$(OBJ) \ | ||||
|   f16_sqrt$(OBJ) \ | ||||
|   f16_eq$(OBJ) \ | ||||
|   f16_le$(OBJ) \ | ||||
|   f16_lt$(OBJ) \ | ||||
|   f16_eq_signaling$(OBJ) \ | ||||
|   f16_le_quiet$(OBJ) \ | ||||
|   f16_lt_quiet$(OBJ) \ | ||||
|   f16_isSignalingNaN$(OBJ) \ | ||||
|   f32_to_ui32$(OBJ) \ | ||||
|   f32_to_ui64$(OBJ) \ | ||||
|   f32_to_i32$(OBJ) \ | ||||
|   f32_to_i64$(OBJ) \ | ||||
|   f32_to_ui32_r_minMag$(OBJ) \ | ||||
|   f32_to_ui64_r_minMag$(OBJ) \ | ||||
|   f32_to_i32_r_minMag$(OBJ) \ | ||||
|   f32_to_i64_r_minMag$(OBJ) \ | ||||
|   f32_to_f16$(OBJ) \ | ||||
|   f32_to_f64$(OBJ) \ | ||||
|   f32_to_extF80M$(OBJ) \ | ||||
|   f32_to_f128M$(OBJ) \ | ||||
|   f32_roundToInt$(OBJ) \ | ||||
|   f32_add$(OBJ) \ | ||||
|   f32_sub$(OBJ) \ | ||||
|   f32_mul$(OBJ) \ | ||||
|   f32_mulAdd$(OBJ) \ | ||||
|   f32_div$(OBJ) \ | ||||
|   f32_rem$(OBJ) \ | ||||
|   f32_sqrt$(OBJ) \ | ||||
|   f32_eq$(OBJ) \ | ||||
|   f32_le$(OBJ) \ | ||||
|   f32_lt$(OBJ) \ | ||||
|   f32_eq_signaling$(OBJ) \ | ||||
|   f32_le_quiet$(OBJ) \ | ||||
|   f32_lt_quiet$(OBJ) \ | ||||
|   f32_isSignalingNaN$(OBJ) \ | ||||
|   f64_to_ui32$(OBJ) \ | ||||
|   f64_to_ui64$(OBJ) \ | ||||
|   f64_to_i32$(OBJ) \ | ||||
|   f64_to_i64$(OBJ) \ | ||||
|   f64_to_ui32_r_minMag$(OBJ) \ | ||||
|   f64_to_ui64_r_minMag$(OBJ) \ | ||||
|   f64_to_i32_r_minMag$(OBJ) \ | ||||
|   f64_to_i64_r_minMag$(OBJ) \ | ||||
|   f64_to_f16$(OBJ) \ | ||||
|   f64_to_f32$(OBJ) \ | ||||
|   f64_to_extF80M$(OBJ) \ | ||||
|   f64_to_f128M$(OBJ) \ | ||||
|   f64_roundToInt$(OBJ) \ | ||||
|   f64_add$(OBJ) \ | ||||
|   f64_sub$(OBJ) \ | ||||
|   f64_mul$(OBJ) \ | ||||
|   f64_mulAdd$(OBJ) \ | ||||
|   f64_div$(OBJ) \ | ||||
|   f64_rem$(OBJ) \ | ||||
|   f64_sqrt$(OBJ) \ | ||||
|   f64_eq$(OBJ) \ | ||||
|   f64_le$(OBJ) \ | ||||
|   f64_lt$(OBJ) \ | ||||
|   f64_eq_signaling$(OBJ) \ | ||||
|   f64_le_quiet$(OBJ) \ | ||||
|   f64_lt_quiet$(OBJ) \ | ||||
|   f64_isSignalingNaN$(OBJ) \ | ||||
|   extF80M_to_ui32$(OBJ) \ | ||||
|   extF80M_to_ui64$(OBJ) \ | ||||
|   extF80M_to_i32$(OBJ) \ | ||||
|   extF80M_to_i64$(OBJ) \ | ||||
|   extF80M_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_f16$(OBJ) \ | ||||
|   extF80M_to_f32$(OBJ) \ | ||||
|   extF80M_to_f64$(OBJ) \ | ||||
|   extF80M_to_f128M$(OBJ) \ | ||||
|   extF80M_roundToInt$(OBJ) \ | ||||
|   extF80M_add$(OBJ) \ | ||||
|   extF80M_sub$(OBJ) \ | ||||
|   extF80M_mul$(OBJ) \ | ||||
|   extF80M_div$(OBJ) \ | ||||
|   extF80M_rem$(OBJ) \ | ||||
|   extF80M_sqrt$(OBJ) \ | ||||
|   extF80M_eq$(OBJ) \ | ||||
|   extF80M_le$(OBJ) \ | ||||
|   extF80M_lt$(OBJ) \ | ||||
|   extF80M_eq_signaling$(OBJ) \ | ||||
|   extF80M_le_quiet$(OBJ) \ | ||||
|   extF80M_lt_quiet$(OBJ) \ | ||||
|   f128M_to_ui32$(OBJ) \ | ||||
|   f128M_to_ui64$(OBJ) \ | ||||
|   f128M_to_i32$(OBJ) \ | ||||
|   f128M_to_i64$(OBJ) \ | ||||
|   f128M_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128M_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128M_to_i32_r_minMag$(OBJ) \ | ||||
|   f128M_to_i64_r_minMag$(OBJ) \ | ||||
|   f128M_to_f16$(OBJ) \ | ||||
|   f128M_to_f32$(OBJ) \ | ||||
|   f128M_to_f64$(OBJ) \ | ||||
|   f128M_to_extF80M$(OBJ) \ | ||||
|   f128M_roundToInt$(OBJ) \ | ||||
|   f128M_add$(OBJ) \ | ||||
|   f128M_sub$(OBJ) \ | ||||
|   f128M_mul$(OBJ) \ | ||||
|   f128M_mulAdd$(OBJ) \ | ||||
|   f128M_div$(OBJ) \ | ||||
|   f128M_rem$(OBJ) \ | ||||
|   f128M_sqrt$(OBJ) \ | ||||
|   f128M_eq$(OBJ) \ | ||||
|   f128M_le$(OBJ) \ | ||||
|   f128M_lt$(OBJ) \ | ||||
|   f128M_eq_signaling$(OBJ) \ | ||||
|   f128M_le_quiet$(OBJ) \ | ||||
|   f128M_lt_quiet$(OBJ) \ | ||||
|  | ||||
| OBJS_ALL = $(OBJS_PRIMITIVES) $(OBJS_SPECIALIZE) $(OBJS_OTHERS) | ||||
|  | ||||
| $(OBJS_ALL): \ | ||||
|   $(OTHER_HEADERS) platform.h $(SOURCE_DIR)/include/primitiveTypes.h \ | ||||
|   $(SOURCE_DIR)/include/primitives.h | ||||
| $(OBJS_SPECIALIZE) $(OBJS_OTHERS): \ | ||||
|   $(SOURCE_DIR)/include/softfloat_types.h $(SOURCE_DIR)/include/internals.h \ | ||||
|   $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/specialize.h \ | ||||
|   $(SOURCE_DIR)/include/softfloat.h | ||||
|  | ||||
| $(OBJS_PRIMITIVES) $(OBJS_OTHERS): %$(OBJ): $(SOURCE_DIR)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$*.c | ||||
|  | ||||
| $(OBJS_SPECIALIZE): %$(OBJ): $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/$*.c | ||||
|  | ||||
| softfloat$(LIB): $(OBJS_ALL) | ||||
| 	$(DELETE) $@ | ||||
| 	$(MAKELIB) $^ | ||||
|  | ||||
| .PHONY: clean | ||||
| clean: | ||||
| 	$(DELETE) $(OBJS_ALL) softfloat$(LIB) | ||||
|  | ||||
|  | ||||
| #============================================================================= | ||||
| # | ||||
| # This Makefile is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| # Package, Release 3e, by John R. Hauser. | ||||
| # | ||||
| # Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| # University of California.  All rights reserved. | ||||
| # | ||||
| # Redistribution and use in source and binary forms, with or without | ||||
| # modification, are permitted provided that the following conditions are met: | ||||
| # | ||||
| #  1. Redistributions of source code must retain the above copyright notice, | ||||
| #     this list of conditions, and the following disclaimer. | ||||
| # | ||||
| #  2. Redistributions in binary form must reproduce the above copyright | ||||
| #     notice, this list of conditions, and the following disclaimer in the | ||||
| #     documentation and/or other materials provided with the distribution. | ||||
| # | ||||
| #  3. Neither the name of the University nor the names of its contributors | ||||
| #     may be used to endorse or promote products derived from this software | ||||
| #     without specific prior written permission. | ||||
| # | ||||
| # THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| # DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||||
| # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| # | ||||
| #============================================================================= | ||||
|  | ||||
| SOURCE_DIR ?= ../../source | ||||
| SPECIALIZE_TYPE ?= 8086 | ||||
|  | ||||
| SOFTFLOAT_OPTS ?= \ | ||||
|   -DSOFTFLOAT_ROUND_ODD -DINLINE_LEVEL=5 -DSOFTFLOAT_FAST_DIV32TO16 \ | ||||
|   -DSOFTFLOAT_FAST_DIV64TO32 | ||||
|  | ||||
| DELETE = rm -f | ||||
| C_INCLUDES = -I. -I$(SOURCE_DIR)/$(SPECIALIZE_TYPE) -I$(SOURCE_DIR)/include | ||||
| COMPILE_C = \ | ||||
|   gcc -c -Werror-implicit-function-declaration $(SOFTFLOAT_OPTS) \ | ||||
|     $(C_INCLUDES) -O2 -o $@ | ||||
| MAKELIB = ar crs $@ | ||||
|  | ||||
| OBJ = .o | ||||
| LIB = .a | ||||
|  | ||||
| OTHER_HEADERS = | ||||
|  | ||||
| .PHONY: all | ||||
| all: softfloat$(LIB) | ||||
|  | ||||
| OBJS_PRIMITIVES = \ | ||||
|   s_compare96M$(OBJ) \ | ||||
|   s_compare128M$(OBJ) \ | ||||
|   s_shortShiftLeft64To96M$(OBJ) \ | ||||
|   s_shortShiftLeftM$(OBJ) \ | ||||
|   s_shiftLeftM$(OBJ) \ | ||||
|   s_shortShiftRightM$(OBJ) \ | ||||
|   s_shortShiftRightJam64$(OBJ) \ | ||||
|   s_shortShiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightJam32$(OBJ) \ | ||||
|   s_shiftRightJam64$(OBJ) \ | ||||
|   s_shiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightM$(OBJ) \ | ||||
|   s_countLeadingZeros8$(OBJ) \ | ||||
|   s_countLeadingZeros16$(OBJ) \ | ||||
|   s_countLeadingZeros32$(OBJ) \ | ||||
|   s_countLeadingZeros64$(OBJ) \ | ||||
|   s_addM$(OBJ) \ | ||||
|   s_addCarryM$(OBJ) \ | ||||
|   s_addComplCarryM$(OBJ) \ | ||||
|   s_negXM$(OBJ) \ | ||||
|   s_sub1XM$(OBJ) \ | ||||
|   s_subM$(OBJ) \ | ||||
|   s_mul64To128M$(OBJ) \ | ||||
|   s_mul128MTo256M$(OBJ) \ | ||||
|   s_approxRecip_1Ks$(OBJ) \ | ||||
|   s_approxRecip32_1$(OBJ) \ | ||||
|   s_approxRecipSqrt_1Ks$(OBJ) \ | ||||
|   s_approxRecipSqrt32_1$(OBJ) \ | ||||
|   s_remStepMBy32$(OBJ) \ | ||||
|  | ||||
| OBJS_SPECIALIZE = \ | ||||
|   softfloat_raiseFlags$(OBJ) \ | ||||
|   s_f16UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF16UI$(OBJ) \ | ||||
|   s_propagateNaNF16UI$(OBJ) \ | ||||
|   s_f32UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF32UI$(OBJ) \ | ||||
|   s_propagateNaNF32UI$(OBJ) \ | ||||
|   s_f64UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF64UI$(OBJ) \ | ||||
|   s_propagateNaNF64UI$(OBJ) \ | ||||
|   extF80M_isSignalingNaN$(OBJ) \ | ||||
|   s_extF80MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToExtF80M$(OBJ) \ | ||||
|   s_propagateNaNExtF80M$(OBJ) \ | ||||
|   f128M_isSignalingNaN$(OBJ) \ | ||||
|   s_f128MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF128M$(OBJ) \ | ||||
|   s_propagateNaNF128M$(OBJ) \ | ||||
|  | ||||
| OBJS_OTHERS = \ | ||||
|   s_roundToUI32$(OBJ) \ | ||||
|   s_roundMToUI64$(OBJ) \ | ||||
|   s_roundToI32$(OBJ) \ | ||||
|   s_roundMToI64$(OBJ) \ | ||||
|   s_normSubnormalF16Sig$(OBJ) \ | ||||
|   s_roundPackToF16$(OBJ) \ | ||||
|   s_normRoundPackToF16$(OBJ) \ | ||||
|   s_addMagsF16$(OBJ) \ | ||||
|   s_subMagsF16$(OBJ) \ | ||||
|   s_mulAddF16$(OBJ) \ | ||||
|   s_normSubnormalF32Sig$(OBJ) \ | ||||
|   s_roundPackToF32$(OBJ) \ | ||||
|   s_normRoundPackToF32$(OBJ) \ | ||||
|   s_addMagsF32$(OBJ) \ | ||||
|   s_subMagsF32$(OBJ) \ | ||||
|   s_mulAddF32$(OBJ) \ | ||||
|   s_normSubnormalF64Sig$(OBJ) \ | ||||
|   s_roundPackToF64$(OBJ) \ | ||||
|   s_normRoundPackToF64$(OBJ) \ | ||||
|   s_addMagsF64$(OBJ) \ | ||||
|   s_subMagsF64$(OBJ) \ | ||||
|   s_mulAddF64$(OBJ) \ | ||||
|   s_tryPropagateNaNExtF80M$(OBJ) \ | ||||
|   s_invalidExtF80M$(OBJ) \ | ||||
|   s_normExtF80SigM$(OBJ) \ | ||||
|   s_roundPackMToExtF80M$(OBJ) \ | ||||
|   s_normRoundPackMToExtF80M$(OBJ) \ | ||||
|   s_addExtF80M$(OBJ) \ | ||||
|   s_compareNonnormExtF80M$(OBJ) \ | ||||
|   s_isNaNF128M$(OBJ) \ | ||||
|   s_tryPropagateNaNF128M$(OBJ) \ | ||||
|   s_invalidF128M$(OBJ) \ | ||||
|   s_shiftNormSigF128M$(OBJ) \ | ||||
|   s_roundPackMToF128M$(OBJ) \ | ||||
|   s_normRoundPackMToF128M$(OBJ) \ | ||||
|   s_addF128M$(OBJ) \ | ||||
|   s_mulAddF128M$(OBJ) \ | ||||
|   softfloat_state$(OBJ) \ | ||||
|   ui32_to_f16$(OBJ) \ | ||||
|   ui32_to_f32$(OBJ) \ | ||||
|   ui32_to_f64$(OBJ) \ | ||||
|   ui32_to_extF80M$(OBJ) \ | ||||
|   ui32_to_f128M$(OBJ) \ | ||||
|   ui64_to_f16$(OBJ) \ | ||||
|   ui64_to_f32$(OBJ) \ | ||||
|   ui64_to_f64$(OBJ) \ | ||||
|   ui64_to_extF80M$(OBJ) \ | ||||
|   ui64_to_f128M$(OBJ) \ | ||||
|   i32_to_f16$(OBJ) \ | ||||
|   i32_to_f32$(OBJ) \ | ||||
|   i32_to_f64$(OBJ) \ | ||||
|   i32_to_extF80M$(OBJ) \ | ||||
|   i32_to_f128M$(OBJ) \ | ||||
|   i64_to_f16$(OBJ) \ | ||||
|   i64_to_f32$(OBJ) \ | ||||
|   i64_to_f64$(OBJ) \ | ||||
|   i64_to_extF80M$(OBJ) \ | ||||
|   i64_to_f128M$(OBJ) \ | ||||
|   f16_to_ui32$(OBJ) \ | ||||
|   f16_to_ui64$(OBJ) \ | ||||
|   f16_to_i32$(OBJ) \ | ||||
|   f16_to_i64$(OBJ) \ | ||||
|   f16_to_ui32_r_minMag$(OBJ) \ | ||||
|   f16_to_ui64_r_minMag$(OBJ) \ | ||||
|   f16_to_i32_r_minMag$(OBJ) \ | ||||
|   f16_to_i64_r_minMag$(OBJ) \ | ||||
|   f16_to_f32$(OBJ) \ | ||||
|   f16_to_f64$(OBJ) \ | ||||
|   f16_to_extF80M$(OBJ) \ | ||||
|   f16_to_f128M$(OBJ) \ | ||||
|   f16_roundToInt$(OBJ) \ | ||||
|   f16_add$(OBJ) \ | ||||
|   f16_sub$(OBJ) \ | ||||
|   f16_mul$(OBJ) \ | ||||
|   f16_mulAdd$(OBJ) \ | ||||
|   f16_div$(OBJ) \ | ||||
|   f16_rem$(OBJ) \ | ||||
|   f16_sqrt$(OBJ) \ | ||||
|   f16_eq$(OBJ) \ | ||||
|   f16_le$(OBJ) \ | ||||
|   f16_lt$(OBJ) \ | ||||
|   f16_eq_signaling$(OBJ) \ | ||||
|   f16_le_quiet$(OBJ) \ | ||||
|   f16_lt_quiet$(OBJ) \ | ||||
|   f16_isSignalingNaN$(OBJ) \ | ||||
|   f32_to_ui32$(OBJ) \ | ||||
|   f32_to_ui64$(OBJ) \ | ||||
|   f32_to_i32$(OBJ) \ | ||||
|   f32_to_i64$(OBJ) \ | ||||
|   f32_to_ui32_r_minMag$(OBJ) \ | ||||
|   f32_to_ui64_r_minMag$(OBJ) \ | ||||
|   f32_to_i32_r_minMag$(OBJ) \ | ||||
|   f32_to_i64_r_minMag$(OBJ) \ | ||||
|   f32_to_f16$(OBJ) \ | ||||
|   f32_to_f64$(OBJ) \ | ||||
|   f32_to_extF80M$(OBJ) \ | ||||
|   f32_to_f128M$(OBJ) \ | ||||
|   f32_roundToInt$(OBJ) \ | ||||
|   f32_add$(OBJ) \ | ||||
|   f32_sub$(OBJ) \ | ||||
|   f32_mul$(OBJ) \ | ||||
|   f32_mulAdd$(OBJ) \ | ||||
|   f32_div$(OBJ) \ | ||||
|   f32_rem$(OBJ) \ | ||||
|   f32_sqrt$(OBJ) \ | ||||
|   f32_eq$(OBJ) \ | ||||
|   f32_le$(OBJ) \ | ||||
|   f32_lt$(OBJ) \ | ||||
|   f32_eq_signaling$(OBJ) \ | ||||
|   f32_le_quiet$(OBJ) \ | ||||
|   f32_lt_quiet$(OBJ) \ | ||||
|   f32_isSignalingNaN$(OBJ) \ | ||||
|   f64_to_ui32$(OBJ) \ | ||||
|   f64_to_ui64$(OBJ) \ | ||||
|   f64_to_i32$(OBJ) \ | ||||
|   f64_to_i64$(OBJ) \ | ||||
|   f64_to_ui32_r_minMag$(OBJ) \ | ||||
|   f64_to_ui64_r_minMag$(OBJ) \ | ||||
|   f64_to_i32_r_minMag$(OBJ) \ | ||||
|   f64_to_i64_r_minMag$(OBJ) \ | ||||
|   f64_to_f16$(OBJ) \ | ||||
|   f64_to_f32$(OBJ) \ | ||||
|   f64_to_extF80M$(OBJ) \ | ||||
|   f64_to_f128M$(OBJ) \ | ||||
|   f64_roundToInt$(OBJ) \ | ||||
|   f64_add$(OBJ) \ | ||||
|   f64_sub$(OBJ) \ | ||||
|   f64_mul$(OBJ) \ | ||||
|   f64_mulAdd$(OBJ) \ | ||||
|   f64_div$(OBJ) \ | ||||
|   f64_rem$(OBJ) \ | ||||
|   f64_sqrt$(OBJ) \ | ||||
|   f64_eq$(OBJ) \ | ||||
|   f64_le$(OBJ) \ | ||||
|   f64_lt$(OBJ) \ | ||||
|   f64_eq_signaling$(OBJ) \ | ||||
|   f64_le_quiet$(OBJ) \ | ||||
|   f64_lt_quiet$(OBJ) \ | ||||
|   f64_isSignalingNaN$(OBJ) \ | ||||
|   extF80M_to_ui32$(OBJ) \ | ||||
|   extF80M_to_ui64$(OBJ) \ | ||||
|   extF80M_to_i32$(OBJ) \ | ||||
|   extF80M_to_i64$(OBJ) \ | ||||
|   extF80M_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_f16$(OBJ) \ | ||||
|   extF80M_to_f32$(OBJ) \ | ||||
|   extF80M_to_f64$(OBJ) \ | ||||
|   extF80M_to_f128M$(OBJ) \ | ||||
|   extF80M_roundToInt$(OBJ) \ | ||||
|   extF80M_add$(OBJ) \ | ||||
|   extF80M_sub$(OBJ) \ | ||||
|   extF80M_mul$(OBJ) \ | ||||
|   extF80M_div$(OBJ) \ | ||||
|   extF80M_rem$(OBJ) \ | ||||
|   extF80M_sqrt$(OBJ) \ | ||||
|   extF80M_eq$(OBJ) \ | ||||
|   extF80M_le$(OBJ) \ | ||||
|   extF80M_lt$(OBJ) \ | ||||
|   extF80M_eq_signaling$(OBJ) \ | ||||
|   extF80M_le_quiet$(OBJ) \ | ||||
|   extF80M_lt_quiet$(OBJ) \ | ||||
|   f128M_to_ui32$(OBJ) \ | ||||
|   f128M_to_ui64$(OBJ) \ | ||||
|   f128M_to_i32$(OBJ) \ | ||||
|   f128M_to_i64$(OBJ) \ | ||||
|   f128M_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128M_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128M_to_i32_r_minMag$(OBJ) \ | ||||
|   f128M_to_i64_r_minMag$(OBJ) \ | ||||
|   f128M_to_f16$(OBJ) \ | ||||
|   f128M_to_f32$(OBJ) \ | ||||
|   f128M_to_f64$(OBJ) \ | ||||
|   f128M_to_extF80M$(OBJ) \ | ||||
|   f128M_roundToInt$(OBJ) \ | ||||
|   f128M_add$(OBJ) \ | ||||
|   f128M_sub$(OBJ) \ | ||||
|   f128M_mul$(OBJ) \ | ||||
|   f128M_mulAdd$(OBJ) \ | ||||
|   f128M_div$(OBJ) \ | ||||
|   f128M_rem$(OBJ) \ | ||||
|   f128M_sqrt$(OBJ) \ | ||||
|   f128M_eq$(OBJ) \ | ||||
|   f128M_le$(OBJ) \ | ||||
|   f128M_lt$(OBJ) \ | ||||
|   f128M_eq_signaling$(OBJ) \ | ||||
|   f128M_le_quiet$(OBJ) \ | ||||
|   f128M_lt_quiet$(OBJ) \ | ||||
|  | ||||
| OBJS_ALL = $(OBJS_PRIMITIVES) $(OBJS_SPECIALIZE) $(OBJS_OTHERS) | ||||
|  | ||||
| $(OBJS_ALL): \ | ||||
|   $(OTHER_HEADERS) platform.h $(SOURCE_DIR)/include/primitiveTypes.h \ | ||||
|   $(SOURCE_DIR)/include/primitives.h | ||||
| $(OBJS_SPECIALIZE) $(OBJS_OTHERS): \ | ||||
|   $(SOURCE_DIR)/include/softfloat_types.h $(SOURCE_DIR)/include/internals.h \ | ||||
|   $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/specialize.h \ | ||||
|   $(SOURCE_DIR)/include/softfloat.h | ||||
|  | ||||
| $(OBJS_PRIMITIVES) $(OBJS_OTHERS): %$(OBJ): $(SOURCE_DIR)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$*.c | ||||
|  | ||||
| $(OBJS_SPECIALIZE): %$(OBJ): $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/$*.c | ||||
|  | ||||
| softfloat$(LIB): $(OBJS_ALL) | ||||
| 	$(DELETE) $@ | ||||
| 	$(MAKELIB) $^ | ||||
|  | ||||
| .PHONY: clean | ||||
| clean: | ||||
| 	$(DELETE) $(OBJS_ALL) softfloat$(LIB) | ||||
|  | ||||
|   | ||||
| @@ -1,52 +1,53 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #define LITTLEENDIAN 1 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #ifdef __GNUC_STDC_INLINE__ | ||||
| #define INLINE inline | ||||
| #else | ||||
| #define INLINE extern inline | ||||
| #endif | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #define SOFTFLOAT_BUILTIN_CLZ 1 | ||||
| #include "opts-GCC.h" | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define LITTLEENDIAN 1 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #ifdef __GNUC_STDC_INLINE__ | ||||
| #define INLINE inline | ||||
| #else | ||||
| #define INLINE extern inline | ||||
| #endif | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define SOFTFLOAT_BUILTIN_CLZ 1 | ||||
| #include "opts-GCC.h" | ||||
|  | ||||
|   | ||||
| @@ -1,325 +1,325 @@ | ||||
|  | ||||
| #============================================================================= | ||||
| # | ||||
| # This Makefile is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| # Package, Release 3e, by John R. Hauser. | ||||
| # | ||||
| # Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| # University of California.  All rights reserved. | ||||
| # | ||||
| # Redistribution and use in source and binary forms, with or without | ||||
| # modification, are permitted provided that the following conditions are met: | ||||
| # | ||||
| #  1. Redistributions of source code must retain the above copyright notice, | ||||
| #     this list of conditions, and the following disclaimer. | ||||
| # | ||||
| #  2. Redistributions in binary form must reproduce the above copyright | ||||
| #     notice, this list of conditions, and the following disclaimer in the | ||||
| #     documentation and/or other materials provided with the distribution. | ||||
| # | ||||
| #  3. Neither the name of the University nor the names of its contributors | ||||
| #     may be used to endorse or promote products derived from this software | ||||
| #     without specific prior written permission. | ||||
| # | ||||
| # THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| # DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||||
| # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| # | ||||
| #============================================================================= | ||||
|  | ||||
| SOURCE_DIR ?= ../../source | ||||
| SPECIALIZE_TYPE ?= 8086-SSE | ||||
|  | ||||
| SOFTFLOAT_OPTS ?= \ | ||||
|   -DSOFTFLOAT_ROUND_ODD -DINLINE_LEVEL=5 -DSOFTFLOAT_FAST_DIV32TO16 \ | ||||
|   -DSOFTFLOAT_FAST_DIV64TO32 | ||||
|  | ||||
| DELETE = rm -f | ||||
| C_INCLUDES = -I. -I$(SOURCE_DIR)/$(SPECIALIZE_TYPE) -I$(SOURCE_DIR)/include | ||||
| COMPILE_C = \ | ||||
|   gcc -c -Werror-implicit-function-declaration $(SOFTFLOAT_OPTS) \ | ||||
|     $(C_INCLUDES) -O2 -o $@ | ||||
| MAKELIB = ar crs $@ | ||||
|  | ||||
| OBJ = .o | ||||
| LIB = .a | ||||
|  | ||||
| OTHER_HEADERS = | ||||
|  | ||||
| .PHONY: all | ||||
| all: softfloat$(LIB) | ||||
|  | ||||
| OBJS_PRIMITIVES = \ | ||||
|   s_compare96M$(OBJ) \ | ||||
|   s_compare128M$(OBJ) \ | ||||
|   s_shortShiftLeft64To96M$(OBJ) \ | ||||
|   s_shortShiftLeftM$(OBJ) \ | ||||
|   s_shiftLeftM$(OBJ) \ | ||||
|   s_shortShiftRightM$(OBJ) \ | ||||
|   s_shortShiftRightJam64$(OBJ) \ | ||||
|   s_shortShiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightJam32$(OBJ) \ | ||||
|   s_shiftRightJam64$(OBJ) \ | ||||
|   s_shiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightM$(OBJ) \ | ||||
|   s_countLeadingZeros8$(OBJ) \ | ||||
|   s_countLeadingZeros16$(OBJ) \ | ||||
|   s_countLeadingZeros32$(OBJ) \ | ||||
|   s_countLeadingZeros64$(OBJ) \ | ||||
|   s_addM$(OBJ) \ | ||||
|   s_addCarryM$(OBJ) \ | ||||
|   s_addComplCarryM$(OBJ) \ | ||||
|   s_negXM$(OBJ) \ | ||||
|   s_sub1XM$(OBJ) \ | ||||
|   s_subM$(OBJ) \ | ||||
|   s_mul64To128M$(OBJ) \ | ||||
|   s_mul128MTo256M$(OBJ) \ | ||||
|   s_approxRecip_1Ks$(OBJ) \ | ||||
|   s_approxRecip32_1$(OBJ) \ | ||||
|   s_approxRecipSqrt_1Ks$(OBJ) \ | ||||
|   s_approxRecipSqrt32_1$(OBJ) \ | ||||
|   s_remStepMBy32$(OBJ) \ | ||||
|  | ||||
| OBJS_SPECIALIZE = \ | ||||
|   softfloat_raiseFlags$(OBJ) \ | ||||
|   s_f16UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF16UI$(OBJ) \ | ||||
|   s_propagateNaNF16UI$(OBJ) \ | ||||
|   s_f32UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF32UI$(OBJ) \ | ||||
|   s_propagateNaNF32UI$(OBJ) \ | ||||
|   s_f64UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF64UI$(OBJ) \ | ||||
|   s_propagateNaNF64UI$(OBJ) \ | ||||
|   extF80M_isSignalingNaN$(OBJ) \ | ||||
|   s_extF80MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToExtF80M$(OBJ) \ | ||||
|   s_propagateNaNExtF80M$(OBJ) \ | ||||
|   f128M_isSignalingNaN$(OBJ) \ | ||||
|   s_f128MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF128M$(OBJ) \ | ||||
|   s_propagateNaNF128M$(OBJ) \ | ||||
|  | ||||
| OBJS_OTHERS = \ | ||||
|   s_roundToUI32$(OBJ) \ | ||||
|   s_roundMToUI64$(OBJ) \ | ||||
|   s_roundToI32$(OBJ) \ | ||||
|   s_roundMToI64$(OBJ) \ | ||||
|   s_normSubnormalF16Sig$(OBJ) \ | ||||
|   s_roundPackToF16$(OBJ) \ | ||||
|   s_normRoundPackToF16$(OBJ) \ | ||||
|   s_addMagsF16$(OBJ) \ | ||||
|   s_subMagsF16$(OBJ) \ | ||||
|   s_mulAddF16$(OBJ) \ | ||||
|   s_normSubnormalF32Sig$(OBJ) \ | ||||
|   s_roundPackToF32$(OBJ) \ | ||||
|   s_normRoundPackToF32$(OBJ) \ | ||||
|   s_addMagsF32$(OBJ) \ | ||||
|   s_subMagsF32$(OBJ) \ | ||||
|   s_mulAddF32$(OBJ) \ | ||||
|   s_normSubnormalF64Sig$(OBJ) \ | ||||
|   s_roundPackToF64$(OBJ) \ | ||||
|   s_normRoundPackToF64$(OBJ) \ | ||||
|   s_addMagsF64$(OBJ) \ | ||||
|   s_subMagsF64$(OBJ) \ | ||||
|   s_mulAddF64$(OBJ) \ | ||||
|   s_tryPropagateNaNExtF80M$(OBJ) \ | ||||
|   s_invalidExtF80M$(OBJ) \ | ||||
|   s_normExtF80SigM$(OBJ) \ | ||||
|   s_roundPackMToExtF80M$(OBJ) \ | ||||
|   s_normRoundPackMToExtF80M$(OBJ) \ | ||||
|   s_addExtF80M$(OBJ) \ | ||||
|   s_compareNonnormExtF80M$(OBJ) \ | ||||
|   s_isNaNF128M$(OBJ) \ | ||||
|   s_tryPropagateNaNF128M$(OBJ) \ | ||||
|   s_invalidF128M$(OBJ) \ | ||||
|   s_shiftNormSigF128M$(OBJ) \ | ||||
|   s_roundPackMToF128M$(OBJ) \ | ||||
|   s_normRoundPackMToF128M$(OBJ) \ | ||||
|   s_addF128M$(OBJ) \ | ||||
|   s_mulAddF128M$(OBJ) \ | ||||
|   softfloat_state$(OBJ) \ | ||||
|   ui32_to_f16$(OBJ) \ | ||||
|   ui32_to_f32$(OBJ) \ | ||||
|   ui32_to_f64$(OBJ) \ | ||||
|   ui32_to_extF80M$(OBJ) \ | ||||
|   ui32_to_f128M$(OBJ) \ | ||||
|   ui64_to_f16$(OBJ) \ | ||||
|   ui64_to_f32$(OBJ) \ | ||||
|   ui64_to_f64$(OBJ) \ | ||||
|   ui64_to_extF80M$(OBJ) \ | ||||
|   ui64_to_f128M$(OBJ) \ | ||||
|   i32_to_f16$(OBJ) \ | ||||
|   i32_to_f32$(OBJ) \ | ||||
|   i32_to_f64$(OBJ) \ | ||||
|   i32_to_extF80M$(OBJ) \ | ||||
|   i32_to_f128M$(OBJ) \ | ||||
|   i64_to_f16$(OBJ) \ | ||||
|   i64_to_f32$(OBJ) \ | ||||
|   i64_to_f64$(OBJ) \ | ||||
|   i64_to_extF80M$(OBJ) \ | ||||
|   i64_to_f128M$(OBJ) \ | ||||
|   f16_to_ui32$(OBJ) \ | ||||
|   f16_to_ui64$(OBJ) \ | ||||
|   f16_to_i32$(OBJ) \ | ||||
|   f16_to_i64$(OBJ) \ | ||||
|   f16_to_ui32_r_minMag$(OBJ) \ | ||||
|   f16_to_ui64_r_minMag$(OBJ) \ | ||||
|   f16_to_i32_r_minMag$(OBJ) \ | ||||
|   f16_to_i64_r_minMag$(OBJ) \ | ||||
|   f16_to_f32$(OBJ) \ | ||||
|   f16_to_f64$(OBJ) \ | ||||
|   f16_to_extF80M$(OBJ) \ | ||||
|   f16_to_f128M$(OBJ) \ | ||||
|   f16_roundToInt$(OBJ) \ | ||||
|   f16_add$(OBJ) \ | ||||
|   f16_sub$(OBJ) \ | ||||
|   f16_mul$(OBJ) \ | ||||
|   f16_mulAdd$(OBJ) \ | ||||
|   f16_div$(OBJ) \ | ||||
|   f16_rem$(OBJ) \ | ||||
|   f16_sqrt$(OBJ) \ | ||||
|   f16_eq$(OBJ) \ | ||||
|   f16_le$(OBJ) \ | ||||
|   f16_lt$(OBJ) \ | ||||
|   f16_eq_signaling$(OBJ) \ | ||||
|   f16_le_quiet$(OBJ) \ | ||||
|   f16_lt_quiet$(OBJ) \ | ||||
|   f16_isSignalingNaN$(OBJ) \ | ||||
|   f32_to_ui32$(OBJ) \ | ||||
|   f32_to_ui64$(OBJ) \ | ||||
|   f32_to_i32$(OBJ) \ | ||||
|   f32_to_i64$(OBJ) \ | ||||
|   f32_to_ui32_r_minMag$(OBJ) \ | ||||
|   f32_to_ui64_r_minMag$(OBJ) \ | ||||
|   f32_to_i32_r_minMag$(OBJ) \ | ||||
|   f32_to_i64_r_minMag$(OBJ) \ | ||||
|   f32_to_f16$(OBJ) \ | ||||
|   f32_to_f64$(OBJ) \ | ||||
|   f32_to_extF80M$(OBJ) \ | ||||
|   f32_to_f128M$(OBJ) \ | ||||
|   f32_roundToInt$(OBJ) \ | ||||
|   f32_add$(OBJ) \ | ||||
|   f32_sub$(OBJ) \ | ||||
|   f32_mul$(OBJ) \ | ||||
|   f32_mulAdd$(OBJ) \ | ||||
|   f32_div$(OBJ) \ | ||||
|   f32_rem$(OBJ) \ | ||||
|   f32_sqrt$(OBJ) \ | ||||
|   f32_eq$(OBJ) \ | ||||
|   f32_le$(OBJ) \ | ||||
|   f32_lt$(OBJ) \ | ||||
|   f32_eq_signaling$(OBJ) \ | ||||
|   f32_le_quiet$(OBJ) \ | ||||
|   f32_lt_quiet$(OBJ) \ | ||||
|   f32_isSignalingNaN$(OBJ) \ | ||||
|   f64_to_ui32$(OBJ) \ | ||||
|   f64_to_ui64$(OBJ) \ | ||||
|   f64_to_i32$(OBJ) \ | ||||
|   f64_to_i64$(OBJ) \ | ||||
|   f64_to_ui32_r_minMag$(OBJ) \ | ||||
|   f64_to_ui64_r_minMag$(OBJ) \ | ||||
|   f64_to_i32_r_minMag$(OBJ) \ | ||||
|   f64_to_i64_r_minMag$(OBJ) \ | ||||
|   f64_to_f16$(OBJ) \ | ||||
|   f64_to_f32$(OBJ) \ | ||||
|   f64_to_extF80M$(OBJ) \ | ||||
|   f64_to_f128M$(OBJ) \ | ||||
|   f64_roundToInt$(OBJ) \ | ||||
|   f64_add$(OBJ) \ | ||||
|   f64_sub$(OBJ) \ | ||||
|   f64_mul$(OBJ) \ | ||||
|   f64_mulAdd$(OBJ) \ | ||||
|   f64_div$(OBJ) \ | ||||
|   f64_rem$(OBJ) \ | ||||
|   f64_sqrt$(OBJ) \ | ||||
|   f64_eq$(OBJ) \ | ||||
|   f64_le$(OBJ) \ | ||||
|   f64_lt$(OBJ) \ | ||||
|   f64_eq_signaling$(OBJ) \ | ||||
|   f64_le_quiet$(OBJ) \ | ||||
|   f64_lt_quiet$(OBJ) \ | ||||
|   f64_isSignalingNaN$(OBJ) \ | ||||
|   extF80M_to_ui32$(OBJ) \ | ||||
|   extF80M_to_ui64$(OBJ) \ | ||||
|   extF80M_to_i32$(OBJ) \ | ||||
|   extF80M_to_i64$(OBJ) \ | ||||
|   extF80M_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_f16$(OBJ) \ | ||||
|   extF80M_to_f32$(OBJ) \ | ||||
|   extF80M_to_f64$(OBJ) \ | ||||
|   extF80M_to_f128M$(OBJ) \ | ||||
|   extF80M_roundToInt$(OBJ) \ | ||||
|   extF80M_add$(OBJ) \ | ||||
|   extF80M_sub$(OBJ) \ | ||||
|   extF80M_mul$(OBJ) \ | ||||
|   extF80M_div$(OBJ) \ | ||||
|   extF80M_rem$(OBJ) \ | ||||
|   extF80M_sqrt$(OBJ) \ | ||||
|   extF80M_eq$(OBJ) \ | ||||
|   extF80M_le$(OBJ) \ | ||||
|   extF80M_lt$(OBJ) \ | ||||
|   extF80M_eq_signaling$(OBJ) \ | ||||
|   extF80M_le_quiet$(OBJ) \ | ||||
|   extF80M_lt_quiet$(OBJ) \ | ||||
|   f128M_to_ui32$(OBJ) \ | ||||
|   f128M_to_ui64$(OBJ) \ | ||||
|   f128M_to_i32$(OBJ) \ | ||||
|   f128M_to_i64$(OBJ) \ | ||||
|   f128M_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128M_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128M_to_i32_r_minMag$(OBJ) \ | ||||
|   f128M_to_i64_r_minMag$(OBJ) \ | ||||
|   f128M_to_f16$(OBJ) \ | ||||
|   f128M_to_f32$(OBJ) \ | ||||
|   f128M_to_f64$(OBJ) \ | ||||
|   f128M_to_extF80M$(OBJ) \ | ||||
|   f128M_roundToInt$(OBJ) \ | ||||
|   f128M_add$(OBJ) \ | ||||
|   f128M_sub$(OBJ) \ | ||||
|   f128M_mul$(OBJ) \ | ||||
|   f128M_mulAdd$(OBJ) \ | ||||
|   f128M_div$(OBJ) \ | ||||
|   f128M_rem$(OBJ) \ | ||||
|   f128M_sqrt$(OBJ) \ | ||||
|   f128M_eq$(OBJ) \ | ||||
|   f128M_le$(OBJ) \ | ||||
|   f128M_lt$(OBJ) \ | ||||
|   f128M_eq_signaling$(OBJ) \ | ||||
|   f128M_le_quiet$(OBJ) \ | ||||
|   f128M_lt_quiet$(OBJ) \ | ||||
|  | ||||
| OBJS_ALL = $(OBJS_PRIMITIVES) $(OBJS_SPECIALIZE) $(OBJS_OTHERS) | ||||
|  | ||||
| $(OBJS_ALL): \ | ||||
|   $(OTHER_HEADERS) platform.h $(SOURCE_DIR)/include/primitiveTypes.h \ | ||||
|   $(SOURCE_DIR)/include/primitives.h | ||||
| $(OBJS_SPECIALIZE) $(OBJS_OTHERS): \ | ||||
|   $(SOURCE_DIR)/include/softfloat_types.h $(SOURCE_DIR)/include/internals.h \ | ||||
|   $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/specialize.h \ | ||||
|   $(SOURCE_DIR)/include/softfloat.h | ||||
|  | ||||
| $(OBJS_PRIMITIVES) $(OBJS_OTHERS): %$(OBJ): $(SOURCE_DIR)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$*.c | ||||
|  | ||||
| $(OBJS_SPECIALIZE): %$(OBJ): $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/$*.c | ||||
|  | ||||
| softfloat$(LIB): $(OBJS_ALL) | ||||
| 	$(DELETE) $@ | ||||
| 	$(MAKELIB) $^ | ||||
|  | ||||
| .PHONY: clean | ||||
| clean: | ||||
| 	$(DELETE) $(OBJS_ALL) softfloat$(LIB) | ||||
|  | ||||
|  | ||||
| #============================================================================= | ||||
| # | ||||
| # This Makefile is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| # Package, Release 3e, by John R. Hauser. | ||||
| # | ||||
| # Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| # University of California.  All rights reserved. | ||||
| # | ||||
| # Redistribution and use in source and binary forms, with or without | ||||
| # modification, are permitted provided that the following conditions are met: | ||||
| # | ||||
| #  1. Redistributions of source code must retain the above copyright notice, | ||||
| #     this list of conditions, and the following disclaimer. | ||||
| # | ||||
| #  2. Redistributions in binary form must reproduce the above copyright | ||||
| #     notice, this list of conditions, and the following disclaimer in the | ||||
| #     documentation and/or other materials provided with the distribution. | ||||
| # | ||||
| #  3. Neither the name of the University nor the names of its contributors | ||||
| #     may be used to endorse or promote products derived from this software | ||||
| #     without specific prior written permission. | ||||
| # | ||||
| # THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| # DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||||
| # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| # | ||||
| #============================================================================= | ||||
|  | ||||
| SOURCE_DIR ?= ../../source | ||||
| SPECIALIZE_TYPE ?= 8086-SSE | ||||
|  | ||||
| SOFTFLOAT_OPTS ?= \ | ||||
|   -DSOFTFLOAT_ROUND_ODD -DINLINE_LEVEL=5 -DSOFTFLOAT_FAST_DIV32TO16 \ | ||||
|   -DSOFTFLOAT_FAST_DIV64TO32 | ||||
|  | ||||
| DELETE = rm -f | ||||
| C_INCLUDES = -I. -I$(SOURCE_DIR)/$(SPECIALIZE_TYPE) -I$(SOURCE_DIR)/include | ||||
| COMPILE_C = \ | ||||
|   gcc -c -Werror-implicit-function-declaration $(SOFTFLOAT_OPTS) \ | ||||
|     $(C_INCLUDES) -O2 -o $@ | ||||
| MAKELIB = ar crs $@ | ||||
|  | ||||
| OBJ = .o | ||||
| LIB = .a | ||||
|  | ||||
| OTHER_HEADERS = | ||||
|  | ||||
| .PHONY: all | ||||
| all: softfloat$(LIB) | ||||
|  | ||||
| OBJS_PRIMITIVES = \ | ||||
|   s_compare96M$(OBJ) \ | ||||
|   s_compare128M$(OBJ) \ | ||||
|   s_shortShiftLeft64To96M$(OBJ) \ | ||||
|   s_shortShiftLeftM$(OBJ) \ | ||||
|   s_shiftLeftM$(OBJ) \ | ||||
|   s_shortShiftRightM$(OBJ) \ | ||||
|   s_shortShiftRightJam64$(OBJ) \ | ||||
|   s_shortShiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightJam32$(OBJ) \ | ||||
|   s_shiftRightJam64$(OBJ) \ | ||||
|   s_shiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightM$(OBJ) \ | ||||
|   s_countLeadingZeros8$(OBJ) \ | ||||
|   s_countLeadingZeros16$(OBJ) \ | ||||
|   s_countLeadingZeros32$(OBJ) \ | ||||
|   s_countLeadingZeros64$(OBJ) \ | ||||
|   s_addM$(OBJ) \ | ||||
|   s_addCarryM$(OBJ) \ | ||||
|   s_addComplCarryM$(OBJ) \ | ||||
|   s_negXM$(OBJ) \ | ||||
|   s_sub1XM$(OBJ) \ | ||||
|   s_subM$(OBJ) \ | ||||
|   s_mul64To128M$(OBJ) \ | ||||
|   s_mul128MTo256M$(OBJ) \ | ||||
|   s_approxRecip_1Ks$(OBJ) \ | ||||
|   s_approxRecip32_1$(OBJ) \ | ||||
|   s_approxRecipSqrt_1Ks$(OBJ) \ | ||||
|   s_approxRecipSqrt32_1$(OBJ) \ | ||||
|   s_remStepMBy32$(OBJ) \ | ||||
|  | ||||
| OBJS_SPECIALIZE = \ | ||||
|   softfloat_raiseFlags$(OBJ) \ | ||||
|   s_f16UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF16UI$(OBJ) \ | ||||
|   s_propagateNaNF16UI$(OBJ) \ | ||||
|   s_f32UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF32UI$(OBJ) \ | ||||
|   s_propagateNaNF32UI$(OBJ) \ | ||||
|   s_f64UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF64UI$(OBJ) \ | ||||
|   s_propagateNaNF64UI$(OBJ) \ | ||||
|   extF80M_isSignalingNaN$(OBJ) \ | ||||
|   s_extF80MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToExtF80M$(OBJ) \ | ||||
|   s_propagateNaNExtF80M$(OBJ) \ | ||||
|   f128M_isSignalingNaN$(OBJ) \ | ||||
|   s_f128MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF128M$(OBJ) \ | ||||
|   s_propagateNaNF128M$(OBJ) \ | ||||
|  | ||||
| OBJS_OTHERS = \ | ||||
|   s_roundToUI32$(OBJ) \ | ||||
|   s_roundMToUI64$(OBJ) \ | ||||
|   s_roundToI32$(OBJ) \ | ||||
|   s_roundMToI64$(OBJ) \ | ||||
|   s_normSubnormalF16Sig$(OBJ) \ | ||||
|   s_roundPackToF16$(OBJ) \ | ||||
|   s_normRoundPackToF16$(OBJ) \ | ||||
|   s_addMagsF16$(OBJ) \ | ||||
|   s_subMagsF16$(OBJ) \ | ||||
|   s_mulAddF16$(OBJ) \ | ||||
|   s_normSubnormalF32Sig$(OBJ) \ | ||||
|   s_roundPackToF32$(OBJ) \ | ||||
|   s_normRoundPackToF32$(OBJ) \ | ||||
|   s_addMagsF32$(OBJ) \ | ||||
|   s_subMagsF32$(OBJ) \ | ||||
|   s_mulAddF32$(OBJ) \ | ||||
|   s_normSubnormalF64Sig$(OBJ) \ | ||||
|   s_roundPackToF64$(OBJ) \ | ||||
|   s_normRoundPackToF64$(OBJ) \ | ||||
|   s_addMagsF64$(OBJ) \ | ||||
|   s_subMagsF64$(OBJ) \ | ||||
|   s_mulAddF64$(OBJ) \ | ||||
|   s_tryPropagateNaNExtF80M$(OBJ) \ | ||||
|   s_invalidExtF80M$(OBJ) \ | ||||
|   s_normExtF80SigM$(OBJ) \ | ||||
|   s_roundPackMToExtF80M$(OBJ) \ | ||||
|   s_normRoundPackMToExtF80M$(OBJ) \ | ||||
|   s_addExtF80M$(OBJ) \ | ||||
|   s_compareNonnormExtF80M$(OBJ) \ | ||||
|   s_isNaNF128M$(OBJ) \ | ||||
|   s_tryPropagateNaNF128M$(OBJ) \ | ||||
|   s_invalidF128M$(OBJ) \ | ||||
|   s_shiftNormSigF128M$(OBJ) \ | ||||
|   s_roundPackMToF128M$(OBJ) \ | ||||
|   s_normRoundPackMToF128M$(OBJ) \ | ||||
|   s_addF128M$(OBJ) \ | ||||
|   s_mulAddF128M$(OBJ) \ | ||||
|   softfloat_state$(OBJ) \ | ||||
|   ui32_to_f16$(OBJ) \ | ||||
|   ui32_to_f32$(OBJ) \ | ||||
|   ui32_to_f64$(OBJ) \ | ||||
|   ui32_to_extF80M$(OBJ) \ | ||||
|   ui32_to_f128M$(OBJ) \ | ||||
|   ui64_to_f16$(OBJ) \ | ||||
|   ui64_to_f32$(OBJ) \ | ||||
|   ui64_to_f64$(OBJ) \ | ||||
|   ui64_to_extF80M$(OBJ) \ | ||||
|   ui64_to_f128M$(OBJ) \ | ||||
|   i32_to_f16$(OBJ) \ | ||||
|   i32_to_f32$(OBJ) \ | ||||
|   i32_to_f64$(OBJ) \ | ||||
|   i32_to_extF80M$(OBJ) \ | ||||
|   i32_to_f128M$(OBJ) \ | ||||
|   i64_to_f16$(OBJ) \ | ||||
|   i64_to_f32$(OBJ) \ | ||||
|   i64_to_f64$(OBJ) \ | ||||
|   i64_to_extF80M$(OBJ) \ | ||||
|   i64_to_f128M$(OBJ) \ | ||||
|   f16_to_ui32$(OBJ) \ | ||||
|   f16_to_ui64$(OBJ) \ | ||||
|   f16_to_i32$(OBJ) \ | ||||
|   f16_to_i64$(OBJ) \ | ||||
|   f16_to_ui32_r_minMag$(OBJ) \ | ||||
|   f16_to_ui64_r_minMag$(OBJ) \ | ||||
|   f16_to_i32_r_minMag$(OBJ) \ | ||||
|   f16_to_i64_r_minMag$(OBJ) \ | ||||
|   f16_to_f32$(OBJ) \ | ||||
|   f16_to_f64$(OBJ) \ | ||||
|   f16_to_extF80M$(OBJ) \ | ||||
|   f16_to_f128M$(OBJ) \ | ||||
|   f16_roundToInt$(OBJ) \ | ||||
|   f16_add$(OBJ) \ | ||||
|   f16_sub$(OBJ) \ | ||||
|   f16_mul$(OBJ) \ | ||||
|   f16_mulAdd$(OBJ) \ | ||||
|   f16_div$(OBJ) \ | ||||
|   f16_rem$(OBJ) \ | ||||
|   f16_sqrt$(OBJ) \ | ||||
|   f16_eq$(OBJ) \ | ||||
|   f16_le$(OBJ) \ | ||||
|   f16_lt$(OBJ) \ | ||||
|   f16_eq_signaling$(OBJ) \ | ||||
|   f16_le_quiet$(OBJ) \ | ||||
|   f16_lt_quiet$(OBJ) \ | ||||
|   f16_isSignalingNaN$(OBJ) \ | ||||
|   f32_to_ui32$(OBJ) \ | ||||
|   f32_to_ui64$(OBJ) \ | ||||
|   f32_to_i32$(OBJ) \ | ||||
|   f32_to_i64$(OBJ) \ | ||||
|   f32_to_ui32_r_minMag$(OBJ) \ | ||||
|   f32_to_ui64_r_minMag$(OBJ) \ | ||||
|   f32_to_i32_r_minMag$(OBJ) \ | ||||
|   f32_to_i64_r_minMag$(OBJ) \ | ||||
|   f32_to_f16$(OBJ) \ | ||||
|   f32_to_f64$(OBJ) \ | ||||
|   f32_to_extF80M$(OBJ) \ | ||||
|   f32_to_f128M$(OBJ) \ | ||||
|   f32_roundToInt$(OBJ) \ | ||||
|   f32_add$(OBJ) \ | ||||
|   f32_sub$(OBJ) \ | ||||
|   f32_mul$(OBJ) \ | ||||
|   f32_mulAdd$(OBJ) \ | ||||
|   f32_div$(OBJ) \ | ||||
|   f32_rem$(OBJ) \ | ||||
|   f32_sqrt$(OBJ) \ | ||||
|   f32_eq$(OBJ) \ | ||||
|   f32_le$(OBJ) \ | ||||
|   f32_lt$(OBJ) \ | ||||
|   f32_eq_signaling$(OBJ) \ | ||||
|   f32_le_quiet$(OBJ) \ | ||||
|   f32_lt_quiet$(OBJ) \ | ||||
|   f32_isSignalingNaN$(OBJ) \ | ||||
|   f64_to_ui32$(OBJ) \ | ||||
|   f64_to_ui64$(OBJ) \ | ||||
|   f64_to_i32$(OBJ) \ | ||||
|   f64_to_i64$(OBJ) \ | ||||
|   f64_to_ui32_r_minMag$(OBJ) \ | ||||
|   f64_to_ui64_r_minMag$(OBJ) \ | ||||
|   f64_to_i32_r_minMag$(OBJ) \ | ||||
|   f64_to_i64_r_minMag$(OBJ) \ | ||||
|   f64_to_f16$(OBJ) \ | ||||
|   f64_to_f32$(OBJ) \ | ||||
|   f64_to_extF80M$(OBJ) \ | ||||
|   f64_to_f128M$(OBJ) \ | ||||
|   f64_roundToInt$(OBJ) \ | ||||
|   f64_add$(OBJ) \ | ||||
|   f64_sub$(OBJ) \ | ||||
|   f64_mul$(OBJ) \ | ||||
|   f64_mulAdd$(OBJ) \ | ||||
|   f64_div$(OBJ) \ | ||||
|   f64_rem$(OBJ) \ | ||||
|   f64_sqrt$(OBJ) \ | ||||
|   f64_eq$(OBJ) \ | ||||
|   f64_le$(OBJ) \ | ||||
|   f64_lt$(OBJ) \ | ||||
|   f64_eq_signaling$(OBJ) \ | ||||
|   f64_le_quiet$(OBJ) \ | ||||
|   f64_lt_quiet$(OBJ) \ | ||||
|   f64_isSignalingNaN$(OBJ) \ | ||||
|   extF80M_to_ui32$(OBJ) \ | ||||
|   extF80M_to_ui64$(OBJ) \ | ||||
|   extF80M_to_i32$(OBJ) \ | ||||
|   extF80M_to_i64$(OBJ) \ | ||||
|   extF80M_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_f16$(OBJ) \ | ||||
|   extF80M_to_f32$(OBJ) \ | ||||
|   extF80M_to_f64$(OBJ) \ | ||||
|   extF80M_to_f128M$(OBJ) \ | ||||
|   extF80M_roundToInt$(OBJ) \ | ||||
|   extF80M_add$(OBJ) \ | ||||
|   extF80M_sub$(OBJ) \ | ||||
|   extF80M_mul$(OBJ) \ | ||||
|   extF80M_div$(OBJ) \ | ||||
|   extF80M_rem$(OBJ) \ | ||||
|   extF80M_sqrt$(OBJ) \ | ||||
|   extF80M_eq$(OBJ) \ | ||||
|   extF80M_le$(OBJ) \ | ||||
|   extF80M_lt$(OBJ) \ | ||||
|   extF80M_eq_signaling$(OBJ) \ | ||||
|   extF80M_le_quiet$(OBJ) \ | ||||
|   extF80M_lt_quiet$(OBJ) \ | ||||
|   f128M_to_ui32$(OBJ) \ | ||||
|   f128M_to_ui64$(OBJ) \ | ||||
|   f128M_to_i32$(OBJ) \ | ||||
|   f128M_to_i64$(OBJ) \ | ||||
|   f128M_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128M_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128M_to_i32_r_minMag$(OBJ) \ | ||||
|   f128M_to_i64_r_minMag$(OBJ) \ | ||||
|   f128M_to_f16$(OBJ) \ | ||||
|   f128M_to_f32$(OBJ) \ | ||||
|   f128M_to_f64$(OBJ) \ | ||||
|   f128M_to_extF80M$(OBJ) \ | ||||
|   f128M_roundToInt$(OBJ) \ | ||||
|   f128M_add$(OBJ) \ | ||||
|   f128M_sub$(OBJ) \ | ||||
|   f128M_mul$(OBJ) \ | ||||
|   f128M_mulAdd$(OBJ) \ | ||||
|   f128M_div$(OBJ) \ | ||||
|   f128M_rem$(OBJ) \ | ||||
|   f128M_sqrt$(OBJ) \ | ||||
|   f128M_eq$(OBJ) \ | ||||
|   f128M_le$(OBJ) \ | ||||
|   f128M_lt$(OBJ) \ | ||||
|   f128M_eq_signaling$(OBJ) \ | ||||
|   f128M_le_quiet$(OBJ) \ | ||||
|   f128M_lt_quiet$(OBJ) \ | ||||
|  | ||||
| OBJS_ALL = $(OBJS_PRIMITIVES) $(OBJS_SPECIALIZE) $(OBJS_OTHERS) | ||||
|  | ||||
| $(OBJS_ALL): \ | ||||
|   $(OTHER_HEADERS) platform.h $(SOURCE_DIR)/include/primitiveTypes.h \ | ||||
|   $(SOURCE_DIR)/include/primitives.h | ||||
| $(OBJS_SPECIALIZE) $(OBJS_OTHERS): \ | ||||
|   $(SOURCE_DIR)/include/softfloat_types.h $(SOURCE_DIR)/include/internals.h \ | ||||
|   $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/specialize.h \ | ||||
|   $(SOURCE_DIR)/include/softfloat.h | ||||
|  | ||||
| $(OBJS_PRIMITIVES) $(OBJS_OTHERS): %$(OBJ): $(SOURCE_DIR)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$*.c | ||||
|  | ||||
| $(OBJS_SPECIALIZE): %$(OBJ): $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/$*.c | ||||
|  | ||||
| softfloat$(LIB): $(OBJS_ALL) | ||||
| 	$(DELETE) $@ | ||||
| 	$(MAKELIB) $^ | ||||
|  | ||||
| .PHONY: clean | ||||
| clean: | ||||
| 	$(DELETE) $(OBJS_ALL) softfloat$(LIB) | ||||
|  | ||||
|   | ||||
| @@ -1,52 +1,53 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #define LITTLEENDIAN 1 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #ifdef __GNUC_STDC_INLINE__ | ||||
| #define INLINE inline | ||||
| #else | ||||
| #define INLINE extern inline | ||||
| #endif | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #define SOFTFLOAT_BUILTIN_CLZ 1 | ||||
| #include "opts-GCC.h" | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define LITTLEENDIAN 1 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #ifdef __GNUC_STDC_INLINE__ | ||||
| #define INLINE inline | ||||
| #else | ||||
| #define INLINE extern inline | ||||
| #endif | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define SOFTFLOAT_BUILTIN_CLZ 1 | ||||
| #include "opts-GCC.h" | ||||
|  | ||||
|   | ||||
| @@ -1,323 +1,323 @@ | ||||
|  | ||||
| #============================================================================= | ||||
| # | ||||
| # This Makefile is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| # Package, Release 3e, by John R. Hauser. | ||||
| # | ||||
| # Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| # University of California.  All rights reserved. | ||||
| # | ||||
| # Redistribution and use in source and binary forms, with or without | ||||
| # modification, are permitted provided that the following conditions are met: | ||||
| # | ||||
| #  1. Redistributions of source code must retain the above copyright notice, | ||||
| #     this list of conditions, and the following disclaimer. | ||||
| # | ||||
| #  2. Redistributions in binary form must reproduce the above copyright | ||||
| #     notice, this list of conditions, and the following disclaimer in the | ||||
| #     documentation and/or other materials provided with the distribution. | ||||
| # | ||||
| #  3. Neither the name of the University nor the names of its contributors | ||||
| #     may be used to endorse or promote products derived from this software | ||||
| #     without specific prior written permission. | ||||
| # | ||||
| # THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| # DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||||
| # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| # | ||||
| #============================================================================= | ||||
|  | ||||
| SOURCE_DIR ?= ../../source | ||||
| SPECIALIZE_TYPE ?= ARM-VFPv2 | ||||
|  | ||||
| SOFTFLOAT_OPTS ?= -DSOFTFLOAT_ROUND_ODD -DINLINE_LEVEL=5 | ||||
|  | ||||
| DELETE = rm -f | ||||
| C_INCLUDES = -I. -I$(SOURCE_DIR)/$(SPECIALIZE_TYPE) -I$(SOURCE_DIR)/include | ||||
| COMPILE_C = \ | ||||
|   gcc -c -Werror-implicit-function-declaration $(SOFTFLOAT_OPTS) \ | ||||
|     $(C_INCLUDES) -O2 -o $@ | ||||
| MAKELIB = ar crs $@ | ||||
|  | ||||
| OBJ = .o | ||||
| LIB = .a | ||||
|  | ||||
| OTHER_HEADERS = | ||||
|  | ||||
| .PHONY: all | ||||
| all: softfloat$(LIB) | ||||
|  | ||||
| OBJS_PRIMITIVES = \ | ||||
|   s_compare96M$(OBJ) \ | ||||
|   s_compare128M$(OBJ) \ | ||||
|   s_shortShiftLeft64To96M$(OBJ) \ | ||||
|   s_shortShiftLeftM$(OBJ) \ | ||||
|   s_shiftLeftM$(OBJ) \ | ||||
|   s_shortShiftRightM$(OBJ) \ | ||||
|   s_shortShiftRightJam64$(OBJ) \ | ||||
|   s_shortShiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightJam32$(OBJ) \ | ||||
|   s_shiftRightJam64$(OBJ) \ | ||||
|   s_shiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightM$(OBJ) \ | ||||
|   s_countLeadingZeros8$(OBJ) \ | ||||
|   s_countLeadingZeros16$(OBJ) \ | ||||
|   s_countLeadingZeros32$(OBJ) \ | ||||
|   s_countLeadingZeros64$(OBJ) \ | ||||
|   s_addM$(OBJ) \ | ||||
|   s_addCarryM$(OBJ) \ | ||||
|   s_addComplCarryM$(OBJ) \ | ||||
|   s_negXM$(OBJ) \ | ||||
|   s_sub1XM$(OBJ) \ | ||||
|   s_subM$(OBJ) \ | ||||
|   s_mul64To128M$(OBJ) \ | ||||
|   s_mul128MTo256M$(OBJ) \ | ||||
|   s_approxRecip_1Ks$(OBJ) \ | ||||
|   s_approxRecip32_1$(OBJ) \ | ||||
|   s_approxRecipSqrt_1Ks$(OBJ) \ | ||||
|   s_approxRecipSqrt32_1$(OBJ) \ | ||||
|   s_remStepMBy32$(OBJ) \ | ||||
|  | ||||
| OBJS_SPECIALIZE = \ | ||||
|   softfloat_raiseFlags$(OBJ) \ | ||||
|   s_f16UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF16UI$(OBJ) \ | ||||
|   s_propagateNaNF16UI$(OBJ) \ | ||||
|   s_f32UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF32UI$(OBJ) \ | ||||
|   s_propagateNaNF32UI$(OBJ) \ | ||||
|   s_f64UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF64UI$(OBJ) \ | ||||
|   s_propagateNaNF64UI$(OBJ) \ | ||||
|   extF80M_isSignalingNaN$(OBJ) \ | ||||
|   s_extF80MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToExtF80M$(OBJ) \ | ||||
|   s_propagateNaNExtF80M$(OBJ) \ | ||||
|   f128M_isSignalingNaN$(OBJ) \ | ||||
|   s_f128MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF128M$(OBJ) \ | ||||
|   s_propagateNaNF128M$(OBJ) \ | ||||
|  | ||||
| OBJS_OTHERS = \ | ||||
|   s_roundToUI32$(OBJ) \ | ||||
|   s_roundMToUI64$(OBJ) \ | ||||
|   s_roundToI32$(OBJ) \ | ||||
|   s_roundMToI64$(OBJ) \ | ||||
|   s_normSubnormalF16Sig$(OBJ) \ | ||||
|   s_roundPackToF16$(OBJ) \ | ||||
|   s_normRoundPackToF16$(OBJ) \ | ||||
|   s_addMagsF16$(OBJ) \ | ||||
|   s_subMagsF16$(OBJ) \ | ||||
|   s_mulAddF16$(OBJ) \ | ||||
|   s_normSubnormalF32Sig$(OBJ) \ | ||||
|   s_roundPackToF32$(OBJ) \ | ||||
|   s_normRoundPackToF32$(OBJ) \ | ||||
|   s_addMagsF32$(OBJ) \ | ||||
|   s_subMagsF32$(OBJ) \ | ||||
|   s_mulAddF32$(OBJ) \ | ||||
|   s_normSubnormalF64Sig$(OBJ) \ | ||||
|   s_roundPackToF64$(OBJ) \ | ||||
|   s_normRoundPackToF64$(OBJ) \ | ||||
|   s_addMagsF64$(OBJ) \ | ||||
|   s_subMagsF64$(OBJ) \ | ||||
|   s_mulAddF64$(OBJ) \ | ||||
|   s_tryPropagateNaNExtF80M$(OBJ) \ | ||||
|   s_invalidExtF80M$(OBJ) \ | ||||
|   s_normExtF80SigM$(OBJ) \ | ||||
|   s_roundPackMToExtF80M$(OBJ) \ | ||||
|   s_normRoundPackMToExtF80M$(OBJ) \ | ||||
|   s_addExtF80M$(OBJ) \ | ||||
|   s_compareNonnormExtF80M$(OBJ) \ | ||||
|   s_isNaNF128M$(OBJ) \ | ||||
|   s_tryPropagateNaNF128M$(OBJ) \ | ||||
|   s_invalidF128M$(OBJ) \ | ||||
|   s_shiftNormSigF128M$(OBJ) \ | ||||
|   s_roundPackMToF128M$(OBJ) \ | ||||
|   s_normRoundPackMToF128M$(OBJ) \ | ||||
|   s_addF128M$(OBJ) \ | ||||
|   s_mulAddF128M$(OBJ) \ | ||||
|   softfloat_state$(OBJ) \ | ||||
|   ui32_to_f16$(OBJ) \ | ||||
|   ui32_to_f32$(OBJ) \ | ||||
|   ui32_to_f64$(OBJ) \ | ||||
|   ui32_to_extF80M$(OBJ) \ | ||||
|   ui32_to_f128M$(OBJ) \ | ||||
|   ui64_to_f16$(OBJ) \ | ||||
|   ui64_to_f32$(OBJ) \ | ||||
|   ui64_to_f64$(OBJ) \ | ||||
|   ui64_to_extF80M$(OBJ) \ | ||||
|   ui64_to_f128M$(OBJ) \ | ||||
|   i32_to_f16$(OBJ) \ | ||||
|   i32_to_f32$(OBJ) \ | ||||
|   i32_to_f64$(OBJ) \ | ||||
|   i32_to_extF80M$(OBJ) \ | ||||
|   i32_to_f128M$(OBJ) \ | ||||
|   i64_to_f16$(OBJ) \ | ||||
|   i64_to_f32$(OBJ) \ | ||||
|   i64_to_f64$(OBJ) \ | ||||
|   i64_to_extF80M$(OBJ) \ | ||||
|   i64_to_f128M$(OBJ) \ | ||||
|   f16_to_ui32$(OBJ) \ | ||||
|   f16_to_ui64$(OBJ) \ | ||||
|   f16_to_i32$(OBJ) \ | ||||
|   f16_to_i64$(OBJ) \ | ||||
|   f16_to_ui32_r_minMag$(OBJ) \ | ||||
|   f16_to_ui64_r_minMag$(OBJ) \ | ||||
|   f16_to_i32_r_minMag$(OBJ) \ | ||||
|   f16_to_i64_r_minMag$(OBJ) \ | ||||
|   f16_to_f32$(OBJ) \ | ||||
|   f16_to_f64$(OBJ) \ | ||||
|   f16_to_extF80M$(OBJ) \ | ||||
|   f16_to_f128M$(OBJ) \ | ||||
|   f16_roundToInt$(OBJ) \ | ||||
|   f16_add$(OBJ) \ | ||||
|   f16_sub$(OBJ) \ | ||||
|   f16_mul$(OBJ) \ | ||||
|   f16_mulAdd$(OBJ) \ | ||||
|   f16_div$(OBJ) \ | ||||
|   f16_rem$(OBJ) \ | ||||
|   f16_sqrt$(OBJ) \ | ||||
|   f16_eq$(OBJ) \ | ||||
|   f16_le$(OBJ) \ | ||||
|   f16_lt$(OBJ) \ | ||||
|   f16_eq_signaling$(OBJ) \ | ||||
|   f16_le_quiet$(OBJ) \ | ||||
|   f16_lt_quiet$(OBJ) \ | ||||
|   f16_isSignalingNaN$(OBJ) \ | ||||
|   f32_to_ui32$(OBJ) \ | ||||
|   f32_to_ui64$(OBJ) \ | ||||
|   f32_to_i32$(OBJ) \ | ||||
|   f32_to_i64$(OBJ) \ | ||||
|   f32_to_ui32_r_minMag$(OBJ) \ | ||||
|   f32_to_ui64_r_minMag$(OBJ) \ | ||||
|   f32_to_i32_r_minMag$(OBJ) \ | ||||
|   f32_to_i64_r_minMag$(OBJ) \ | ||||
|   f32_to_f16$(OBJ) \ | ||||
|   f32_to_f64$(OBJ) \ | ||||
|   f32_to_extF80M$(OBJ) \ | ||||
|   f32_to_f128M$(OBJ) \ | ||||
|   f32_roundToInt$(OBJ) \ | ||||
|   f32_add$(OBJ) \ | ||||
|   f32_sub$(OBJ) \ | ||||
|   f32_mul$(OBJ) \ | ||||
|   f32_mulAdd$(OBJ) \ | ||||
|   f32_div$(OBJ) \ | ||||
|   f32_rem$(OBJ) \ | ||||
|   f32_sqrt$(OBJ) \ | ||||
|   f32_eq$(OBJ) \ | ||||
|   f32_le$(OBJ) \ | ||||
|   f32_lt$(OBJ) \ | ||||
|   f32_eq_signaling$(OBJ) \ | ||||
|   f32_le_quiet$(OBJ) \ | ||||
|   f32_lt_quiet$(OBJ) \ | ||||
|   f32_isSignalingNaN$(OBJ) \ | ||||
|   f64_to_ui32$(OBJ) \ | ||||
|   f64_to_ui64$(OBJ) \ | ||||
|   f64_to_i32$(OBJ) \ | ||||
|   f64_to_i64$(OBJ) \ | ||||
|   f64_to_ui32_r_minMag$(OBJ) \ | ||||
|   f64_to_ui64_r_minMag$(OBJ) \ | ||||
|   f64_to_i32_r_minMag$(OBJ) \ | ||||
|   f64_to_i64_r_minMag$(OBJ) \ | ||||
|   f64_to_f16$(OBJ) \ | ||||
|   f64_to_f32$(OBJ) \ | ||||
|   f64_to_extF80M$(OBJ) \ | ||||
|   f64_to_f128M$(OBJ) \ | ||||
|   f64_roundToInt$(OBJ) \ | ||||
|   f64_add$(OBJ) \ | ||||
|   f64_sub$(OBJ) \ | ||||
|   f64_mul$(OBJ) \ | ||||
|   f64_mulAdd$(OBJ) \ | ||||
|   f64_div$(OBJ) \ | ||||
|   f64_rem$(OBJ) \ | ||||
|   f64_sqrt$(OBJ) \ | ||||
|   f64_eq$(OBJ) \ | ||||
|   f64_le$(OBJ) \ | ||||
|   f64_lt$(OBJ) \ | ||||
|   f64_eq_signaling$(OBJ) \ | ||||
|   f64_le_quiet$(OBJ) \ | ||||
|   f64_lt_quiet$(OBJ) \ | ||||
|   f64_isSignalingNaN$(OBJ) \ | ||||
|   extF80M_to_ui32$(OBJ) \ | ||||
|   extF80M_to_ui64$(OBJ) \ | ||||
|   extF80M_to_i32$(OBJ) \ | ||||
|   extF80M_to_i64$(OBJ) \ | ||||
|   extF80M_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_f16$(OBJ) \ | ||||
|   extF80M_to_f32$(OBJ) \ | ||||
|   extF80M_to_f64$(OBJ) \ | ||||
|   extF80M_to_f128M$(OBJ) \ | ||||
|   extF80M_roundToInt$(OBJ) \ | ||||
|   extF80M_add$(OBJ) \ | ||||
|   extF80M_sub$(OBJ) \ | ||||
|   extF80M_mul$(OBJ) \ | ||||
|   extF80M_div$(OBJ) \ | ||||
|   extF80M_rem$(OBJ) \ | ||||
|   extF80M_sqrt$(OBJ) \ | ||||
|   extF80M_eq$(OBJ) \ | ||||
|   extF80M_le$(OBJ) \ | ||||
|   extF80M_lt$(OBJ) \ | ||||
|   extF80M_eq_signaling$(OBJ) \ | ||||
|   extF80M_le_quiet$(OBJ) \ | ||||
|   extF80M_lt_quiet$(OBJ) \ | ||||
|   f128M_to_ui32$(OBJ) \ | ||||
|   f128M_to_ui64$(OBJ) \ | ||||
|   f128M_to_i32$(OBJ) \ | ||||
|   f128M_to_i64$(OBJ) \ | ||||
|   f128M_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128M_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128M_to_i32_r_minMag$(OBJ) \ | ||||
|   f128M_to_i64_r_minMag$(OBJ) \ | ||||
|   f128M_to_f16$(OBJ) \ | ||||
|   f128M_to_f32$(OBJ) \ | ||||
|   f128M_to_f64$(OBJ) \ | ||||
|   f128M_to_extF80M$(OBJ) \ | ||||
|   f128M_roundToInt$(OBJ) \ | ||||
|   f128M_add$(OBJ) \ | ||||
|   f128M_sub$(OBJ) \ | ||||
|   f128M_mul$(OBJ) \ | ||||
|   f128M_mulAdd$(OBJ) \ | ||||
|   f128M_div$(OBJ) \ | ||||
|   f128M_rem$(OBJ) \ | ||||
|   f128M_sqrt$(OBJ) \ | ||||
|   f128M_eq$(OBJ) \ | ||||
|   f128M_le$(OBJ) \ | ||||
|   f128M_lt$(OBJ) \ | ||||
|   f128M_eq_signaling$(OBJ) \ | ||||
|   f128M_le_quiet$(OBJ) \ | ||||
|   f128M_lt_quiet$(OBJ) \ | ||||
|  | ||||
| OBJS_ALL = $(OBJS_PRIMITIVES) $(OBJS_SPECIALIZE) $(OBJS_OTHERS) | ||||
|  | ||||
| $(OBJS_ALL): \ | ||||
|   $(OTHER_HEADERS) platform.h $(SOURCE_DIR)/include/primitiveTypes.h \ | ||||
|   $(SOURCE_DIR)/include/primitives.h | ||||
| $(OBJS_SPECIALIZE) $(OBJS_OTHERS): \ | ||||
|   $(SOURCE_DIR)/include/softfloat_types.h $(SOURCE_DIR)/include/internals.h \ | ||||
|   $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/specialize.h \ | ||||
|   $(SOURCE_DIR)/include/softfloat.h | ||||
|  | ||||
| $(OBJS_PRIMITIVES) $(OBJS_OTHERS): %$(OBJ): $(SOURCE_DIR)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$*.c | ||||
|  | ||||
| $(OBJS_SPECIALIZE): %$(OBJ): $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/$*.c | ||||
|  | ||||
| softfloat$(LIB): $(OBJS_ALL) | ||||
| 	$(DELETE) $@ | ||||
| 	$(MAKELIB) $^ | ||||
|  | ||||
| .PHONY: clean | ||||
| clean: | ||||
| 	$(DELETE) $(OBJS_ALL) softfloat$(LIB) | ||||
|  | ||||
|  | ||||
| #============================================================================= | ||||
| # | ||||
| # This Makefile is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| # Package, Release 3e, by John R. Hauser. | ||||
| # | ||||
| # Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| # University of California.  All rights reserved. | ||||
| # | ||||
| # Redistribution and use in source and binary forms, with or without | ||||
| # modification, are permitted provided that the following conditions are met: | ||||
| # | ||||
| #  1. Redistributions of source code must retain the above copyright notice, | ||||
| #     this list of conditions, and the following disclaimer. | ||||
| # | ||||
| #  2. Redistributions in binary form must reproduce the above copyright | ||||
| #     notice, this list of conditions, and the following disclaimer in the | ||||
| #     documentation and/or other materials provided with the distribution. | ||||
| # | ||||
| #  3. Neither the name of the University nor the names of its contributors | ||||
| #     may be used to endorse or promote products derived from this software | ||||
| #     without specific prior written permission. | ||||
| # | ||||
| # THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| # DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||||
| # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| # | ||||
| #============================================================================= | ||||
|  | ||||
| SOURCE_DIR ?= ../../source | ||||
| SPECIALIZE_TYPE ?= ARM-VFPv2 | ||||
|  | ||||
| SOFTFLOAT_OPTS ?= -DSOFTFLOAT_ROUND_ODD -DINLINE_LEVEL=5 | ||||
|  | ||||
| DELETE = rm -f | ||||
| C_INCLUDES = -I. -I$(SOURCE_DIR)/$(SPECIALIZE_TYPE) -I$(SOURCE_DIR)/include | ||||
| COMPILE_C = \ | ||||
|   gcc -c -Werror-implicit-function-declaration $(SOFTFLOAT_OPTS) \ | ||||
|     $(C_INCLUDES) -O2 -o $@ | ||||
| MAKELIB = ar crs $@ | ||||
|  | ||||
| OBJ = .o | ||||
| LIB = .a | ||||
|  | ||||
| OTHER_HEADERS = | ||||
|  | ||||
| .PHONY: all | ||||
| all: softfloat$(LIB) | ||||
|  | ||||
| OBJS_PRIMITIVES = \ | ||||
|   s_compare96M$(OBJ) \ | ||||
|   s_compare128M$(OBJ) \ | ||||
|   s_shortShiftLeft64To96M$(OBJ) \ | ||||
|   s_shortShiftLeftM$(OBJ) \ | ||||
|   s_shiftLeftM$(OBJ) \ | ||||
|   s_shortShiftRightM$(OBJ) \ | ||||
|   s_shortShiftRightJam64$(OBJ) \ | ||||
|   s_shortShiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightJam32$(OBJ) \ | ||||
|   s_shiftRightJam64$(OBJ) \ | ||||
|   s_shiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightM$(OBJ) \ | ||||
|   s_countLeadingZeros8$(OBJ) \ | ||||
|   s_countLeadingZeros16$(OBJ) \ | ||||
|   s_countLeadingZeros32$(OBJ) \ | ||||
|   s_countLeadingZeros64$(OBJ) \ | ||||
|   s_addM$(OBJ) \ | ||||
|   s_addCarryM$(OBJ) \ | ||||
|   s_addComplCarryM$(OBJ) \ | ||||
|   s_negXM$(OBJ) \ | ||||
|   s_sub1XM$(OBJ) \ | ||||
|   s_subM$(OBJ) \ | ||||
|   s_mul64To128M$(OBJ) \ | ||||
|   s_mul128MTo256M$(OBJ) \ | ||||
|   s_approxRecip_1Ks$(OBJ) \ | ||||
|   s_approxRecip32_1$(OBJ) \ | ||||
|   s_approxRecipSqrt_1Ks$(OBJ) \ | ||||
|   s_approxRecipSqrt32_1$(OBJ) \ | ||||
|   s_remStepMBy32$(OBJ) \ | ||||
|  | ||||
| OBJS_SPECIALIZE = \ | ||||
|   softfloat_raiseFlags$(OBJ) \ | ||||
|   s_f16UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF16UI$(OBJ) \ | ||||
|   s_propagateNaNF16UI$(OBJ) \ | ||||
|   s_f32UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF32UI$(OBJ) \ | ||||
|   s_propagateNaNF32UI$(OBJ) \ | ||||
|   s_f64UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF64UI$(OBJ) \ | ||||
|   s_propagateNaNF64UI$(OBJ) \ | ||||
|   extF80M_isSignalingNaN$(OBJ) \ | ||||
|   s_extF80MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToExtF80M$(OBJ) \ | ||||
|   s_propagateNaNExtF80M$(OBJ) \ | ||||
|   f128M_isSignalingNaN$(OBJ) \ | ||||
|   s_f128MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF128M$(OBJ) \ | ||||
|   s_propagateNaNF128M$(OBJ) \ | ||||
|  | ||||
| OBJS_OTHERS = \ | ||||
|   s_roundToUI32$(OBJ) \ | ||||
|   s_roundMToUI64$(OBJ) \ | ||||
|   s_roundToI32$(OBJ) \ | ||||
|   s_roundMToI64$(OBJ) \ | ||||
|   s_normSubnormalF16Sig$(OBJ) \ | ||||
|   s_roundPackToF16$(OBJ) \ | ||||
|   s_normRoundPackToF16$(OBJ) \ | ||||
|   s_addMagsF16$(OBJ) \ | ||||
|   s_subMagsF16$(OBJ) \ | ||||
|   s_mulAddF16$(OBJ) \ | ||||
|   s_normSubnormalF32Sig$(OBJ) \ | ||||
|   s_roundPackToF32$(OBJ) \ | ||||
|   s_normRoundPackToF32$(OBJ) \ | ||||
|   s_addMagsF32$(OBJ) \ | ||||
|   s_subMagsF32$(OBJ) \ | ||||
|   s_mulAddF32$(OBJ) \ | ||||
|   s_normSubnormalF64Sig$(OBJ) \ | ||||
|   s_roundPackToF64$(OBJ) \ | ||||
|   s_normRoundPackToF64$(OBJ) \ | ||||
|   s_addMagsF64$(OBJ) \ | ||||
|   s_subMagsF64$(OBJ) \ | ||||
|   s_mulAddF64$(OBJ) \ | ||||
|   s_tryPropagateNaNExtF80M$(OBJ) \ | ||||
|   s_invalidExtF80M$(OBJ) \ | ||||
|   s_normExtF80SigM$(OBJ) \ | ||||
|   s_roundPackMToExtF80M$(OBJ) \ | ||||
|   s_normRoundPackMToExtF80M$(OBJ) \ | ||||
|   s_addExtF80M$(OBJ) \ | ||||
|   s_compareNonnormExtF80M$(OBJ) \ | ||||
|   s_isNaNF128M$(OBJ) \ | ||||
|   s_tryPropagateNaNF128M$(OBJ) \ | ||||
|   s_invalidF128M$(OBJ) \ | ||||
|   s_shiftNormSigF128M$(OBJ) \ | ||||
|   s_roundPackMToF128M$(OBJ) \ | ||||
|   s_normRoundPackMToF128M$(OBJ) \ | ||||
|   s_addF128M$(OBJ) \ | ||||
|   s_mulAddF128M$(OBJ) \ | ||||
|   softfloat_state$(OBJ) \ | ||||
|   ui32_to_f16$(OBJ) \ | ||||
|   ui32_to_f32$(OBJ) \ | ||||
|   ui32_to_f64$(OBJ) \ | ||||
|   ui32_to_extF80M$(OBJ) \ | ||||
|   ui32_to_f128M$(OBJ) \ | ||||
|   ui64_to_f16$(OBJ) \ | ||||
|   ui64_to_f32$(OBJ) \ | ||||
|   ui64_to_f64$(OBJ) \ | ||||
|   ui64_to_extF80M$(OBJ) \ | ||||
|   ui64_to_f128M$(OBJ) \ | ||||
|   i32_to_f16$(OBJ) \ | ||||
|   i32_to_f32$(OBJ) \ | ||||
|   i32_to_f64$(OBJ) \ | ||||
|   i32_to_extF80M$(OBJ) \ | ||||
|   i32_to_f128M$(OBJ) \ | ||||
|   i64_to_f16$(OBJ) \ | ||||
|   i64_to_f32$(OBJ) \ | ||||
|   i64_to_f64$(OBJ) \ | ||||
|   i64_to_extF80M$(OBJ) \ | ||||
|   i64_to_f128M$(OBJ) \ | ||||
|   f16_to_ui32$(OBJ) \ | ||||
|   f16_to_ui64$(OBJ) \ | ||||
|   f16_to_i32$(OBJ) \ | ||||
|   f16_to_i64$(OBJ) \ | ||||
|   f16_to_ui32_r_minMag$(OBJ) \ | ||||
|   f16_to_ui64_r_minMag$(OBJ) \ | ||||
|   f16_to_i32_r_minMag$(OBJ) \ | ||||
|   f16_to_i64_r_minMag$(OBJ) \ | ||||
|   f16_to_f32$(OBJ) \ | ||||
|   f16_to_f64$(OBJ) \ | ||||
|   f16_to_extF80M$(OBJ) \ | ||||
|   f16_to_f128M$(OBJ) \ | ||||
|   f16_roundToInt$(OBJ) \ | ||||
|   f16_add$(OBJ) \ | ||||
|   f16_sub$(OBJ) \ | ||||
|   f16_mul$(OBJ) \ | ||||
|   f16_mulAdd$(OBJ) \ | ||||
|   f16_div$(OBJ) \ | ||||
|   f16_rem$(OBJ) \ | ||||
|   f16_sqrt$(OBJ) \ | ||||
|   f16_eq$(OBJ) \ | ||||
|   f16_le$(OBJ) \ | ||||
|   f16_lt$(OBJ) \ | ||||
|   f16_eq_signaling$(OBJ) \ | ||||
|   f16_le_quiet$(OBJ) \ | ||||
|   f16_lt_quiet$(OBJ) \ | ||||
|   f16_isSignalingNaN$(OBJ) \ | ||||
|   f32_to_ui32$(OBJ) \ | ||||
|   f32_to_ui64$(OBJ) \ | ||||
|   f32_to_i32$(OBJ) \ | ||||
|   f32_to_i64$(OBJ) \ | ||||
|   f32_to_ui32_r_minMag$(OBJ) \ | ||||
|   f32_to_ui64_r_minMag$(OBJ) \ | ||||
|   f32_to_i32_r_minMag$(OBJ) \ | ||||
|   f32_to_i64_r_minMag$(OBJ) \ | ||||
|   f32_to_f16$(OBJ) \ | ||||
|   f32_to_f64$(OBJ) \ | ||||
|   f32_to_extF80M$(OBJ) \ | ||||
|   f32_to_f128M$(OBJ) \ | ||||
|   f32_roundToInt$(OBJ) \ | ||||
|   f32_add$(OBJ) \ | ||||
|   f32_sub$(OBJ) \ | ||||
|   f32_mul$(OBJ) \ | ||||
|   f32_mulAdd$(OBJ) \ | ||||
|   f32_div$(OBJ) \ | ||||
|   f32_rem$(OBJ) \ | ||||
|   f32_sqrt$(OBJ) \ | ||||
|   f32_eq$(OBJ) \ | ||||
|   f32_le$(OBJ) \ | ||||
|   f32_lt$(OBJ) \ | ||||
|   f32_eq_signaling$(OBJ) \ | ||||
|   f32_le_quiet$(OBJ) \ | ||||
|   f32_lt_quiet$(OBJ) \ | ||||
|   f32_isSignalingNaN$(OBJ) \ | ||||
|   f64_to_ui32$(OBJ) \ | ||||
|   f64_to_ui64$(OBJ) \ | ||||
|   f64_to_i32$(OBJ) \ | ||||
|   f64_to_i64$(OBJ) \ | ||||
|   f64_to_ui32_r_minMag$(OBJ) \ | ||||
|   f64_to_ui64_r_minMag$(OBJ) \ | ||||
|   f64_to_i32_r_minMag$(OBJ) \ | ||||
|   f64_to_i64_r_minMag$(OBJ) \ | ||||
|   f64_to_f16$(OBJ) \ | ||||
|   f64_to_f32$(OBJ) \ | ||||
|   f64_to_extF80M$(OBJ) \ | ||||
|   f64_to_f128M$(OBJ) \ | ||||
|   f64_roundToInt$(OBJ) \ | ||||
|   f64_add$(OBJ) \ | ||||
|   f64_sub$(OBJ) \ | ||||
|   f64_mul$(OBJ) \ | ||||
|   f64_mulAdd$(OBJ) \ | ||||
|   f64_div$(OBJ) \ | ||||
|   f64_rem$(OBJ) \ | ||||
|   f64_sqrt$(OBJ) \ | ||||
|   f64_eq$(OBJ) \ | ||||
|   f64_le$(OBJ) \ | ||||
|   f64_lt$(OBJ) \ | ||||
|   f64_eq_signaling$(OBJ) \ | ||||
|   f64_le_quiet$(OBJ) \ | ||||
|   f64_lt_quiet$(OBJ) \ | ||||
|   f64_isSignalingNaN$(OBJ) \ | ||||
|   extF80M_to_ui32$(OBJ) \ | ||||
|   extF80M_to_ui64$(OBJ) \ | ||||
|   extF80M_to_i32$(OBJ) \ | ||||
|   extF80M_to_i64$(OBJ) \ | ||||
|   extF80M_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_f16$(OBJ) \ | ||||
|   extF80M_to_f32$(OBJ) \ | ||||
|   extF80M_to_f64$(OBJ) \ | ||||
|   extF80M_to_f128M$(OBJ) \ | ||||
|   extF80M_roundToInt$(OBJ) \ | ||||
|   extF80M_add$(OBJ) \ | ||||
|   extF80M_sub$(OBJ) \ | ||||
|   extF80M_mul$(OBJ) \ | ||||
|   extF80M_div$(OBJ) \ | ||||
|   extF80M_rem$(OBJ) \ | ||||
|   extF80M_sqrt$(OBJ) \ | ||||
|   extF80M_eq$(OBJ) \ | ||||
|   extF80M_le$(OBJ) \ | ||||
|   extF80M_lt$(OBJ) \ | ||||
|   extF80M_eq_signaling$(OBJ) \ | ||||
|   extF80M_le_quiet$(OBJ) \ | ||||
|   extF80M_lt_quiet$(OBJ) \ | ||||
|   f128M_to_ui32$(OBJ) \ | ||||
|   f128M_to_ui64$(OBJ) \ | ||||
|   f128M_to_i32$(OBJ) \ | ||||
|   f128M_to_i64$(OBJ) \ | ||||
|   f128M_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128M_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128M_to_i32_r_minMag$(OBJ) \ | ||||
|   f128M_to_i64_r_minMag$(OBJ) \ | ||||
|   f128M_to_f16$(OBJ) \ | ||||
|   f128M_to_f32$(OBJ) \ | ||||
|   f128M_to_f64$(OBJ) \ | ||||
|   f128M_to_extF80M$(OBJ) \ | ||||
|   f128M_roundToInt$(OBJ) \ | ||||
|   f128M_add$(OBJ) \ | ||||
|   f128M_sub$(OBJ) \ | ||||
|   f128M_mul$(OBJ) \ | ||||
|   f128M_mulAdd$(OBJ) \ | ||||
|   f128M_div$(OBJ) \ | ||||
|   f128M_rem$(OBJ) \ | ||||
|   f128M_sqrt$(OBJ) \ | ||||
|   f128M_eq$(OBJ) \ | ||||
|   f128M_le$(OBJ) \ | ||||
|   f128M_lt$(OBJ) \ | ||||
|   f128M_eq_signaling$(OBJ) \ | ||||
|   f128M_le_quiet$(OBJ) \ | ||||
|   f128M_lt_quiet$(OBJ) \ | ||||
|  | ||||
| OBJS_ALL = $(OBJS_PRIMITIVES) $(OBJS_SPECIALIZE) $(OBJS_OTHERS) | ||||
|  | ||||
| $(OBJS_ALL): \ | ||||
|   $(OTHER_HEADERS) platform.h $(SOURCE_DIR)/include/primitiveTypes.h \ | ||||
|   $(SOURCE_DIR)/include/primitives.h | ||||
| $(OBJS_SPECIALIZE) $(OBJS_OTHERS): \ | ||||
|   $(SOURCE_DIR)/include/softfloat_types.h $(SOURCE_DIR)/include/internals.h \ | ||||
|   $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/specialize.h \ | ||||
|   $(SOURCE_DIR)/include/softfloat.h | ||||
|  | ||||
| $(OBJS_PRIMITIVES) $(OBJS_OTHERS): %$(OBJ): $(SOURCE_DIR)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$*.c | ||||
|  | ||||
| $(OBJS_SPECIALIZE): %$(OBJ): $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/$*.c | ||||
|  | ||||
| softfloat$(LIB): $(OBJS_ALL) | ||||
| 	$(DELETE) $@ | ||||
| 	$(MAKELIB) $^ | ||||
|  | ||||
| .PHONY: clean | ||||
| clean: | ||||
| 	$(DELETE) $(OBJS_ALL) softfloat$(LIB) | ||||
|  | ||||
|   | ||||
| @@ -1,52 +1,53 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #define LITTLEENDIAN 1 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #ifdef __GNUC_STDC_INLINE__ | ||||
| #define INLINE inline | ||||
| #else | ||||
| #define INLINE extern inline | ||||
| #endif | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #define SOFTFLOAT_BUILTIN_CLZ 1 | ||||
| #include "opts-GCC.h" | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define LITTLEENDIAN 1 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #ifdef __GNUC_STDC_INLINE__ | ||||
| #define INLINE inline | ||||
| #else | ||||
| #define INLINE extern inline | ||||
| #endif | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define SOFTFLOAT_BUILTIN_CLZ 1 | ||||
| #include "opts-GCC.h" | ||||
|  | ||||
|   | ||||
							
								
								
									
										399
									
								
								softfloat/build/Linux-RISCV64-GCC/Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										399
									
								
								softfloat/build/Linux-RISCV64-GCC/Makefile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,399 @@ | ||||
|  | ||||
| #============================================================================= | ||||
| # | ||||
| # This Makefile is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| # Package, Release 3e, by John R. Hauser. | ||||
| # | ||||
| # Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| # University of California.  All rights reserved. | ||||
| # | ||||
| # Redistribution and use in source and binary forms, with or without | ||||
| # modification, are permitted provided that the following conditions are met: | ||||
| # | ||||
| #  1. Redistributions of source code must retain the above copyright notice, | ||||
| #     this list of conditions, and the following disclaimer. | ||||
| # | ||||
| #  2. Redistributions in binary form must reproduce the above copyright | ||||
| #     notice, this list of conditions, and the following disclaimer in the | ||||
| #     documentation and/or other materials provided with the distribution. | ||||
| # | ||||
| #  3. Neither the name of the University nor the names of its contributors | ||||
| #     may be used to endorse or promote products derived from this software | ||||
| #     without specific prior written permission. | ||||
| # | ||||
| # THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| # DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||||
| # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| # | ||||
| #============================================================================= | ||||
|  | ||||
| SOURCE_DIR ?= ../../source | ||||
| SPECIALIZE_TYPE ?= RISCV | ||||
| MARCH ?= rv64gcv_zfh_zfhmin | ||||
| MABI ?= lp64d | ||||
|  | ||||
| SOFTFLOAT_OPTS ?= \ | ||||
|   -DSOFTFLOAT_ROUND_ODD -DINLINE_LEVEL=5 -DSOFTFLOAT_FAST_DIV32TO16 \ | ||||
|   -DSOFTFLOAT_FAST_DIV64TO32 | ||||
|  | ||||
| DELETE = rm -f | ||||
| C_INCLUDES = -I. -I$(SOURCE_DIR)/$(SPECIALIZE_TYPE) -I$(SOURCE_DIR)/include | ||||
| COMPILE_C = \ | ||||
|   riscv64-unknown-linux-gnu-gcc -c -march=$(MARCH) -mabi=$(MABI) -Werror-implicit-function-declaration -DSOFTFLOAT_FAST_INT64 \ | ||||
|     $(SOFTFLOAT_OPTS) $(C_INCLUDES) -O2 -o $@ | ||||
| MAKELIB = ar crs $@ | ||||
|  | ||||
| OBJ = .o | ||||
| LIB = .a | ||||
|  | ||||
| OTHER_HEADERS = $(SOURCE_DIR)/include/opts-GCC.h | ||||
|  | ||||
| .PHONY: all | ||||
| all: softfloat$(LIB) | ||||
|  | ||||
| OBJS_PRIMITIVES = \ | ||||
|   s_eq128$(OBJ) \ | ||||
|   s_le128$(OBJ) \ | ||||
|   s_lt128$(OBJ) \ | ||||
|   s_shortShiftLeft128$(OBJ) \ | ||||
|   s_shortShiftRight128$(OBJ) \ | ||||
|   s_shortShiftRightJam64$(OBJ) \ | ||||
|   s_shortShiftRightJam64Extra$(OBJ) \ | ||||
|   s_shortShiftRightJam128$(OBJ) \ | ||||
|   s_shortShiftRightJam128Extra$(OBJ) \ | ||||
|   s_shiftRightJam32$(OBJ) \ | ||||
|   s_shiftRightJam64$(OBJ) \ | ||||
|   s_shiftRightJam64Extra$(OBJ) \ | ||||
|   s_shiftRightJam128$(OBJ) \ | ||||
|   s_shiftRightJam128Extra$(OBJ) \ | ||||
|   s_shiftRightJam256M$(OBJ) \ | ||||
|   s_countLeadingZeros8$(OBJ) \ | ||||
|   s_countLeadingZeros16$(OBJ) \ | ||||
|   s_countLeadingZeros32$(OBJ) \ | ||||
|   s_countLeadingZeros64$(OBJ) \ | ||||
|   s_add128$(OBJ) \ | ||||
|   s_add256M$(OBJ) \ | ||||
|   s_sub128$(OBJ) \ | ||||
|   s_sub256M$(OBJ) \ | ||||
|   s_mul64ByShifted32To128$(OBJ) \ | ||||
|   s_mul64To128$(OBJ) \ | ||||
|   s_mul128By32$(OBJ) \ | ||||
|   s_mul128To256M$(OBJ) \ | ||||
|   s_approxRecip_1Ks$(OBJ) \ | ||||
|   s_approxRecip32_1$(OBJ) \ | ||||
|   s_approxRecipSqrt_1Ks$(OBJ) \ | ||||
|   s_approxRecipSqrt32_1$(OBJ) \ | ||||
|  | ||||
| OBJS_SPECIALIZE = \ | ||||
|   softfloat_raiseFlags$(OBJ) \ | ||||
|   s_f16UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF16UI$(OBJ) \ | ||||
|   s_propagateNaNF16UI$(OBJ) \ | ||||
|   s_bf16UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToBF16UI$(OBJ) \ | ||||
|   s_f32UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF32UI$(OBJ) \ | ||||
|   s_propagateNaNF32UI$(OBJ) \ | ||||
|   s_f64UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF64UI$(OBJ) \ | ||||
|   s_propagateNaNF64UI$(OBJ) \ | ||||
|   extF80M_isSignalingNaN$(OBJ) \ | ||||
|   s_extF80UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToExtF80UI$(OBJ) \ | ||||
|   s_propagateNaNExtF80UI$(OBJ) \ | ||||
|   f128M_isSignalingNaN$(OBJ) \ | ||||
|   s_f128UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF128UI$(OBJ) \ | ||||
|   s_propagateNaNF128UI$(OBJ) \ | ||||
|  | ||||
| OBJS_OTHERS = \ | ||||
|   s_roundToUI32$(OBJ) \ | ||||
|   s_roundToUI64$(OBJ) \ | ||||
|   s_roundToI32$(OBJ) \ | ||||
|   s_roundToI64$(OBJ) \ | ||||
|   s_normSubnormalBF16Sig$(OBJ) \ | ||||
|   s_roundPackToBF16$(OBJ) \ | ||||
|   s_normSubnormalF16Sig$(OBJ) \ | ||||
|   s_roundPackToF16$(OBJ) \ | ||||
|   s_normRoundPackToF16$(OBJ) \ | ||||
|   s_addMagsF16$(OBJ) \ | ||||
|   s_subMagsF16$(OBJ) \ | ||||
|   s_mulAddF16$(OBJ) \ | ||||
|   s_normSubnormalF32Sig$(OBJ) \ | ||||
|   s_roundPackToF32$(OBJ) \ | ||||
|   s_normRoundPackToF32$(OBJ) \ | ||||
|   s_addMagsF32$(OBJ) \ | ||||
|   s_subMagsF32$(OBJ) \ | ||||
|   s_mulAddF32$(OBJ) \ | ||||
|   s_normSubnormalF64Sig$(OBJ) \ | ||||
|   s_roundPackToF64$(OBJ) \ | ||||
|   s_normRoundPackToF64$(OBJ) \ | ||||
|   s_addMagsF64$(OBJ) \ | ||||
|   s_subMagsF64$(OBJ) \ | ||||
|   s_mulAddF64$(OBJ) \ | ||||
|   s_normSubnormalExtF80Sig$(OBJ) \ | ||||
|   s_roundPackToExtF80$(OBJ) \ | ||||
|   s_normRoundPackToExtF80$(OBJ) \ | ||||
|   s_addMagsExtF80$(OBJ) \ | ||||
|   s_subMagsExtF80$(OBJ) \ | ||||
|   s_normSubnormalF128Sig$(OBJ) \ | ||||
|   s_roundPackToF128$(OBJ) \ | ||||
|   s_normRoundPackToF128$(OBJ) \ | ||||
|   s_addMagsF128$(OBJ) \ | ||||
|   s_subMagsF128$(OBJ) \ | ||||
|   s_mulAddF128$(OBJ) \ | ||||
|   softfloat_state$(OBJ) \ | ||||
|   ui32_to_f16$(OBJ) \ | ||||
|   ui32_to_f32$(OBJ) \ | ||||
|   ui32_to_f64$(OBJ) \ | ||||
|   ui32_to_extF80$(OBJ) \ | ||||
|   ui32_to_extF80M$(OBJ) \ | ||||
|   ui32_to_f128$(OBJ) \ | ||||
|   ui32_to_f128M$(OBJ) \ | ||||
|   ui64_to_f16$(OBJ) \ | ||||
|   ui64_to_f32$(OBJ) \ | ||||
|   ui64_to_f64$(OBJ) \ | ||||
|   ui64_to_extF80$(OBJ) \ | ||||
|   ui64_to_extF80M$(OBJ) \ | ||||
|   ui64_to_f128$(OBJ) \ | ||||
|   ui64_to_f128M$(OBJ) \ | ||||
|   i32_to_f16$(OBJ) \ | ||||
|   i32_to_f32$(OBJ) \ | ||||
|   i32_to_f64$(OBJ) \ | ||||
|   i32_to_extF80$(OBJ) \ | ||||
|   i32_to_extF80M$(OBJ) \ | ||||
|   i32_to_f128$(OBJ) \ | ||||
|   i32_to_f128M$(OBJ) \ | ||||
|   i64_to_f16$(OBJ) \ | ||||
|   i64_to_f32$(OBJ) \ | ||||
|   i64_to_f64$(OBJ) \ | ||||
|   i64_to_extF80$(OBJ) \ | ||||
|   i64_to_extF80M$(OBJ) \ | ||||
|   i64_to_f128$(OBJ) \ | ||||
|   i64_to_f128M$(OBJ) \ | ||||
|   bf16_isSignalingNaN$(OBJ) \ | ||||
|   bf16_to_f32$(OBJ) \ | ||||
|   f16_to_ui32$(OBJ) \ | ||||
|   f16_to_ui64$(OBJ) \ | ||||
|   f16_to_i32$(OBJ) \ | ||||
|   f16_to_i64$(OBJ) \ | ||||
|   f16_to_ui32_r_minMag$(OBJ) \ | ||||
|   f16_to_ui64_r_minMag$(OBJ) \ | ||||
|   f16_to_i32_r_minMag$(OBJ) \ | ||||
|   f16_to_i64_r_minMag$(OBJ) \ | ||||
|   f16_to_f32$(OBJ) \ | ||||
|   f16_to_f64$(OBJ) \ | ||||
|   f16_to_extF80$(OBJ) \ | ||||
|   f16_to_extF80M$(OBJ) \ | ||||
|   f16_to_f128$(OBJ) \ | ||||
|   f16_to_f128M$(OBJ) \ | ||||
|   f16_roundToInt$(OBJ) \ | ||||
|   f16_add$(OBJ) \ | ||||
|   f16_sub$(OBJ) \ | ||||
|   f16_mul$(OBJ) \ | ||||
|   f16_mulAdd$(OBJ) \ | ||||
|   f16_div$(OBJ) \ | ||||
|   f16_rem$(OBJ) \ | ||||
|   f16_sqrt$(OBJ) \ | ||||
|   f16_eq$(OBJ) \ | ||||
|   f16_le$(OBJ) \ | ||||
|   f16_lt$(OBJ) \ | ||||
|   f16_eq_signaling$(OBJ) \ | ||||
|   f16_le_quiet$(OBJ) \ | ||||
|   f16_lt_quiet$(OBJ) \ | ||||
|   f16_isSignalingNaN$(OBJ) \ | ||||
|   f32_to_ui32$(OBJ) \ | ||||
|   f32_to_ui64$(OBJ) \ | ||||
|   f32_to_i32$(OBJ) \ | ||||
|   f32_to_i64$(OBJ) \ | ||||
|   f32_to_ui32_r_minMag$(OBJ) \ | ||||
|   f32_to_ui64_r_minMag$(OBJ) \ | ||||
|   f32_to_i32_r_minMag$(OBJ) \ | ||||
|   f32_to_i64_r_minMag$(OBJ) \ | ||||
|   f32_to_bf16$(OBJ) \ | ||||
|   f32_to_f16$(OBJ) \ | ||||
|   f32_to_f64$(OBJ) \ | ||||
|   f32_to_extF80$(OBJ) \ | ||||
|   f32_to_extF80M$(OBJ) \ | ||||
|   f32_to_f128$(OBJ) \ | ||||
|   f32_to_f128M$(OBJ) \ | ||||
|   f32_roundToInt$(OBJ) \ | ||||
|   f32_add$(OBJ) \ | ||||
|   f32_sub$(OBJ) \ | ||||
|   f32_mul$(OBJ) \ | ||||
|   f32_mulAdd$(OBJ) \ | ||||
|   f32_div$(OBJ) \ | ||||
|   f32_rem$(OBJ) \ | ||||
|   f32_sqrt$(OBJ) \ | ||||
|   f32_eq$(OBJ) \ | ||||
|   f32_le$(OBJ) \ | ||||
|   f32_lt$(OBJ) \ | ||||
|   f32_eq_signaling$(OBJ) \ | ||||
|   f32_le_quiet$(OBJ) \ | ||||
|   f32_lt_quiet$(OBJ) \ | ||||
|   f32_isSignalingNaN$(OBJ) \ | ||||
|   f64_to_ui32$(OBJ) \ | ||||
|   f64_to_ui64$(OBJ) \ | ||||
|   f64_to_i32$(OBJ) \ | ||||
|   f64_to_i64$(OBJ) \ | ||||
|   f64_to_ui32_r_minMag$(OBJ) \ | ||||
|   f64_to_ui64_r_minMag$(OBJ) \ | ||||
|   f64_to_i32_r_minMag$(OBJ) \ | ||||
|   f64_to_i64_r_minMag$(OBJ) \ | ||||
|   f64_to_f16$(OBJ) \ | ||||
|   f64_to_f32$(OBJ) \ | ||||
|   f64_to_extF80$(OBJ) \ | ||||
|   f64_to_extF80M$(OBJ) \ | ||||
|   f64_to_f128$(OBJ) \ | ||||
|   f64_to_f128M$(OBJ) \ | ||||
|   f64_roundToInt$(OBJ) \ | ||||
|   f64_add$(OBJ) \ | ||||
|   f64_sub$(OBJ) \ | ||||
|   f64_mul$(OBJ) \ | ||||
|   f64_mulAdd$(OBJ) \ | ||||
|   f64_div$(OBJ) \ | ||||
|   f64_rem$(OBJ) \ | ||||
|   f64_sqrt$(OBJ) \ | ||||
|   f64_eq$(OBJ) \ | ||||
|   f64_le$(OBJ) \ | ||||
|   f64_lt$(OBJ) \ | ||||
|   f64_eq_signaling$(OBJ) \ | ||||
|   f64_le_quiet$(OBJ) \ | ||||
|   f64_lt_quiet$(OBJ) \ | ||||
|   f64_isSignalingNaN$(OBJ) \ | ||||
|   extF80_to_ui32$(OBJ) \ | ||||
|   extF80_to_ui64$(OBJ) \ | ||||
|   extF80_to_i32$(OBJ) \ | ||||
|   extF80_to_i64$(OBJ) \ | ||||
|   extF80_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80_to_f16$(OBJ) \ | ||||
|   extF80_to_f32$(OBJ) \ | ||||
|   extF80_to_f64$(OBJ) \ | ||||
|   extF80_to_f128$(OBJ) \ | ||||
|   extF80_roundToInt$(OBJ) \ | ||||
|   extF80_add$(OBJ) \ | ||||
|   extF80_sub$(OBJ) \ | ||||
|   extF80_mul$(OBJ) \ | ||||
|   extF80_div$(OBJ) \ | ||||
|   extF80_rem$(OBJ) \ | ||||
|   extF80_sqrt$(OBJ) \ | ||||
|   extF80_eq$(OBJ) \ | ||||
|   extF80_le$(OBJ) \ | ||||
|   extF80_lt$(OBJ) \ | ||||
|   extF80_eq_signaling$(OBJ) \ | ||||
|   extF80_le_quiet$(OBJ) \ | ||||
|   extF80_lt_quiet$(OBJ) \ | ||||
|   extF80_isSignalingNaN$(OBJ) \ | ||||
|   extF80M_to_ui32$(OBJ) \ | ||||
|   extF80M_to_ui64$(OBJ) \ | ||||
|   extF80M_to_i32$(OBJ) \ | ||||
|   extF80M_to_i64$(OBJ) \ | ||||
|   extF80M_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_f16$(OBJ) \ | ||||
|   extF80M_to_f32$(OBJ) \ | ||||
|   extF80M_to_f64$(OBJ) \ | ||||
|   extF80M_to_f128M$(OBJ) \ | ||||
|   extF80M_roundToInt$(OBJ) \ | ||||
|   extF80M_add$(OBJ) \ | ||||
|   extF80M_sub$(OBJ) \ | ||||
|   extF80M_mul$(OBJ) \ | ||||
|   extF80M_div$(OBJ) \ | ||||
|   extF80M_rem$(OBJ) \ | ||||
|   extF80M_sqrt$(OBJ) \ | ||||
|   extF80M_eq$(OBJ) \ | ||||
|   extF80M_le$(OBJ) \ | ||||
|   extF80M_lt$(OBJ) \ | ||||
|   extF80M_eq_signaling$(OBJ) \ | ||||
|   extF80M_le_quiet$(OBJ) \ | ||||
|   extF80M_lt_quiet$(OBJ) \ | ||||
|   f128_to_ui32$(OBJ) \ | ||||
|   f128_to_ui64$(OBJ) \ | ||||
|   f128_to_i32$(OBJ) \ | ||||
|   f128_to_i64$(OBJ) \ | ||||
|   f128_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128_to_i32_r_minMag$(OBJ) \ | ||||
|   f128_to_i64_r_minMag$(OBJ) \ | ||||
|   f128_to_f16$(OBJ) \ | ||||
|   f128_to_f32$(OBJ) \ | ||||
|   f128_to_extF80$(OBJ) \ | ||||
|   f128_to_f64$(OBJ) \ | ||||
|   f128_roundToInt$(OBJ) \ | ||||
|   f128_add$(OBJ) \ | ||||
|   f128_sub$(OBJ) \ | ||||
|   f128_mul$(OBJ) \ | ||||
|   f128_mulAdd$(OBJ) \ | ||||
|   f128_div$(OBJ) \ | ||||
|   f128_rem$(OBJ) \ | ||||
|   f128_sqrt$(OBJ) \ | ||||
|   f128_eq$(OBJ) \ | ||||
|   f128_le$(OBJ) \ | ||||
|   f128_lt$(OBJ) \ | ||||
|   f128_eq_signaling$(OBJ) \ | ||||
|   f128_le_quiet$(OBJ) \ | ||||
|   f128_lt_quiet$(OBJ) \ | ||||
|   f128_isSignalingNaN$(OBJ) \ | ||||
|   f128M_to_ui32$(OBJ) \ | ||||
|   f128M_to_ui64$(OBJ) \ | ||||
|   f128M_to_i32$(OBJ) \ | ||||
|   f128M_to_i64$(OBJ) \ | ||||
|   f128M_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128M_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128M_to_i32_r_minMag$(OBJ) \ | ||||
|   f128M_to_i64_r_minMag$(OBJ) \ | ||||
|   f128M_to_f16$(OBJ) \ | ||||
|   f128M_to_f32$(OBJ) \ | ||||
|   f128M_to_extF80M$(OBJ) \ | ||||
|   f128M_to_f64$(OBJ) \ | ||||
|   f128M_roundToInt$(OBJ) \ | ||||
|   f128M_add$(OBJ) \ | ||||
|   f128M_sub$(OBJ) \ | ||||
|   f128M_mul$(OBJ) \ | ||||
|   f128M_mulAdd$(OBJ) \ | ||||
|   f128M_div$(OBJ) \ | ||||
|   f128M_rem$(OBJ) \ | ||||
|   f128M_sqrt$(OBJ) \ | ||||
|   f128M_eq$(OBJ) \ | ||||
|   f128M_le$(OBJ) \ | ||||
|   f128M_lt$(OBJ) \ | ||||
|   f128M_eq_signaling$(OBJ) \ | ||||
|   f128M_le_quiet$(OBJ) \ | ||||
|   f128M_lt_quiet$(OBJ) \ | ||||
|  | ||||
| OBJS_ALL = $(OBJS_PRIMITIVES) $(OBJS_SPECIALIZE) $(OBJS_OTHERS) | ||||
|  | ||||
| $(OBJS_ALL): \ | ||||
|   $(OTHER_HEADERS) platform.h $(SOURCE_DIR)/include/primitiveTypes.h \ | ||||
|   $(SOURCE_DIR)/include/primitives.h | ||||
| $(OBJS_SPECIALIZE) $(OBJS_OTHERS): \ | ||||
|   $(SOURCE_DIR)/include/softfloat_types.h $(SOURCE_DIR)/include/internals.h \ | ||||
|   $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/specialize.h \ | ||||
|   $(SOURCE_DIR)/include/softfloat.h | ||||
|  | ||||
| $(OBJS_PRIMITIVES) $(OBJS_OTHERS): %$(OBJ): $(SOURCE_DIR)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$*.c | ||||
|  | ||||
| $(OBJS_SPECIALIZE): %$(OBJ): $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/$*.c | ||||
|  | ||||
| softfloat$(LIB): $(OBJS_ALL) | ||||
| 	$(DELETE) $@ | ||||
| 	$(MAKELIB) $^ | ||||
|  | ||||
| .PHONY: clean | ||||
| clean: | ||||
| 	$(DELETE) $(OBJS_ALL) softfloat$(LIB) | ||||
|  | ||||
							
								
								
									
										54
									
								
								softfloat/build/Linux-RISCV64-GCC/platform.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								softfloat/build/Linux-RISCV64-GCC/platform.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,54 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define LITTLEENDIAN 1 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #ifdef __GNUC_STDC_INLINE__ | ||||
| #define INLINE inline | ||||
| #else | ||||
| #define INLINE extern inline | ||||
| #endif | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define SOFTFLOAT_BUILTIN_CLZ 1 | ||||
| #define SOFTFLOAT_INTRINSIC_INT128 1 | ||||
| #include "opts-GCC.h" | ||||
|  | ||||
| @@ -1,390 +1,397 @@ | ||||
|  | ||||
| #============================================================================= | ||||
| # | ||||
| # This Makefile is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| # Package, Release 3e, by John R. Hauser. | ||||
| # | ||||
| # Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| # University of California.  All rights reserved. | ||||
| # | ||||
| # Redistribution and use in source and binary forms, with or without | ||||
| # modification, are permitted provided that the following conditions are met: | ||||
| # | ||||
| #  1. Redistributions of source code must retain the above copyright notice, | ||||
| #     this list of conditions, and the following disclaimer. | ||||
| # | ||||
| #  2. Redistributions in binary form must reproduce the above copyright | ||||
| #     notice, this list of conditions, and the following disclaimer in the | ||||
| #     documentation and/or other materials provided with the distribution. | ||||
| # | ||||
| #  3. Neither the name of the University nor the names of its contributors | ||||
| #     may be used to endorse or promote products derived from this software | ||||
| #     without specific prior written permission. | ||||
| # | ||||
| # THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| # DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||||
| # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| # | ||||
| #============================================================================= | ||||
|  | ||||
| SOURCE_DIR ?= ../../source | ||||
| SPECIALIZE_TYPE ?= 8086-SSE | ||||
|  | ||||
| SOFTFLOAT_OPTS ?= \ | ||||
|   -DSOFTFLOAT_ROUND_ODD -DINLINE_LEVEL=5 -DSOFTFLOAT_FAST_DIV32TO16 \ | ||||
|   -DSOFTFLOAT_FAST_DIV64TO32 | ||||
|  | ||||
| DELETE = rm -f | ||||
| C_INCLUDES = -I. -I$(SOURCE_DIR)/$(SPECIALIZE_TYPE) -I$(SOURCE_DIR)/include | ||||
| COMPILE_C = \ | ||||
|   gcc -c -Werror-implicit-function-declaration -DSOFTFLOAT_FAST_INT64 \ | ||||
|     $(SOFTFLOAT_OPTS) $(C_INCLUDES) -O2 -o $@ | ||||
| MAKELIB = ar crs $@ | ||||
|  | ||||
| OBJ = .o | ||||
| LIB = .a | ||||
|  | ||||
| OTHER_HEADERS = $(SOURCE_DIR)/include/opts-GCC.h | ||||
|  | ||||
| .PHONY: all | ||||
| all: softfloat$(LIB) | ||||
|  | ||||
| OBJS_PRIMITIVES = \ | ||||
|   s_eq128$(OBJ) \ | ||||
|   s_le128$(OBJ) \ | ||||
|   s_lt128$(OBJ) \ | ||||
|   s_shortShiftLeft128$(OBJ) \ | ||||
|   s_shortShiftRight128$(OBJ) \ | ||||
|   s_shortShiftRightJam64$(OBJ) \ | ||||
|   s_shortShiftRightJam64Extra$(OBJ) \ | ||||
|   s_shortShiftRightJam128$(OBJ) \ | ||||
|   s_shortShiftRightJam128Extra$(OBJ) \ | ||||
|   s_shiftRightJam32$(OBJ) \ | ||||
|   s_shiftRightJam64$(OBJ) \ | ||||
|   s_shiftRightJam64Extra$(OBJ) \ | ||||
|   s_shiftRightJam128$(OBJ) \ | ||||
|   s_shiftRightJam128Extra$(OBJ) \ | ||||
|   s_shiftRightJam256M$(OBJ) \ | ||||
|   s_countLeadingZeros8$(OBJ) \ | ||||
|   s_countLeadingZeros16$(OBJ) \ | ||||
|   s_countLeadingZeros32$(OBJ) \ | ||||
|   s_countLeadingZeros64$(OBJ) \ | ||||
|   s_add128$(OBJ) \ | ||||
|   s_add256M$(OBJ) \ | ||||
|   s_sub128$(OBJ) \ | ||||
|   s_sub256M$(OBJ) \ | ||||
|   s_mul64ByShifted32To128$(OBJ) \ | ||||
|   s_mul64To128$(OBJ) \ | ||||
|   s_mul128By32$(OBJ) \ | ||||
|   s_mul128To256M$(OBJ) \ | ||||
|   s_approxRecip_1Ks$(OBJ) \ | ||||
|   s_approxRecip32_1$(OBJ) \ | ||||
|   s_approxRecipSqrt_1Ks$(OBJ) \ | ||||
|   s_approxRecipSqrt32_1$(OBJ) \ | ||||
|  | ||||
| OBJS_SPECIALIZE = \ | ||||
|   softfloat_raiseFlags$(OBJ) \ | ||||
|   s_f16UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF16UI$(OBJ) \ | ||||
|   s_propagateNaNF16UI$(OBJ) \ | ||||
|   s_f32UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF32UI$(OBJ) \ | ||||
|   s_propagateNaNF32UI$(OBJ) \ | ||||
|   s_f64UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF64UI$(OBJ) \ | ||||
|   s_propagateNaNF64UI$(OBJ) \ | ||||
|   extF80M_isSignalingNaN$(OBJ) \ | ||||
|   s_extF80UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToExtF80UI$(OBJ) \ | ||||
|   s_propagateNaNExtF80UI$(OBJ) \ | ||||
|   f128M_isSignalingNaN$(OBJ) \ | ||||
|   s_f128UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF128UI$(OBJ) \ | ||||
|   s_propagateNaNF128UI$(OBJ) \ | ||||
|  | ||||
| OBJS_OTHERS = \ | ||||
|   s_roundToUI32$(OBJ) \ | ||||
|   s_roundToUI64$(OBJ) \ | ||||
|   s_roundToI32$(OBJ) \ | ||||
|   s_roundToI64$(OBJ) \ | ||||
|   s_normSubnormalF16Sig$(OBJ) \ | ||||
|   s_roundPackToF16$(OBJ) \ | ||||
|   s_normRoundPackToF16$(OBJ) \ | ||||
|   s_addMagsF16$(OBJ) \ | ||||
|   s_subMagsF16$(OBJ) \ | ||||
|   s_mulAddF16$(OBJ) \ | ||||
|   s_normSubnormalF32Sig$(OBJ) \ | ||||
|   s_roundPackToF32$(OBJ) \ | ||||
|   s_normRoundPackToF32$(OBJ) \ | ||||
|   s_addMagsF32$(OBJ) \ | ||||
|   s_subMagsF32$(OBJ) \ | ||||
|   s_mulAddF32$(OBJ) \ | ||||
|   s_normSubnormalF64Sig$(OBJ) \ | ||||
|   s_roundPackToF64$(OBJ) \ | ||||
|   s_normRoundPackToF64$(OBJ) \ | ||||
|   s_addMagsF64$(OBJ) \ | ||||
|   s_subMagsF64$(OBJ) \ | ||||
|   s_mulAddF64$(OBJ) \ | ||||
|   s_normSubnormalExtF80Sig$(OBJ) \ | ||||
|   s_roundPackToExtF80$(OBJ) \ | ||||
|   s_normRoundPackToExtF80$(OBJ) \ | ||||
|   s_addMagsExtF80$(OBJ) \ | ||||
|   s_subMagsExtF80$(OBJ) \ | ||||
|   s_normSubnormalF128Sig$(OBJ) \ | ||||
|   s_roundPackToF128$(OBJ) \ | ||||
|   s_normRoundPackToF128$(OBJ) \ | ||||
|   s_addMagsF128$(OBJ) \ | ||||
|   s_subMagsF128$(OBJ) \ | ||||
|   s_mulAddF128$(OBJ) \ | ||||
|   softfloat_state$(OBJ) \ | ||||
|   ui32_to_f16$(OBJ) \ | ||||
|   ui32_to_f32$(OBJ) \ | ||||
|   ui32_to_f64$(OBJ) \ | ||||
|   ui32_to_extF80$(OBJ) \ | ||||
|   ui32_to_extF80M$(OBJ) \ | ||||
|   ui32_to_f128$(OBJ) \ | ||||
|   ui32_to_f128M$(OBJ) \ | ||||
|   ui64_to_f16$(OBJ) \ | ||||
|   ui64_to_f32$(OBJ) \ | ||||
|   ui64_to_f64$(OBJ) \ | ||||
|   ui64_to_extF80$(OBJ) \ | ||||
|   ui64_to_extF80M$(OBJ) \ | ||||
|   ui64_to_f128$(OBJ) \ | ||||
|   ui64_to_f128M$(OBJ) \ | ||||
|   i32_to_f16$(OBJ) \ | ||||
|   i32_to_f32$(OBJ) \ | ||||
|   i32_to_f64$(OBJ) \ | ||||
|   i32_to_extF80$(OBJ) \ | ||||
|   i32_to_extF80M$(OBJ) \ | ||||
|   i32_to_f128$(OBJ) \ | ||||
|   i32_to_f128M$(OBJ) \ | ||||
|   i64_to_f16$(OBJ) \ | ||||
|   i64_to_f32$(OBJ) \ | ||||
|   i64_to_f64$(OBJ) \ | ||||
|   i64_to_extF80$(OBJ) \ | ||||
|   i64_to_extF80M$(OBJ) \ | ||||
|   i64_to_f128$(OBJ) \ | ||||
|   i64_to_f128M$(OBJ) \ | ||||
|   f16_to_ui32$(OBJ) \ | ||||
|   f16_to_ui64$(OBJ) \ | ||||
|   f16_to_i32$(OBJ) \ | ||||
|   f16_to_i64$(OBJ) \ | ||||
|   f16_to_ui32_r_minMag$(OBJ) \ | ||||
|   f16_to_ui64_r_minMag$(OBJ) \ | ||||
|   f16_to_i32_r_minMag$(OBJ) \ | ||||
|   f16_to_i64_r_minMag$(OBJ) \ | ||||
|   f16_to_f32$(OBJ) \ | ||||
|   f16_to_f64$(OBJ) \ | ||||
|   f16_to_extF80$(OBJ) \ | ||||
|   f16_to_extF80M$(OBJ) \ | ||||
|   f16_to_f128$(OBJ) \ | ||||
|   f16_to_f128M$(OBJ) \ | ||||
|   f16_roundToInt$(OBJ) \ | ||||
|   f16_add$(OBJ) \ | ||||
|   f16_sub$(OBJ) \ | ||||
|   f16_mul$(OBJ) \ | ||||
|   f16_mulAdd$(OBJ) \ | ||||
|   f16_div$(OBJ) \ | ||||
|   f16_rem$(OBJ) \ | ||||
|   f16_sqrt$(OBJ) \ | ||||
|   f16_eq$(OBJ) \ | ||||
|   f16_le$(OBJ) \ | ||||
|   f16_lt$(OBJ) \ | ||||
|   f16_eq_signaling$(OBJ) \ | ||||
|   f16_le_quiet$(OBJ) \ | ||||
|   f16_lt_quiet$(OBJ) \ | ||||
|   f16_isSignalingNaN$(OBJ) \ | ||||
|   f32_to_ui32$(OBJ) \ | ||||
|   f32_to_ui64$(OBJ) \ | ||||
|   f32_to_i32$(OBJ) \ | ||||
|   f32_to_i64$(OBJ) \ | ||||
|   f32_to_ui32_r_minMag$(OBJ) \ | ||||
|   f32_to_ui64_r_minMag$(OBJ) \ | ||||
|   f32_to_i32_r_minMag$(OBJ) \ | ||||
|   f32_to_i64_r_minMag$(OBJ) \ | ||||
|   f32_to_f16$(OBJ) \ | ||||
|   f32_to_f64$(OBJ) \ | ||||
|   f32_to_extF80$(OBJ) \ | ||||
|   f32_to_extF80M$(OBJ) \ | ||||
|   f32_to_f128$(OBJ) \ | ||||
|   f32_to_f128M$(OBJ) \ | ||||
|   f32_roundToInt$(OBJ) \ | ||||
|   f32_add$(OBJ) \ | ||||
|   f32_sub$(OBJ) \ | ||||
|   f32_mul$(OBJ) \ | ||||
|   f32_mulAdd$(OBJ) \ | ||||
|   f32_div$(OBJ) \ | ||||
|   f32_rem$(OBJ) \ | ||||
|   f32_sqrt$(OBJ) \ | ||||
|   f32_eq$(OBJ) \ | ||||
|   f32_le$(OBJ) \ | ||||
|   f32_lt$(OBJ) \ | ||||
|   f32_eq_signaling$(OBJ) \ | ||||
|   f32_le_quiet$(OBJ) \ | ||||
|   f32_lt_quiet$(OBJ) \ | ||||
|   f32_isSignalingNaN$(OBJ) \ | ||||
|   f64_to_ui32$(OBJ) \ | ||||
|   f64_to_ui64$(OBJ) \ | ||||
|   f64_to_i32$(OBJ) \ | ||||
|   f64_to_i64$(OBJ) \ | ||||
|   f64_to_ui32_r_minMag$(OBJ) \ | ||||
|   f64_to_ui64_r_minMag$(OBJ) \ | ||||
|   f64_to_i32_r_minMag$(OBJ) \ | ||||
|   f64_to_i64_r_minMag$(OBJ) \ | ||||
|   f64_to_f16$(OBJ) \ | ||||
|   f64_to_f32$(OBJ) \ | ||||
|   f64_to_extF80$(OBJ) \ | ||||
|   f64_to_extF80M$(OBJ) \ | ||||
|   f64_to_f128$(OBJ) \ | ||||
|   f64_to_f128M$(OBJ) \ | ||||
|   f64_roundToInt$(OBJ) \ | ||||
|   f64_add$(OBJ) \ | ||||
|   f64_sub$(OBJ) \ | ||||
|   f64_mul$(OBJ) \ | ||||
|   f64_mulAdd$(OBJ) \ | ||||
|   f64_div$(OBJ) \ | ||||
|   f64_rem$(OBJ) \ | ||||
|   f64_sqrt$(OBJ) \ | ||||
|   f64_eq$(OBJ) \ | ||||
|   f64_le$(OBJ) \ | ||||
|   f64_lt$(OBJ) \ | ||||
|   f64_eq_signaling$(OBJ) \ | ||||
|   f64_le_quiet$(OBJ) \ | ||||
|   f64_lt_quiet$(OBJ) \ | ||||
|   f64_isSignalingNaN$(OBJ) \ | ||||
|   extF80_to_ui32$(OBJ) \ | ||||
|   extF80_to_ui64$(OBJ) \ | ||||
|   extF80_to_i32$(OBJ) \ | ||||
|   extF80_to_i64$(OBJ) \ | ||||
|   extF80_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80_to_f16$(OBJ) \ | ||||
|   extF80_to_f32$(OBJ) \ | ||||
|   extF80_to_f64$(OBJ) \ | ||||
|   extF80_to_f128$(OBJ) \ | ||||
|   extF80_roundToInt$(OBJ) \ | ||||
|   extF80_add$(OBJ) \ | ||||
|   extF80_sub$(OBJ) \ | ||||
|   extF80_mul$(OBJ) \ | ||||
|   extF80_div$(OBJ) \ | ||||
|   extF80_rem$(OBJ) \ | ||||
|   extF80_sqrt$(OBJ) \ | ||||
|   extF80_eq$(OBJ) \ | ||||
|   extF80_le$(OBJ) \ | ||||
|   extF80_lt$(OBJ) \ | ||||
|   extF80_eq_signaling$(OBJ) \ | ||||
|   extF80_le_quiet$(OBJ) \ | ||||
|   extF80_lt_quiet$(OBJ) \ | ||||
|   extF80_isSignalingNaN$(OBJ) \ | ||||
|   extF80M_to_ui32$(OBJ) \ | ||||
|   extF80M_to_ui64$(OBJ) \ | ||||
|   extF80M_to_i32$(OBJ) \ | ||||
|   extF80M_to_i64$(OBJ) \ | ||||
|   extF80M_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_f16$(OBJ) \ | ||||
|   extF80M_to_f32$(OBJ) \ | ||||
|   extF80M_to_f64$(OBJ) \ | ||||
|   extF80M_to_f128M$(OBJ) \ | ||||
|   extF80M_roundToInt$(OBJ) \ | ||||
|   extF80M_add$(OBJ) \ | ||||
|   extF80M_sub$(OBJ) \ | ||||
|   extF80M_mul$(OBJ) \ | ||||
|   extF80M_div$(OBJ) \ | ||||
|   extF80M_rem$(OBJ) \ | ||||
|   extF80M_sqrt$(OBJ) \ | ||||
|   extF80M_eq$(OBJ) \ | ||||
|   extF80M_le$(OBJ) \ | ||||
|   extF80M_lt$(OBJ) \ | ||||
|   extF80M_eq_signaling$(OBJ) \ | ||||
|   extF80M_le_quiet$(OBJ) \ | ||||
|   extF80M_lt_quiet$(OBJ) \ | ||||
|   f128_to_ui32$(OBJ) \ | ||||
|   f128_to_ui64$(OBJ) \ | ||||
|   f128_to_i32$(OBJ) \ | ||||
|   f128_to_i64$(OBJ) \ | ||||
|   f128_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128_to_i32_r_minMag$(OBJ) \ | ||||
|   f128_to_i64_r_minMag$(OBJ) \ | ||||
|   f128_to_f16$(OBJ) \ | ||||
|   f128_to_f32$(OBJ) \ | ||||
|   f128_to_extF80$(OBJ) \ | ||||
|   f128_to_f64$(OBJ) \ | ||||
|   f128_roundToInt$(OBJ) \ | ||||
|   f128_add$(OBJ) \ | ||||
|   f128_sub$(OBJ) \ | ||||
|   f128_mul$(OBJ) \ | ||||
|   f128_mulAdd$(OBJ) \ | ||||
|   f128_div$(OBJ) \ | ||||
|   f128_rem$(OBJ) \ | ||||
|   f128_sqrt$(OBJ) \ | ||||
|   f128_eq$(OBJ) \ | ||||
|   f128_le$(OBJ) \ | ||||
|   f128_lt$(OBJ) \ | ||||
|   f128_eq_signaling$(OBJ) \ | ||||
|   f128_le_quiet$(OBJ) \ | ||||
|   f128_lt_quiet$(OBJ) \ | ||||
|   f128_isSignalingNaN$(OBJ) \ | ||||
|   f128M_to_ui32$(OBJ) \ | ||||
|   f128M_to_ui64$(OBJ) \ | ||||
|   f128M_to_i32$(OBJ) \ | ||||
|   f128M_to_i64$(OBJ) \ | ||||
|   f128M_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128M_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128M_to_i32_r_minMag$(OBJ) \ | ||||
|   f128M_to_i64_r_minMag$(OBJ) \ | ||||
|   f128M_to_f16$(OBJ) \ | ||||
|   f128M_to_f32$(OBJ) \ | ||||
|   f128M_to_extF80M$(OBJ) \ | ||||
|   f128M_to_f64$(OBJ) \ | ||||
|   f128M_roundToInt$(OBJ) \ | ||||
|   f128M_add$(OBJ) \ | ||||
|   f128M_sub$(OBJ) \ | ||||
|   f128M_mul$(OBJ) \ | ||||
|   f128M_mulAdd$(OBJ) \ | ||||
|   f128M_div$(OBJ) \ | ||||
|   f128M_rem$(OBJ) \ | ||||
|   f128M_sqrt$(OBJ) \ | ||||
|   f128M_eq$(OBJ) \ | ||||
|   f128M_le$(OBJ) \ | ||||
|   f128M_lt$(OBJ) \ | ||||
|   f128M_eq_signaling$(OBJ) \ | ||||
|   f128M_le_quiet$(OBJ) \ | ||||
|   f128M_lt_quiet$(OBJ) \ | ||||
|  | ||||
| OBJS_ALL = $(OBJS_PRIMITIVES) $(OBJS_SPECIALIZE) $(OBJS_OTHERS) | ||||
|  | ||||
| $(OBJS_ALL): \ | ||||
|   $(OTHER_HEADERS) platform.h $(SOURCE_DIR)/include/primitiveTypes.h \ | ||||
|   $(SOURCE_DIR)/include/primitives.h | ||||
| $(OBJS_SPECIALIZE) $(OBJS_OTHERS): \ | ||||
|   $(SOURCE_DIR)/include/softfloat_types.h $(SOURCE_DIR)/include/internals.h \ | ||||
|   $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/specialize.h \ | ||||
|   $(SOURCE_DIR)/include/softfloat.h | ||||
|  | ||||
| $(OBJS_PRIMITIVES) $(OBJS_OTHERS): %$(OBJ): $(SOURCE_DIR)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$*.c | ||||
|  | ||||
| $(OBJS_SPECIALIZE): %$(OBJ): $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/$*.c | ||||
|  | ||||
| softfloat$(LIB): $(OBJS_ALL) | ||||
| 	$(DELETE) $@ | ||||
| 	$(MAKELIB) $^ | ||||
|  | ||||
| .PHONY: clean | ||||
| clean: | ||||
| 	$(DELETE) $(OBJS_ALL) softfloat$(LIB) | ||||
|  | ||||
|  | ||||
| #============================================================================= | ||||
| # | ||||
| # This Makefile is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| # Package, Release 3e, by John R. Hauser. | ||||
| # | ||||
| # Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| # University of California.  All rights reserved. | ||||
| # | ||||
| # Redistribution and use in source and binary forms, with or without | ||||
| # modification, are permitted provided that the following conditions are met: | ||||
| # | ||||
| #  1. Redistributions of source code must retain the above copyright notice, | ||||
| #     this list of conditions, and the following disclaimer. | ||||
| # | ||||
| #  2. Redistributions in binary form must reproduce the above copyright | ||||
| #     notice, this list of conditions, and the following disclaimer in the | ||||
| #     documentation and/or other materials provided with the distribution. | ||||
| # | ||||
| #  3. Neither the name of the University nor the names of its contributors | ||||
| #     may be used to endorse or promote products derived from this software | ||||
| #     without specific prior written permission. | ||||
| # | ||||
| # THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| # DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||||
| # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| # | ||||
| #============================================================================= | ||||
|  | ||||
| SOURCE_DIR ?= ../../source | ||||
| SPECIALIZE_TYPE ?= 8086-SSE | ||||
|  | ||||
| SOFTFLOAT_OPTS ?= \ | ||||
|   -DSOFTFLOAT_ROUND_ODD -DINLINE_LEVEL=5 -DSOFTFLOAT_FAST_DIV32TO16 \ | ||||
|   -DSOFTFLOAT_FAST_DIV64TO32 | ||||
|  | ||||
| DELETE = rm -f | ||||
| C_INCLUDES = -I. -I$(SOURCE_DIR)/$(SPECIALIZE_TYPE) -I$(SOURCE_DIR)/include | ||||
| COMPILE_C = \ | ||||
|   gcc -c -Werror-implicit-function-declaration -DSOFTFLOAT_FAST_INT64 \ | ||||
|     $(SOFTFLOAT_OPTS) $(C_INCLUDES) -O2 -o $@ | ||||
| MAKELIB = ar crs $@ | ||||
|  | ||||
| OBJ = .o | ||||
| LIB = .a | ||||
|  | ||||
| OTHER_HEADERS = $(SOURCE_DIR)/include/opts-GCC.h | ||||
|  | ||||
| .PHONY: all | ||||
| all: softfloat$(LIB) | ||||
|  | ||||
| OBJS_PRIMITIVES = \ | ||||
|   s_eq128$(OBJ) \ | ||||
|   s_le128$(OBJ) \ | ||||
|   s_lt128$(OBJ) \ | ||||
|   s_shortShiftLeft128$(OBJ) \ | ||||
|   s_shortShiftRight128$(OBJ) \ | ||||
|   s_shortShiftRightJam64$(OBJ) \ | ||||
|   s_shortShiftRightJam64Extra$(OBJ) \ | ||||
|   s_shortShiftRightJam128$(OBJ) \ | ||||
|   s_shortShiftRightJam128Extra$(OBJ) \ | ||||
|   s_shiftRightJam32$(OBJ) \ | ||||
|   s_shiftRightJam64$(OBJ) \ | ||||
|   s_shiftRightJam64Extra$(OBJ) \ | ||||
|   s_shiftRightJam128$(OBJ) \ | ||||
|   s_shiftRightJam128Extra$(OBJ) \ | ||||
|   s_shiftRightJam256M$(OBJ) \ | ||||
|   s_countLeadingZeros8$(OBJ) \ | ||||
|   s_countLeadingZeros16$(OBJ) \ | ||||
|   s_countLeadingZeros32$(OBJ) \ | ||||
|   s_countLeadingZeros64$(OBJ) \ | ||||
|   s_add128$(OBJ) \ | ||||
|   s_add256M$(OBJ) \ | ||||
|   s_sub128$(OBJ) \ | ||||
|   s_sub256M$(OBJ) \ | ||||
|   s_mul64ByShifted32To128$(OBJ) \ | ||||
|   s_mul64To128$(OBJ) \ | ||||
|   s_mul128By32$(OBJ) \ | ||||
|   s_mul128To256M$(OBJ) \ | ||||
|   s_approxRecip_1Ks$(OBJ) \ | ||||
|   s_approxRecip32_1$(OBJ) \ | ||||
|   s_approxRecipSqrt_1Ks$(OBJ) \ | ||||
|   s_approxRecipSqrt32_1$(OBJ) \ | ||||
|  | ||||
| OBJS_SPECIALIZE = \ | ||||
|   softfloat_raiseFlags$(OBJ) \ | ||||
|   s_f16UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF16UI$(OBJ) \ | ||||
|   s_propagateNaNF16UI$(OBJ) \ | ||||
|   s_bf16UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToBF16UI$(OBJ) \ | ||||
|   s_f32UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF32UI$(OBJ) \ | ||||
|   s_propagateNaNF32UI$(OBJ) \ | ||||
|   s_f64UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF64UI$(OBJ) \ | ||||
|   s_propagateNaNF64UI$(OBJ) \ | ||||
|   extF80M_isSignalingNaN$(OBJ) \ | ||||
|   s_extF80UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToExtF80UI$(OBJ) \ | ||||
|   s_propagateNaNExtF80UI$(OBJ) \ | ||||
|   f128M_isSignalingNaN$(OBJ) \ | ||||
|   s_f128UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF128UI$(OBJ) \ | ||||
|   s_propagateNaNF128UI$(OBJ) \ | ||||
|  | ||||
| OBJS_OTHERS = \ | ||||
|   s_roundToUI32$(OBJ) \ | ||||
|   s_roundToUI64$(OBJ) \ | ||||
|   s_roundToI32$(OBJ) \ | ||||
|   s_roundToI64$(OBJ) \ | ||||
|   s_normSubnormalBF16Sig$(OBJ) \ | ||||
|   s_roundPackToBF16$(OBJ) \ | ||||
|   s_normSubnormalF16Sig$(OBJ) \ | ||||
|   s_roundPackToF16$(OBJ) \ | ||||
|   s_normRoundPackToF16$(OBJ) \ | ||||
|   s_addMagsF16$(OBJ) \ | ||||
|   s_subMagsF16$(OBJ) \ | ||||
|   s_mulAddF16$(OBJ) \ | ||||
|   s_normSubnormalF32Sig$(OBJ) \ | ||||
|   s_roundPackToF32$(OBJ) \ | ||||
|   s_normRoundPackToF32$(OBJ) \ | ||||
|   s_addMagsF32$(OBJ) \ | ||||
|   s_subMagsF32$(OBJ) \ | ||||
|   s_mulAddF32$(OBJ) \ | ||||
|   s_normSubnormalF64Sig$(OBJ) \ | ||||
|   s_roundPackToF64$(OBJ) \ | ||||
|   s_normRoundPackToF64$(OBJ) \ | ||||
|   s_addMagsF64$(OBJ) \ | ||||
|   s_subMagsF64$(OBJ) \ | ||||
|   s_mulAddF64$(OBJ) \ | ||||
|   s_normSubnormalExtF80Sig$(OBJ) \ | ||||
|   s_roundPackToExtF80$(OBJ) \ | ||||
|   s_normRoundPackToExtF80$(OBJ) \ | ||||
|   s_addMagsExtF80$(OBJ) \ | ||||
|   s_subMagsExtF80$(OBJ) \ | ||||
|   s_normSubnormalF128Sig$(OBJ) \ | ||||
|   s_roundPackToF128$(OBJ) \ | ||||
|   s_normRoundPackToF128$(OBJ) \ | ||||
|   s_addMagsF128$(OBJ) \ | ||||
|   s_subMagsF128$(OBJ) \ | ||||
|   s_mulAddF128$(OBJ) \ | ||||
|   softfloat_state$(OBJ) \ | ||||
|   ui32_to_f16$(OBJ) \ | ||||
|   ui32_to_f32$(OBJ) \ | ||||
|   ui32_to_f64$(OBJ) \ | ||||
|   ui32_to_extF80$(OBJ) \ | ||||
|   ui32_to_extF80M$(OBJ) \ | ||||
|   ui32_to_f128$(OBJ) \ | ||||
|   ui32_to_f128M$(OBJ) \ | ||||
|   ui64_to_f16$(OBJ) \ | ||||
|   ui64_to_f32$(OBJ) \ | ||||
|   ui64_to_f64$(OBJ) \ | ||||
|   ui64_to_extF80$(OBJ) \ | ||||
|   ui64_to_extF80M$(OBJ) \ | ||||
|   ui64_to_f128$(OBJ) \ | ||||
|   ui64_to_f128M$(OBJ) \ | ||||
|   i32_to_f16$(OBJ) \ | ||||
|   i32_to_f32$(OBJ) \ | ||||
|   i32_to_f64$(OBJ) \ | ||||
|   i32_to_extF80$(OBJ) \ | ||||
|   i32_to_extF80M$(OBJ) \ | ||||
|   i32_to_f128$(OBJ) \ | ||||
|   i32_to_f128M$(OBJ) \ | ||||
|   i64_to_f16$(OBJ) \ | ||||
|   i64_to_f32$(OBJ) \ | ||||
|   i64_to_f64$(OBJ) \ | ||||
|   i64_to_extF80$(OBJ) \ | ||||
|   i64_to_extF80M$(OBJ) \ | ||||
|   i64_to_f128$(OBJ) \ | ||||
|   i64_to_f128M$(OBJ) \ | ||||
|   bf16_isSignalingNaN$(OBJ) \ | ||||
|   bf16_to_f32$(OBJ) \ | ||||
|   f16_to_ui32$(OBJ) \ | ||||
|   f16_to_ui64$(OBJ) \ | ||||
|   f16_to_i32$(OBJ) \ | ||||
|   f16_to_i64$(OBJ) \ | ||||
|   f16_to_ui32_r_minMag$(OBJ) \ | ||||
|   f16_to_ui64_r_minMag$(OBJ) \ | ||||
|   f16_to_i32_r_minMag$(OBJ) \ | ||||
|   f16_to_i64_r_minMag$(OBJ) \ | ||||
|   f16_to_f32$(OBJ) \ | ||||
|   f16_to_f64$(OBJ) \ | ||||
|   f16_to_extF80$(OBJ) \ | ||||
|   f16_to_extF80M$(OBJ) \ | ||||
|   f16_to_f128$(OBJ) \ | ||||
|   f16_to_f128M$(OBJ) \ | ||||
|   f16_roundToInt$(OBJ) \ | ||||
|   f16_add$(OBJ) \ | ||||
|   f16_sub$(OBJ) \ | ||||
|   f16_mul$(OBJ) \ | ||||
|   f16_mulAdd$(OBJ) \ | ||||
|   f16_div$(OBJ) \ | ||||
|   f16_rem$(OBJ) \ | ||||
|   f16_sqrt$(OBJ) \ | ||||
|   f16_eq$(OBJ) \ | ||||
|   f16_le$(OBJ) \ | ||||
|   f16_lt$(OBJ) \ | ||||
|   f16_eq_signaling$(OBJ) \ | ||||
|   f16_le_quiet$(OBJ) \ | ||||
|   f16_lt_quiet$(OBJ) \ | ||||
|   f16_isSignalingNaN$(OBJ) \ | ||||
|   f32_to_ui32$(OBJ) \ | ||||
|   f32_to_ui64$(OBJ) \ | ||||
|   f32_to_i32$(OBJ) \ | ||||
|   f32_to_i64$(OBJ) \ | ||||
|   f32_to_ui32_r_minMag$(OBJ) \ | ||||
|   f32_to_ui64_r_minMag$(OBJ) \ | ||||
|   f32_to_i32_r_minMag$(OBJ) \ | ||||
|   f32_to_i64_r_minMag$(OBJ) \ | ||||
|   f32_to_bf16$(OBJ) \ | ||||
|   f32_to_f16$(OBJ) \ | ||||
|   f32_to_f64$(OBJ) \ | ||||
|   f32_to_extF80$(OBJ) \ | ||||
|   f32_to_extF80M$(OBJ) \ | ||||
|   f32_to_f128$(OBJ) \ | ||||
|   f32_to_f128M$(OBJ) \ | ||||
|   f32_roundToInt$(OBJ) \ | ||||
|   f32_add$(OBJ) \ | ||||
|   f32_sub$(OBJ) \ | ||||
|   f32_mul$(OBJ) \ | ||||
|   f32_mulAdd$(OBJ) \ | ||||
|   f32_div$(OBJ) \ | ||||
|   f32_rem$(OBJ) \ | ||||
|   f32_sqrt$(OBJ) \ | ||||
|   f32_eq$(OBJ) \ | ||||
|   f32_le$(OBJ) \ | ||||
|   f32_lt$(OBJ) \ | ||||
|   f32_eq_signaling$(OBJ) \ | ||||
|   f32_le_quiet$(OBJ) \ | ||||
|   f32_lt_quiet$(OBJ) \ | ||||
|   f32_isSignalingNaN$(OBJ) \ | ||||
|   f64_to_ui32$(OBJ) \ | ||||
|   f64_to_ui64$(OBJ) \ | ||||
|   f64_to_i32$(OBJ) \ | ||||
|   f64_to_i64$(OBJ) \ | ||||
|   f64_to_ui32_r_minMag$(OBJ) \ | ||||
|   f64_to_ui64_r_minMag$(OBJ) \ | ||||
|   f64_to_i32_r_minMag$(OBJ) \ | ||||
|   f64_to_i64_r_minMag$(OBJ) \ | ||||
|   f64_to_f16$(OBJ) \ | ||||
|   f64_to_f32$(OBJ) \ | ||||
|   f64_to_extF80$(OBJ) \ | ||||
|   f64_to_extF80M$(OBJ) \ | ||||
|   f64_to_f128$(OBJ) \ | ||||
|   f64_to_f128M$(OBJ) \ | ||||
|   f64_roundToInt$(OBJ) \ | ||||
|   f64_add$(OBJ) \ | ||||
|   f64_sub$(OBJ) \ | ||||
|   f64_mul$(OBJ) \ | ||||
|   f64_mulAdd$(OBJ) \ | ||||
|   f64_div$(OBJ) \ | ||||
|   f64_rem$(OBJ) \ | ||||
|   f64_sqrt$(OBJ) \ | ||||
|   f64_eq$(OBJ) \ | ||||
|   f64_le$(OBJ) \ | ||||
|   f64_lt$(OBJ) \ | ||||
|   f64_eq_signaling$(OBJ) \ | ||||
|   f64_le_quiet$(OBJ) \ | ||||
|   f64_lt_quiet$(OBJ) \ | ||||
|   f64_isSignalingNaN$(OBJ) \ | ||||
|   extF80_to_ui32$(OBJ) \ | ||||
|   extF80_to_ui64$(OBJ) \ | ||||
|   extF80_to_i32$(OBJ) \ | ||||
|   extF80_to_i64$(OBJ) \ | ||||
|   extF80_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80_to_f16$(OBJ) \ | ||||
|   extF80_to_f32$(OBJ) \ | ||||
|   extF80_to_f64$(OBJ) \ | ||||
|   extF80_to_f128$(OBJ) \ | ||||
|   extF80_roundToInt$(OBJ) \ | ||||
|   extF80_add$(OBJ) \ | ||||
|   extF80_sub$(OBJ) \ | ||||
|   extF80_mul$(OBJ) \ | ||||
|   extF80_div$(OBJ) \ | ||||
|   extF80_rem$(OBJ) \ | ||||
|   extF80_sqrt$(OBJ) \ | ||||
|   extF80_eq$(OBJ) \ | ||||
|   extF80_le$(OBJ) \ | ||||
|   extF80_lt$(OBJ) \ | ||||
|   extF80_eq_signaling$(OBJ) \ | ||||
|   extF80_le_quiet$(OBJ) \ | ||||
|   extF80_lt_quiet$(OBJ) \ | ||||
|   extF80_isSignalingNaN$(OBJ) \ | ||||
|   extF80M_to_ui32$(OBJ) \ | ||||
|   extF80M_to_ui64$(OBJ) \ | ||||
|   extF80M_to_i32$(OBJ) \ | ||||
|   extF80M_to_i64$(OBJ) \ | ||||
|   extF80M_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_f16$(OBJ) \ | ||||
|   extF80M_to_f32$(OBJ) \ | ||||
|   extF80M_to_f64$(OBJ) \ | ||||
|   extF80M_to_f128M$(OBJ) \ | ||||
|   extF80M_roundToInt$(OBJ) \ | ||||
|   extF80M_add$(OBJ) \ | ||||
|   extF80M_sub$(OBJ) \ | ||||
|   extF80M_mul$(OBJ) \ | ||||
|   extF80M_div$(OBJ) \ | ||||
|   extF80M_rem$(OBJ) \ | ||||
|   extF80M_sqrt$(OBJ) \ | ||||
|   extF80M_eq$(OBJ) \ | ||||
|   extF80M_le$(OBJ) \ | ||||
|   extF80M_lt$(OBJ) \ | ||||
|   extF80M_eq_signaling$(OBJ) \ | ||||
|   extF80M_le_quiet$(OBJ) \ | ||||
|   extF80M_lt_quiet$(OBJ) \ | ||||
|   f128_to_ui32$(OBJ) \ | ||||
|   f128_to_ui64$(OBJ) \ | ||||
|   f128_to_i32$(OBJ) \ | ||||
|   f128_to_i64$(OBJ) \ | ||||
|   f128_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128_to_i32_r_minMag$(OBJ) \ | ||||
|   f128_to_i64_r_minMag$(OBJ) \ | ||||
|   f128_to_f16$(OBJ) \ | ||||
|   f128_to_f32$(OBJ) \ | ||||
|   f128_to_extF80$(OBJ) \ | ||||
|   f128_to_f64$(OBJ) \ | ||||
|   f128_roundToInt$(OBJ) \ | ||||
|   f128_add$(OBJ) \ | ||||
|   f128_sub$(OBJ) \ | ||||
|   f128_mul$(OBJ) \ | ||||
|   f128_mulAdd$(OBJ) \ | ||||
|   f128_div$(OBJ) \ | ||||
|   f128_rem$(OBJ) \ | ||||
|   f128_sqrt$(OBJ) \ | ||||
|   f128_eq$(OBJ) \ | ||||
|   f128_le$(OBJ) \ | ||||
|   f128_lt$(OBJ) \ | ||||
|   f128_eq_signaling$(OBJ) \ | ||||
|   f128_le_quiet$(OBJ) \ | ||||
|   f128_lt_quiet$(OBJ) \ | ||||
|   f128_isSignalingNaN$(OBJ) \ | ||||
|   f128M_to_ui32$(OBJ) \ | ||||
|   f128M_to_ui64$(OBJ) \ | ||||
|   f128M_to_i32$(OBJ) \ | ||||
|   f128M_to_i64$(OBJ) \ | ||||
|   f128M_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128M_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128M_to_i32_r_minMag$(OBJ) \ | ||||
|   f128M_to_i64_r_minMag$(OBJ) \ | ||||
|   f128M_to_f16$(OBJ) \ | ||||
|   f128M_to_f32$(OBJ) \ | ||||
|   f128M_to_extF80M$(OBJ) \ | ||||
|   f128M_to_f64$(OBJ) \ | ||||
|   f128M_roundToInt$(OBJ) \ | ||||
|   f128M_add$(OBJ) \ | ||||
|   f128M_sub$(OBJ) \ | ||||
|   f128M_mul$(OBJ) \ | ||||
|   f128M_mulAdd$(OBJ) \ | ||||
|   f128M_div$(OBJ) \ | ||||
|   f128M_rem$(OBJ) \ | ||||
|   f128M_sqrt$(OBJ) \ | ||||
|   f128M_eq$(OBJ) \ | ||||
|   f128M_le$(OBJ) \ | ||||
|   f128M_lt$(OBJ) \ | ||||
|   f128M_eq_signaling$(OBJ) \ | ||||
|   f128M_le_quiet$(OBJ) \ | ||||
|   f128M_lt_quiet$(OBJ) \ | ||||
|  | ||||
| OBJS_ALL = $(OBJS_PRIMITIVES) $(OBJS_SPECIALIZE) $(OBJS_OTHERS) | ||||
|  | ||||
| $(OBJS_ALL): \ | ||||
|   $(OTHER_HEADERS) platform.h $(SOURCE_DIR)/include/primitiveTypes.h \ | ||||
|   $(SOURCE_DIR)/include/primitives.h | ||||
| $(OBJS_SPECIALIZE) $(OBJS_OTHERS): \ | ||||
|   $(SOURCE_DIR)/include/softfloat_types.h $(SOURCE_DIR)/include/internals.h \ | ||||
|   $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/specialize.h \ | ||||
|   $(SOURCE_DIR)/include/softfloat.h | ||||
|  | ||||
| $(OBJS_PRIMITIVES) $(OBJS_OTHERS): %$(OBJ): $(SOURCE_DIR)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$*.c | ||||
|  | ||||
| $(OBJS_SPECIALIZE): %$(OBJ): $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/$*.c | ||||
|  | ||||
| softfloat$(LIB): $(OBJS_ALL) | ||||
| 	$(DELETE) $@ | ||||
| 	$(MAKELIB) $^ | ||||
|  | ||||
| .PHONY: clean | ||||
| clean: | ||||
| 	$(DELETE) $(OBJS_ALL) softfloat$(LIB) | ||||
|  | ||||
|   | ||||
| @@ -1,56 +1,56 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #define LITTLEENDIAN 1 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #ifdef __GNUC_STDC_INLINE__ | ||||
| //#define INLINE inline | ||||
| #define INLINE static | ||||
| #else | ||||
| #define INLINE extern inline | ||||
| #endif | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #ifdef __GNUC__ | ||||
| #define SOFTFLOAT_BUILTIN_CLZ 1 | ||||
| #define SOFTFLOAT_INTRINSIC_INT128 1 | ||||
| #endif | ||||
| #include "opts-GCC.h" | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #define LITTLEENDIAN 1 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #ifdef __GNUC_STDC_INLINE__ | ||||
| //#define INLINE inline | ||||
| #define INLINE static | ||||
| #else | ||||
| #define INLINE extern inline | ||||
| #endif | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #ifdef __GNUC__ | ||||
| #define SOFTFLOAT_BUILTIN_CLZ 1 | ||||
| #define SOFTFLOAT_INTRINSIC_INT128 1 | ||||
| #endif | ||||
| #include "opts-GCC.h" | ||||
|   | ||||
| @@ -1,325 +1,325 @@ | ||||
|  | ||||
| #============================================================================= | ||||
| # | ||||
| # This Makefile is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| # Package, Release 3e, by John R. Hauser. | ||||
| # | ||||
| # Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| # University of California.  All rights reserved. | ||||
| # | ||||
| # Redistribution and use in source and binary forms, with or without | ||||
| # modification, are permitted provided that the following conditions are met: | ||||
| # | ||||
| #  1. Redistributions of source code must retain the above copyright notice, | ||||
| #     this list of conditions, and the following disclaimer. | ||||
| # | ||||
| #  2. Redistributions in binary form must reproduce the above copyright | ||||
| #     notice, this list of conditions, and the following disclaimer in the | ||||
| #     documentation and/or other materials provided with the distribution. | ||||
| # | ||||
| #  3. Neither the name of the University nor the names of its contributors | ||||
| #     may be used to endorse or promote products derived from this software | ||||
| #     without specific prior written permission. | ||||
| # | ||||
| # THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| # DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||||
| # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| # | ||||
| #============================================================================= | ||||
|  | ||||
| SOURCE_DIR ?= ../../source | ||||
| SPECIALIZE_TYPE ?= 8086 | ||||
|  | ||||
| SOFTFLOAT_OPTS ?= \ | ||||
|   -DSOFTFLOAT_ROUND_ODD -DINLINE_LEVEL=5 -DSOFTFLOAT_FAST_DIV32TO16 \ | ||||
|   -DSOFTFLOAT_FAST_DIV64TO32 | ||||
|  | ||||
| DELETE = rm -f | ||||
| C_INCLUDES = -I. -I$(SOURCE_DIR)/$(SPECIALIZE_TYPE) -I$(SOURCE_DIR)/include | ||||
| COMPILE_C = \ | ||||
|   gcc -c -Werror-implicit-function-declaration $(SOFTFLOAT_OPTS) \ | ||||
|     $(C_INCLUDES) -O2 -o $@ | ||||
| MAKELIB = ar crs $@ | ||||
|  | ||||
| OBJ = .o | ||||
| LIB = .a | ||||
|  | ||||
| OTHER_HEADERS = | ||||
|  | ||||
| .PHONY: all | ||||
| all: softfloat$(LIB) | ||||
|  | ||||
| OBJS_PRIMITIVES = \ | ||||
|   s_compare96M$(OBJ) \ | ||||
|   s_compare128M$(OBJ) \ | ||||
|   s_shortShiftLeft64To96M$(OBJ) \ | ||||
|   s_shortShiftLeftM$(OBJ) \ | ||||
|   s_shiftLeftM$(OBJ) \ | ||||
|   s_shortShiftRightM$(OBJ) \ | ||||
|   s_shortShiftRightJam64$(OBJ) \ | ||||
|   s_shortShiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightJam32$(OBJ) \ | ||||
|   s_shiftRightJam64$(OBJ) \ | ||||
|   s_shiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightM$(OBJ) \ | ||||
|   s_countLeadingZeros8$(OBJ) \ | ||||
|   s_countLeadingZeros16$(OBJ) \ | ||||
|   s_countLeadingZeros32$(OBJ) \ | ||||
|   s_countLeadingZeros64$(OBJ) \ | ||||
|   s_addM$(OBJ) \ | ||||
|   s_addCarryM$(OBJ) \ | ||||
|   s_addComplCarryM$(OBJ) \ | ||||
|   s_negXM$(OBJ) \ | ||||
|   s_sub1XM$(OBJ) \ | ||||
|   s_subM$(OBJ) \ | ||||
|   s_mul64To128M$(OBJ) \ | ||||
|   s_mul128MTo256M$(OBJ) \ | ||||
|   s_approxRecip_1Ks$(OBJ) \ | ||||
|   s_approxRecip32_1$(OBJ) \ | ||||
|   s_approxRecipSqrt_1Ks$(OBJ) \ | ||||
|   s_approxRecipSqrt32_1$(OBJ) \ | ||||
|   s_remStepMBy32$(OBJ) \ | ||||
|  | ||||
| OBJS_SPECIALIZE = \ | ||||
|   softfloat_raiseFlags$(OBJ) \ | ||||
|   s_f16UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF16UI$(OBJ) \ | ||||
|   s_propagateNaNF16UI$(OBJ) \ | ||||
|   s_f32UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF32UI$(OBJ) \ | ||||
|   s_propagateNaNF32UI$(OBJ) \ | ||||
|   s_f64UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF64UI$(OBJ) \ | ||||
|   s_propagateNaNF64UI$(OBJ) \ | ||||
|   extF80M_isSignalingNaN$(OBJ) \ | ||||
|   s_extF80MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToExtF80M$(OBJ) \ | ||||
|   s_propagateNaNExtF80M$(OBJ) \ | ||||
|   f128M_isSignalingNaN$(OBJ) \ | ||||
|   s_f128MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF128M$(OBJ) \ | ||||
|   s_propagateNaNF128M$(OBJ) \ | ||||
|  | ||||
| OBJS_OTHERS = \ | ||||
|   s_roundToUI32$(OBJ) \ | ||||
|   s_roundMToUI64$(OBJ) \ | ||||
|   s_roundToI32$(OBJ) \ | ||||
|   s_roundMToI64$(OBJ) \ | ||||
|   s_normSubnormalF16Sig$(OBJ) \ | ||||
|   s_roundPackToF16$(OBJ) \ | ||||
|   s_normRoundPackToF16$(OBJ) \ | ||||
|   s_addMagsF16$(OBJ) \ | ||||
|   s_subMagsF16$(OBJ) \ | ||||
|   s_mulAddF16$(OBJ) \ | ||||
|   s_normSubnormalF32Sig$(OBJ) \ | ||||
|   s_roundPackToF32$(OBJ) \ | ||||
|   s_normRoundPackToF32$(OBJ) \ | ||||
|   s_addMagsF32$(OBJ) \ | ||||
|   s_subMagsF32$(OBJ) \ | ||||
|   s_mulAddF32$(OBJ) \ | ||||
|   s_normSubnormalF64Sig$(OBJ) \ | ||||
|   s_roundPackToF64$(OBJ) \ | ||||
|   s_normRoundPackToF64$(OBJ) \ | ||||
|   s_addMagsF64$(OBJ) \ | ||||
|   s_subMagsF64$(OBJ) \ | ||||
|   s_mulAddF64$(OBJ) \ | ||||
|   s_tryPropagateNaNExtF80M$(OBJ) \ | ||||
|   s_invalidExtF80M$(OBJ) \ | ||||
|   s_normExtF80SigM$(OBJ) \ | ||||
|   s_roundPackMToExtF80M$(OBJ) \ | ||||
|   s_normRoundPackMToExtF80M$(OBJ) \ | ||||
|   s_addExtF80M$(OBJ) \ | ||||
|   s_compareNonnormExtF80M$(OBJ) \ | ||||
|   s_isNaNF128M$(OBJ) \ | ||||
|   s_tryPropagateNaNF128M$(OBJ) \ | ||||
|   s_invalidF128M$(OBJ) \ | ||||
|   s_shiftNormSigF128M$(OBJ) \ | ||||
|   s_roundPackMToF128M$(OBJ) \ | ||||
|   s_normRoundPackMToF128M$(OBJ) \ | ||||
|   s_addF128M$(OBJ) \ | ||||
|   s_mulAddF128M$(OBJ) \ | ||||
|   softfloat_state$(OBJ) \ | ||||
|   ui32_to_f16$(OBJ) \ | ||||
|   ui32_to_f32$(OBJ) \ | ||||
|   ui32_to_f64$(OBJ) \ | ||||
|   ui32_to_extF80M$(OBJ) \ | ||||
|   ui32_to_f128M$(OBJ) \ | ||||
|   ui64_to_f16$(OBJ) \ | ||||
|   ui64_to_f32$(OBJ) \ | ||||
|   ui64_to_f64$(OBJ) \ | ||||
|   ui64_to_extF80M$(OBJ) \ | ||||
|   ui64_to_f128M$(OBJ) \ | ||||
|   i32_to_f16$(OBJ) \ | ||||
|   i32_to_f32$(OBJ) \ | ||||
|   i32_to_f64$(OBJ) \ | ||||
|   i32_to_extF80M$(OBJ) \ | ||||
|   i32_to_f128M$(OBJ) \ | ||||
|   i64_to_f16$(OBJ) \ | ||||
|   i64_to_f32$(OBJ) \ | ||||
|   i64_to_f64$(OBJ) \ | ||||
|   i64_to_extF80M$(OBJ) \ | ||||
|   i64_to_f128M$(OBJ) \ | ||||
|   f16_to_ui32$(OBJ) \ | ||||
|   f16_to_ui64$(OBJ) \ | ||||
|   f16_to_i32$(OBJ) \ | ||||
|   f16_to_i64$(OBJ) \ | ||||
|   f16_to_ui32_r_minMag$(OBJ) \ | ||||
|   f16_to_ui64_r_minMag$(OBJ) \ | ||||
|   f16_to_i32_r_minMag$(OBJ) \ | ||||
|   f16_to_i64_r_minMag$(OBJ) \ | ||||
|   f16_to_f32$(OBJ) \ | ||||
|   f16_to_f64$(OBJ) \ | ||||
|   f16_to_extF80M$(OBJ) \ | ||||
|   f16_to_f128M$(OBJ) \ | ||||
|   f16_roundToInt$(OBJ) \ | ||||
|   f16_add$(OBJ) \ | ||||
|   f16_sub$(OBJ) \ | ||||
|   f16_mul$(OBJ) \ | ||||
|   f16_mulAdd$(OBJ) \ | ||||
|   f16_div$(OBJ) \ | ||||
|   f16_rem$(OBJ) \ | ||||
|   f16_sqrt$(OBJ) \ | ||||
|   f16_eq$(OBJ) \ | ||||
|   f16_le$(OBJ) \ | ||||
|   f16_lt$(OBJ) \ | ||||
|   f16_eq_signaling$(OBJ) \ | ||||
|   f16_le_quiet$(OBJ) \ | ||||
|   f16_lt_quiet$(OBJ) \ | ||||
|   f16_isSignalingNaN$(OBJ) \ | ||||
|   f32_to_ui32$(OBJ) \ | ||||
|   f32_to_ui64$(OBJ) \ | ||||
|   f32_to_i32$(OBJ) \ | ||||
|   f32_to_i64$(OBJ) \ | ||||
|   f32_to_ui32_r_minMag$(OBJ) \ | ||||
|   f32_to_ui64_r_minMag$(OBJ) \ | ||||
|   f32_to_i32_r_minMag$(OBJ) \ | ||||
|   f32_to_i64_r_minMag$(OBJ) \ | ||||
|   f32_to_f16$(OBJ) \ | ||||
|   f32_to_f64$(OBJ) \ | ||||
|   f32_to_extF80M$(OBJ) \ | ||||
|   f32_to_f128M$(OBJ) \ | ||||
|   f32_roundToInt$(OBJ) \ | ||||
|   f32_add$(OBJ) \ | ||||
|   f32_sub$(OBJ) \ | ||||
|   f32_mul$(OBJ) \ | ||||
|   f32_mulAdd$(OBJ) \ | ||||
|   f32_div$(OBJ) \ | ||||
|   f32_rem$(OBJ) \ | ||||
|   f32_sqrt$(OBJ) \ | ||||
|   f32_eq$(OBJ) \ | ||||
|   f32_le$(OBJ) \ | ||||
|   f32_lt$(OBJ) \ | ||||
|   f32_eq_signaling$(OBJ) \ | ||||
|   f32_le_quiet$(OBJ) \ | ||||
|   f32_lt_quiet$(OBJ) \ | ||||
|   f32_isSignalingNaN$(OBJ) \ | ||||
|   f64_to_ui32$(OBJ) \ | ||||
|   f64_to_ui64$(OBJ) \ | ||||
|   f64_to_i32$(OBJ) \ | ||||
|   f64_to_i64$(OBJ) \ | ||||
|   f64_to_ui32_r_minMag$(OBJ) \ | ||||
|   f64_to_ui64_r_minMag$(OBJ) \ | ||||
|   f64_to_i32_r_minMag$(OBJ) \ | ||||
|   f64_to_i64_r_minMag$(OBJ) \ | ||||
|   f64_to_f16$(OBJ) \ | ||||
|   f64_to_f32$(OBJ) \ | ||||
|   f64_to_extF80M$(OBJ) \ | ||||
|   f64_to_f128M$(OBJ) \ | ||||
|   f64_roundToInt$(OBJ) \ | ||||
|   f64_add$(OBJ) \ | ||||
|   f64_sub$(OBJ) \ | ||||
|   f64_mul$(OBJ) \ | ||||
|   f64_mulAdd$(OBJ) \ | ||||
|   f64_div$(OBJ) \ | ||||
|   f64_rem$(OBJ) \ | ||||
|   f64_sqrt$(OBJ) \ | ||||
|   f64_eq$(OBJ) \ | ||||
|   f64_le$(OBJ) \ | ||||
|   f64_lt$(OBJ) \ | ||||
|   f64_eq_signaling$(OBJ) \ | ||||
|   f64_le_quiet$(OBJ) \ | ||||
|   f64_lt_quiet$(OBJ) \ | ||||
|   f64_isSignalingNaN$(OBJ) \ | ||||
|   extF80M_to_ui32$(OBJ) \ | ||||
|   extF80M_to_ui64$(OBJ) \ | ||||
|   extF80M_to_i32$(OBJ) \ | ||||
|   extF80M_to_i64$(OBJ) \ | ||||
|   extF80M_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_f16$(OBJ) \ | ||||
|   extF80M_to_f32$(OBJ) \ | ||||
|   extF80M_to_f64$(OBJ) \ | ||||
|   extF80M_to_f128M$(OBJ) \ | ||||
|   extF80M_roundToInt$(OBJ) \ | ||||
|   extF80M_add$(OBJ) \ | ||||
|   extF80M_sub$(OBJ) \ | ||||
|   extF80M_mul$(OBJ) \ | ||||
|   extF80M_div$(OBJ) \ | ||||
|   extF80M_rem$(OBJ) \ | ||||
|   extF80M_sqrt$(OBJ) \ | ||||
|   extF80M_eq$(OBJ) \ | ||||
|   extF80M_le$(OBJ) \ | ||||
|   extF80M_lt$(OBJ) \ | ||||
|   extF80M_eq_signaling$(OBJ) \ | ||||
|   extF80M_le_quiet$(OBJ) \ | ||||
|   extF80M_lt_quiet$(OBJ) \ | ||||
|   f128M_to_ui32$(OBJ) \ | ||||
|   f128M_to_ui64$(OBJ) \ | ||||
|   f128M_to_i32$(OBJ) \ | ||||
|   f128M_to_i64$(OBJ) \ | ||||
|   f128M_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128M_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128M_to_i32_r_minMag$(OBJ) \ | ||||
|   f128M_to_i64_r_minMag$(OBJ) \ | ||||
|   f128M_to_f16$(OBJ) \ | ||||
|   f128M_to_f32$(OBJ) \ | ||||
|   f128M_to_f64$(OBJ) \ | ||||
|   f128M_to_extF80M$(OBJ) \ | ||||
|   f128M_roundToInt$(OBJ) \ | ||||
|   f128M_add$(OBJ) \ | ||||
|   f128M_sub$(OBJ) \ | ||||
|   f128M_mul$(OBJ) \ | ||||
|   f128M_mulAdd$(OBJ) \ | ||||
|   f128M_div$(OBJ) \ | ||||
|   f128M_rem$(OBJ) \ | ||||
|   f128M_sqrt$(OBJ) \ | ||||
|   f128M_eq$(OBJ) \ | ||||
|   f128M_le$(OBJ) \ | ||||
|   f128M_lt$(OBJ) \ | ||||
|   f128M_eq_signaling$(OBJ) \ | ||||
|   f128M_le_quiet$(OBJ) \ | ||||
|   f128M_lt_quiet$(OBJ) \ | ||||
|  | ||||
| OBJS_ALL = $(OBJS_PRIMITIVES) $(OBJS_SPECIALIZE) $(OBJS_OTHERS) | ||||
|  | ||||
| $(OBJS_ALL): \ | ||||
|   $(OTHER_HEADERS) platform.h $(SOURCE_DIR)/include/primitiveTypes.h \ | ||||
|   $(SOURCE_DIR)/include/primitives.h | ||||
| $(OBJS_SPECIALIZE) $(OBJS_OTHERS): \ | ||||
|   $(SOURCE_DIR)/include/softfloat_types.h $(SOURCE_DIR)/include/internals.h \ | ||||
|   $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/specialize.h \ | ||||
|   $(SOURCE_DIR)/include/softfloat.h | ||||
|  | ||||
| $(OBJS_PRIMITIVES) $(OBJS_OTHERS): %$(OBJ): $(SOURCE_DIR)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$*.c | ||||
|  | ||||
| $(OBJS_SPECIALIZE): %$(OBJ): $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/$*.c | ||||
|  | ||||
| softfloat$(LIB): $(OBJS_ALL) | ||||
| 	$(DELETE) $@ | ||||
| 	$(MAKELIB) $^ | ||||
|  | ||||
| .PHONY: clean | ||||
| clean: | ||||
| 	$(DELETE) $(OBJS_ALL) softfloat$(LIB) | ||||
|  | ||||
|  | ||||
| #============================================================================= | ||||
| # | ||||
| # This Makefile is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| # Package, Release 3e, by John R. Hauser. | ||||
| # | ||||
| # Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| # University of California.  All rights reserved. | ||||
| # | ||||
| # Redistribution and use in source and binary forms, with or without | ||||
| # modification, are permitted provided that the following conditions are met: | ||||
| # | ||||
| #  1. Redistributions of source code must retain the above copyright notice, | ||||
| #     this list of conditions, and the following disclaimer. | ||||
| # | ||||
| #  2. Redistributions in binary form must reproduce the above copyright | ||||
| #     notice, this list of conditions, and the following disclaimer in the | ||||
| #     documentation and/or other materials provided with the distribution. | ||||
| # | ||||
| #  3. Neither the name of the University nor the names of its contributors | ||||
| #     may be used to endorse or promote products derived from this software | ||||
| #     without specific prior written permission. | ||||
| # | ||||
| # THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| # DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||||
| # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| # | ||||
| #============================================================================= | ||||
|  | ||||
| SOURCE_DIR ?= ../../source | ||||
| SPECIALIZE_TYPE ?= 8086 | ||||
|  | ||||
| SOFTFLOAT_OPTS ?= \ | ||||
|   -DSOFTFLOAT_ROUND_ODD -DINLINE_LEVEL=5 -DSOFTFLOAT_FAST_DIV32TO16 \ | ||||
|   -DSOFTFLOAT_FAST_DIV64TO32 | ||||
|  | ||||
| DELETE = rm -f | ||||
| C_INCLUDES = -I. -I$(SOURCE_DIR)/$(SPECIALIZE_TYPE) -I$(SOURCE_DIR)/include | ||||
| COMPILE_C = \ | ||||
|   gcc -c -Werror-implicit-function-declaration $(SOFTFLOAT_OPTS) \ | ||||
|     $(C_INCLUDES) -O2 -o $@ | ||||
| MAKELIB = ar crs $@ | ||||
|  | ||||
| OBJ = .o | ||||
| LIB = .a | ||||
|  | ||||
| OTHER_HEADERS = | ||||
|  | ||||
| .PHONY: all | ||||
| all: softfloat$(LIB) | ||||
|  | ||||
| OBJS_PRIMITIVES = \ | ||||
|   s_compare96M$(OBJ) \ | ||||
|   s_compare128M$(OBJ) \ | ||||
|   s_shortShiftLeft64To96M$(OBJ) \ | ||||
|   s_shortShiftLeftM$(OBJ) \ | ||||
|   s_shiftLeftM$(OBJ) \ | ||||
|   s_shortShiftRightM$(OBJ) \ | ||||
|   s_shortShiftRightJam64$(OBJ) \ | ||||
|   s_shortShiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightJam32$(OBJ) \ | ||||
|   s_shiftRightJam64$(OBJ) \ | ||||
|   s_shiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightM$(OBJ) \ | ||||
|   s_countLeadingZeros8$(OBJ) \ | ||||
|   s_countLeadingZeros16$(OBJ) \ | ||||
|   s_countLeadingZeros32$(OBJ) \ | ||||
|   s_countLeadingZeros64$(OBJ) \ | ||||
|   s_addM$(OBJ) \ | ||||
|   s_addCarryM$(OBJ) \ | ||||
|   s_addComplCarryM$(OBJ) \ | ||||
|   s_negXM$(OBJ) \ | ||||
|   s_sub1XM$(OBJ) \ | ||||
|   s_subM$(OBJ) \ | ||||
|   s_mul64To128M$(OBJ) \ | ||||
|   s_mul128MTo256M$(OBJ) \ | ||||
|   s_approxRecip_1Ks$(OBJ) \ | ||||
|   s_approxRecip32_1$(OBJ) \ | ||||
|   s_approxRecipSqrt_1Ks$(OBJ) \ | ||||
|   s_approxRecipSqrt32_1$(OBJ) \ | ||||
|   s_remStepMBy32$(OBJ) \ | ||||
|  | ||||
| OBJS_SPECIALIZE = \ | ||||
|   softfloat_raiseFlags$(OBJ) \ | ||||
|   s_f16UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF16UI$(OBJ) \ | ||||
|   s_propagateNaNF16UI$(OBJ) \ | ||||
|   s_f32UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF32UI$(OBJ) \ | ||||
|   s_propagateNaNF32UI$(OBJ) \ | ||||
|   s_f64UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF64UI$(OBJ) \ | ||||
|   s_propagateNaNF64UI$(OBJ) \ | ||||
|   extF80M_isSignalingNaN$(OBJ) \ | ||||
|   s_extF80MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToExtF80M$(OBJ) \ | ||||
|   s_propagateNaNExtF80M$(OBJ) \ | ||||
|   f128M_isSignalingNaN$(OBJ) \ | ||||
|   s_f128MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF128M$(OBJ) \ | ||||
|   s_propagateNaNF128M$(OBJ) \ | ||||
|  | ||||
| OBJS_OTHERS = \ | ||||
|   s_roundToUI32$(OBJ) \ | ||||
|   s_roundMToUI64$(OBJ) \ | ||||
|   s_roundToI32$(OBJ) \ | ||||
|   s_roundMToI64$(OBJ) \ | ||||
|   s_normSubnormalF16Sig$(OBJ) \ | ||||
|   s_roundPackToF16$(OBJ) \ | ||||
|   s_normRoundPackToF16$(OBJ) \ | ||||
|   s_addMagsF16$(OBJ) \ | ||||
|   s_subMagsF16$(OBJ) \ | ||||
|   s_mulAddF16$(OBJ) \ | ||||
|   s_normSubnormalF32Sig$(OBJ) \ | ||||
|   s_roundPackToF32$(OBJ) \ | ||||
|   s_normRoundPackToF32$(OBJ) \ | ||||
|   s_addMagsF32$(OBJ) \ | ||||
|   s_subMagsF32$(OBJ) \ | ||||
|   s_mulAddF32$(OBJ) \ | ||||
|   s_normSubnormalF64Sig$(OBJ) \ | ||||
|   s_roundPackToF64$(OBJ) \ | ||||
|   s_normRoundPackToF64$(OBJ) \ | ||||
|   s_addMagsF64$(OBJ) \ | ||||
|   s_subMagsF64$(OBJ) \ | ||||
|   s_mulAddF64$(OBJ) \ | ||||
|   s_tryPropagateNaNExtF80M$(OBJ) \ | ||||
|   s_invalidExtF80M$(OBJ) \ | ||||
|   s_normExtF80SigM$(OBJ) \ | ||||
|   s_roundPackMToExtF80M$(OBJ) \ | ||||
|   s_normRoundPackMToExtF80M$(OBJ) \ | ||||
|   s_addExtF80M$(OBJ) \ | ||||
|   s_compareNonnormExtF80M$(OBJ) \ | ||||
|   s_isNaNF128M$(OBJ) \ | ||||
|   s_tryPropagateNaNF128M$(OBJ) \ | ||||
|   s_invalidF128M$(OBJ) \ | ||||
|   s_shiftNormSigF128M$(OBJ) \ | ||||
|   s_roundPackMToF128M$(OBJ) \ | ||||
|   s_normRoundPackMToF128M$(OBJ) \ | ||||
|   s_addF128M$(OBJ) \ | ||||
|   s_mulAddF128M$(OBJ) \ | ||||
|   softfloat_state$(OBJ) \ | ||||
|   ui32_to_f16$(OBJ) \ | ||||
|   ui32_to_f32$(OBJ) \ | ||||
|   ui32_to_f64$(OBJ) \ | ||||
|   ui32_to_extF80M$(OBJ) \ | ||||
|   ui32_to_f128M$(OBJ) \ | ||||
|   ui64_to_f16$(OBJ) \ | ||||
|   ui64_to_f32$(OBJ) \ | ||||
|   ui64_to_f64$(OBJ) \ | ||||
|   ui64_to_extF80M$(OBJ) \ | ||||
|   ui64_to_f128M$(OBJ) \ | ||||
|   i32_to_f16$(OBJ) \ | ||||
|   i32_to_f32$(OBJ) \ | ||||
|   i32_to_f64$(OBJ) \ | ||||
|   i32_to_extF80M$(OBJ) \ | ||||
|   i32_to_f128M$(OBJ) \ | ||||
|   i64_to_f16$(OBJ) \ | ||||
|   i64_to_f32$(OBJ) \ | ||||
|   i64_to_f64$(OBJ) \ | ||||
|   i64_to_extF80M$(OBJ) \ | ||||
|   i64_to_f128M$(OBJ) \ | ||||
|   f16_to_ui32$(OBJ) \ | ||||
|   f16_to_ui64$(OBJ) \ | ||||
|   f16_to_i32$(OBJ) \ | ||||
|   f16_to_i64$(OBJ) \ | ||||
|   f16_to_ui32_r_minMag$(OBJ) \ | ||||
|   f16_to_ui64_r_minMag$(OBJ) \ | ||||
|   f16_to_i32_r_minMag$(OBJ) \ | ||||
|   f16_to_i64_r_minMag$(OBJ) \ | ||||
|   f16_to_f32$(OBJ) \ | ||||
|   f16_to_f64$(OBJ) \ | ||||
|   f16_to_extF80M$(OBJ) \ | ||||
|   f16_to_f128M$(OBJ) \ | ||||
|   f16_roundToInt$(OBJ) \ | ||||
|   f16_add$(OBJ) \ | ||||
|   f16_sub$(OBJ) \ | ||||
|   f16_mul$(OBJ) \ | ||||
|   f16_mulAdd$(OBJ) \ | ||||
|   f16_div$(OBJ) \ | ||||
|   f16_rem$(OBJ) \ | ||||
|   f16_sqrt$(OBJ) \ | ||||
|   f16_eq$(OBJ) \ | ||||
|   f16_le$(OBJ) \ | ||||
|   f16_lt$(OBJ) \ | ||||
|   f16_eq_signaling$(OBJ) \ | ||||
|   f16_le_quiet$(OBJ) \ | ||||
|   f16_lt_quiet$(OBJ) \ | ||||
|   f16_isSignalingNaN$(OBJ) \ | ||||
|   f32_to_ui32$(OBJ) \ | ||||
|   f32_to_ui64$(OBJ) \ | ||||
|   f32_to_i32$(OBJ) \ | ||||
|   f32_to_i64$(OBJ) \ | ||||
|   f32_to_ui32_r_minMag$(OBJ) \ | ||||
|   f32_to_ui64_r_minMag$(OBJ) \ | ||||
|   f32_to_i32_r_minMag$(OBJ) \ | ||||
|   f32_to_i64_r_minMag$(OBJ) \ | ||||
|   f32_to_f16$(OBJ) \ | ||||
|   f32_to_f64$(OBJ) \ | ||||
|   f32_to_extF80M$(OBJ) \ | ||||
|   f32_to_f128M$(OBJ) \ | ||||
|   f32_roundToInt$(OBJ) \ | ||||
|   f32_add$(OBJ) \ | ||||
|   f32_sub$(OBJ) \ | ||||
|   f32_mul$(OBJ) \ | ||||
|   f32_mulAdd$(OBJ) \ | ||||
|   f32_div$(OBJ) \ | ||||
|   f32_rem$(OBJ) \ | ||||
|   f32_sqrt$(OBJ) \ | ||||
|   f32_eq$(OBJ) \ | ||||
|   f32_le$(OBJ) \ | ||||
|   f32_lt$(OBJ) \ | ||||
|   f32_eq_signaling$(OBJ) \ | ||||
|   f32_le_quiet$(OBJ) \ | ||||
|   f32_lt_quiet$(OBJ) \ | ||||
|   f32_isSignalingNaN$(OBJ) \ | ||||
|   f64_to_ui32$(OBJ) \ | ||||
|   f64_to_ui64$(OBJ) \ | ||||
|   f64_to_i32$(OBJ) \ | ||||
|   f64_to_i64$(OBJ) \ | ||||
|   f64_to_ui32_r_minMag$(OBJ) \ | ||||
|   f64_to_ui64_r_minMag$(OBJ) \ | ||||
|   f64_to_i32_r_minMag$(OBJ) \ | ||||
|   f64_to_i64_r_minMag$(OBJ) \ | ||||
|   f64_to_f16$(OBJ) \ | ||||
|   f64_to_f32$(OBJ) \ | ||||
|   f64_to_extF80M$(OBJ) \ | ||||
|   f64_to_f128M$(OBJ) \ | ||||
|   f64_roundToInt$(OBJ) \ | ||||
|   f64_add$(OBJ) \ | ||||
|   f64_sub$(OBJ) \ | ||||
|   f64_mul$(OBJ) \ | ||||
|   f64_mulAdd$(OBJ) \ | ||||
|   f64_div$(OBJ) \ | ||||
|   f64_rem$(OBJ) \ | ||||
|   f64_sqrt$(OBJ) \ | ||||
|   f64_eq$(OBJ) \ | ||||
|   f64_le$(OBJ) \ | ||||
|   f64_lt$(OBJ) \ | ||||
|   f64_eq_signaling$(OBJ) \ | ||||
|   f64_le_quiet$(OBJ) \ | ||||
|   f64_lt_quiet$(OBJ) \ | ||||
|   f64_isSignalingNaN$(OBJ) \ | ||||
|   extF80M_to_ui32$(OBJ) \ | ||||
|   extF80M_to_ui64$(OBJ) \ | ||||
|   extF80M_to_i32$(OBJ) \ | ||||
|   extF80M_to_i64$(OBJ) \ | ||||
|   extF80M_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_f16$(OBJ) \ | ||||
|   extF80M_to_f32$(OBJ) \ | ||||
|   extF80M_to_f64$(OBJ) \ | ||||
|   extF80M_to_f128M$(OBJ) \ | ||||
|   extF80M_roundToInt$(OBJ) \ | ||||
|   extF80M_add$(OBJ) \ | ||||
|   extF80M_sub$(OBJ) \ | ||||
|   extF80M_mul$(OBJ) \ | ||||
|   extF80M_div$(OBJ) \ | ||||
|   extF80M_rem$(OBJ) \ | ||||
|   extF80M_sqrt$(OBJ) \ | ||||
|   extF80M_eq$(OBJ) \ | ||||
|   extF80M_le$(OBJ) \ | ||||
|   extF80M_lt$(OBJ) \ | ||||
|   extF80M_eq_signaling$(OBJ) \ | ||||
|   extF80M_le_quiet$(OBJ) \ | ||||
|   extF80M_lt_quiet$(OBJ) \ | ||||
|   f128M_to_ui32$(OBJ) \ | ||||
|   f128M_to_ui64$(OBJ) \ | ||||
|   f128M_to_i32$(OBJ) \ | ||||
|   f128M_to_i64$(OBJ) \ | ||||
|   f128M_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128M_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128M_to_i32_r_minMag$(OBJ) \ | ||||
|   f128M_to_i64_r_minMag$(OBJ) \ | ||||
|   f128M_to_f16$(OBJ) \ | ||||
|   f128M_to_f32$(OBJ) \ | ||||
|   f128M_to_f64$(OBJ) \ | ||||
|   f128M_to_extF80M$(OBJ) \ | ||||
|   f128M_roundToInt$(OBJ) \ | ||||
|   f128M_add$(OBJ) \ | ||||
|   f128M_sub$(OBJ) \ | ||||
|   f128M_mul$(OBJ) \ | ||||
|   f128M_mulAdd$(OBJ) \ | ||||
|   f128M_div$(OBJ) \ | ||||
|   f128M_rem$(OBJ) \ | ||||
|   f128M_sqrt$(OBJ) \ | ||||
|   f128M_eq$(OBJ) \ | ||||
|   f128M_le$(OBJ) \ | ||||
|   f128M_lt$(OBJ) \ | ||||
|   f128M_eq_signaling$(OBJ) \ | ||||
|   f128M_le_quiet$(OBJ) \ | ||||
|   f128M_lt_quiet$(OBJ) \ | ||||
|  | ||||
| OBJS_ALL = $(OBJS_PRIMITIVES) $(OBJS_SPECIALIZE) $(OBJS_OTHERS) | ||||
|  | ||||
| $(OBJS_ALL): \ | ||||
|   $(OTHER_HEADERS) platform.h $(SOURCE_DIR)/include/primitiveTypes.h \ | ||||
|   $(SOURCE_DIR)/include/primitives.h | ||||
| $(OBJS_SPECIALIZE) $(OBJS_OTHERS): \ | ||||
|   $(SOURCE_DIR)/include/softfloat_types.h $(SOURCE_DIR)/include/internals.h \ | ||||
|   $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/specialize.h \ | ||||
|   $(SOURCE_DIR)/include/softfloat.h | ||||
|  | ||||
| $(OBJS_PRIMITIVES) $(OBJS_OTHERS): %$(OBJ): $(SOURCE_DIR)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$*.c | ||||
|  | ||||
| $(OBJS_SPECIALIZE): %$(OBJ): $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/$*.c | ||||
|  | ||||
| softfloat$(LIB): $(OBJS_ALL) | ||||
| 	$(DELETE) $@ | ||||
| 	$(MAKELIB) $^ | ||||
|  | ||||
| .PHONY: clean | ||||
| clean: | ||||
| 	$(DELETE) $(OBJS_ALL) softfloat$(LIB) | ||||
|  | ||||
|   | ||||
| @@ -1,52 +1,53 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #define LITTLEENDIAN 1 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #ifdef __GNUC_STDC_INLINE__ | ||||
| #define INLINE inline | ||||
| #else | ||||
| #define INLINE extern inline | ||||
| #endif | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #define SOFTFLOAT_BUILTIN_CLZ 1 | ||||
| #include "opts-GCC.h" | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define LITTLEENDIAN 1 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #ifdef __GNUC_STDC_INLINE__ | ||||
| #define INLINE inline | ||||
| #else | ||||
| #define INLINE extern inline | ||||
| #endif | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define SOFTFLOAT_BUILTIN_CLZ 1 | ||||
| #include "opts-GCC.h" | ||||
|  | ||||
|   | ||||
| @@ -1,325 +1,325 @@ | ||||
|  | ||||
| #============================================================================= | ||||
| # | ||||
| # This Makefile is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| # Package, Release 3e, by John R. Hauser. | ||||
| # | ||||
| # Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| # University of California.  All rights reserved. | ||||
| # | ||||
| # Redistribution and use in source and binary forms, with or without | ||||
| # modification, are permitted provided that the following conditions are met: | ||||
| # | ||||
| #  1. Redistributions of source code must retain the above copyright notice, | ||||
| #     this list of conditions, and the following disclaimer. | ||||
| # | ||||
| #  2. Redistributions in binary form must reproduce the above copyright | ||||
| #     notice, this list of conditions, and the following disclaimer in the | ||||
| #     documentation and/or other materials provided with the distribution. | ||||
| # | ||||
| #  3. Neither the name of the University nor the names of its contributors | ||||
| #     may be used to endorse or promote products derived from this software | ||||
| #     without specific prior written permission. | ||||
| # | ||||
| # THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| # DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||||
| # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| # | ||||
| #============================================================================= | ||||
|  | ||||
| SOURCE_DIR ?= ../../source | ||||
| SPECIALIZE_TYPE ?= 8086-SSE | ||||
|  | ||||
| SOFTFLOAT_OPTS ?= \ | ||||
|   -DSOFTFLOAT_ROUND_ODD -DINLINE_LEVEL=5 -DSOFTFLOAT_FAST_DIV32TO16 \ | ||||
|   -DSOFTFLOAT_FAST_DIV64TO32 | ||||
|  | ||||
| DELETE = rm -f | ||||
| C_INCLUDES = -I. -I$(SOURCE_DIR)/$(SPECIALIZE_TYPE) -I$(SOURCE_DIR)/include | ||||
| COMPILE_C = \ | ||||
|   gcc -c -Werror-implicit-function-declaration $(SOFTFLOAT_OPTS) \ | ||||
|     $(C_INCLUDES) -O2 -o $@ | ||||
| MAKELIB = ar crs $@ | ||||
|  | ||||
| OBJ = .o | ||||
| LIB = .a | ||||
|  | ||||
| OTHER_HEADERS = | ||||
|  | ||||
| .PHONY: all | ||||
| all: softfloat$(LIB) | ||||
|  | ||||
| OBJS_PRIMITIVES = \ | ||||
|   s_compare96M$(OBJ) \ | ||||
|   s_compare128M$(OBJ) \ | ||||
|   s_shortShiftLeft64To96M$(OBJ) \ | ||||
|   s_shortShiftLeftM$(OBJ) \ | ||||
|   s_shiftLeftM$(OBJ) \ | ||||
|   s_shortShiftRightM$(OBJ) \ | ||||
|   s_shortShiftRightJam64$(OBJ) \ | ||||
|   s_shortShiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightJam32$(OBJ) \ | ||||
|   s_shiftRightJam64$(OBJ) \ | ||||
|   s_shiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightM$(OBJ) \ | ||||
|   s_countLeadingZeros8$(OBJ) \ | ||||
|   s_countLeadingZeros16$(OBJ) \ | ||||
|   s_countLeadingZeros32$(OBJ) \ | ||||
|   s_countLeadingZeros64$(OBJ) \ | ||||
|   s_addM$(OBJ) \ | ||||
|   s_addCarryM$(OBJ) \ | ||||
|   s_addComplCarryM$(OBJ) \ | ||||
|   s_negXM$(OBJ) \ | ||||
|   s_sub1XM$(OBJ) \ | ||||
|   s_subM$(OBJ) \ | ||||
|   s_mul64To128M$(OBJ) \ | ||||
|   s_mul128MTo256M$(OBJ) \ | ||||
|   s_approxRecip_1Ks$(OBJ) \ | ||||
|   s_approxRecip32_1$(OBJ) \ | ||||
|   s_approxRecipSqrt_1Ks$(OBJ) \ | ||||
|   s_approxRecipSqrt32_1$(OBJ) \ | ||||
|   s_remStepMBy32$(OBJ) \ | ||||
|  | ||||
| OBJS_SPECIALIZE = \ | ||||
|   softfloat_raiseFlags$(OBJ) \ | ||||
|   s_f16UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF16UI$(OBJ) \ | ||||
|   s_propagateNaNF16UI$(OBJ) \ | ||||
|   s_f32UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF32UI$(OBJ) \ | ||||
|   s_propagateNaNF32UI$(OBJ) \ | ||||
|   s_f64UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF64UI$(OBJ) \ | ||||
|   s_propagateNaNF64UI$(OBJ) \ | ||||
|   extF80M_isSignalingNaN$(OBJ) \ | ||||
|   s_extF80MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToExtF80M$(OBJ) \ | ||||
|   s_propagateNaNExtF80M$(OBJ) \ | ||||
|   f128M_isSignalingNaN$(OBJ) \ | ||||
|   s_f128MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF128M$(OBJ) \ | ||||
|   s_propagateNaNF128M$(OBJ) \ | ||||
|  | ||||
| OBJS_OTHERS = \ | ||||
|   s_roundToUI32$(OBJ) \ | ||||
|   s_roundMToUI64$(OBJ) \ | ||||
|   s_roundToI32$(OBJ) \ | ||||
|   s_roundMToI64$(OBJ) \ | ||||
|   s_normSubnormalF16Sig$(OBJ) \ | ||||
|   s_roundPackToF16$(OBJ) \ | ||||
|   s_normRoundPackToF16$(OBJ) \ | ||||
|   s_addMagsF16$(OBJ) \ | ||||
|   s_subMagsF16$(OBJ) \ | ||||
|   s_mulAddF16$(OBJ) \ | ||||
|   s_normSubnormalF32Sig$(OBJ) \ | ||||
|   s_roundPackToF32$(OBJ) \ | ||||
|   s_normRoundPackToF32$(OBJ) \ | ||||
|   s_addMagsF32$(OBJ) \ | ||||
|   s_subMagsF32$(OBJ) \ | ||||
|   s_mulAddF32$(OBJ) \ | ||||
|   s_normSubnormalF64Sig$(OBJ) \ | ||||
|   s_roundPackToF64$(OBJ) \ | ||||
|   s_normRoundPackToF64$(OBJ) \ | ||||
|   s_addMagsF64$(OBJ) \ | ||||
|   s_subMagsF64$(OBJ) \ | ||||
|   s_mulAddF64$(OBJ) \ | ||||
|   s_tryPropagateNaNExtF80M$(OBJ) \ | ||||
|   s_invalidExtF80M$(OBJ) \ | ||||
|   s_normExtF80SigM$(OBJ) \ | ||||
|   s_roundPackMToExtF80M$(OBJ) \ | ||||
|   s_normRoundPackMToExtF80M$(OBJ) \ | ||||
|   s_addExtF80M$(OBJ) \ | ||||
|   s_compareNonnormExtF80M$(OBJ) \ | ||||
|   s_isNaNF128M$(OBJ) \ | ||||
|   s_tryPropagateNaNF128M$(OBJ) \ | ||||
|   s_invalidF128M$(OBJ) \ | ||||
|   s_shiftNormSigF128M$(OBJ) \ | ||||
|   s_roundPackMToF128M$(OBJ) \ | ||||
|   s_normRoundPackMToF128M$(OBJ) \ | ||||
|   s_addF128M$(OBJ) \ | ||||
|   s_mulAddF128M$(OBJ) \ | ||||
|   softfloat_state$(OBJ) \ | ||||
|   ui32_to_f16$(OBJ) \ | ||||
|   ui32_to_f32$(OBJ) \ | ||||
|   ui32_to_f64$(OBJ) \ | ||||
|   ui32_to_extF80M$(OBJ) \ | ||||
|   ui32_to_f128M$(OBJ) \ | ||||
|   ui64_to_f16$(OBJ) \ | ||||
|   ui64_to_f32$(OBJ) \ | ||||
|   ui64_to_f64$(OBJ) \ | ||||
|   ui64_to_extF80M$(OBJ) \ | ||||
|   ui64_to_f128M$(OBJ) \ | ||||
|   i32_to_f16$(OBJ) \ | ||||
|   i32_to_f32$(OBJ) \ | ||||
|   i32_to_f64$(OBJ) \ | ||||
|   i32_to_extF80M$(OBJ) \ | ||||
|   i32_to_f128M$(OBJ) \ | ||||
|   i64_to_f16$(OBJ) \ | ||||
|   i64_to_f32$(OBJ) \ | ||||
|   i64_to_f64$(OBJ) \ | ||||
|   i64_to_extF80M$(OBJ) \ | ||||
|   i64_to_f128M$(OBJ) \ | ||||
|   f16_to_ui32$(OBJ) \ | ||||
|   f16_to_ui64$(OBJ) \ | ||||
|   f16_to_i32$(OBJ) \ | ||||
|   f16_to_i64$(OBJ) \ | ||||
|   f16_to_ui32_r_minMag$(OBJ) \ | ||||
|   f16_to_ui64_r_minMag$(OBJ) \ | ||||
|   f16_to_i32_r_minMag$(OBJ) \ | ||||
|   f16_to_i64_r_minMag$(OBJ) \ | ||||
|   f16_to_f32$(OBJ) \ | ||||
|   f16_to_f64$(OBJ) \ | ||||
|   f16_to_extF80M$(OBJ) \ | ||||
|   f16_to_f128M$(OBJ) \ | ||||
|   f16_roundToInt$(OBJ) \ | ||||
|   f16_add$(OBJ) \ | ||||
|   f16_sub$(OBJ) \ | ||||
|   f16_mul$(OBJ) \ | ||||
|   f16_mulAdd$(OBJ) \ | ||||
|   f16_div$(OBJ) \ | ||||
|   f16_rem$(OBJ) \ | ||||
|   f16_sqrt$(OBJ) \ | ||||
|   f16_eq$(OBJ) \ | ||||
|   f16_le$(OBJ) \ | ||||
|   f16_lt$(OBJ) \ | ||||
|   f16_eq_signaling$(OBJ) \ | ||||
|   f16_le_quiet$(OBJ) \ | ||||
|   f16_lt_quiet$(OBJ) \ | ||||
|   f16_isSignalingNaN$(OBJ) \ | ||||
|   f32_to_ui32$(OBJ) \ | ||||
|   f32_to_ui64$(OBJ) \ | ||||
|   f32_to_i32$(OBJ) \ | ||||
|   f32_to_i64$(OBJ) \ | ||||
|   f32_to_ui32_r_minMag$(OBJ) \ | ||||
|   f32_to_ui64_r_minMag$(OBJ) \ | ||||
|   f32_to_i32_r_minMag$(OBJ) \ | ||||
|   f32_to_i64_r_minMag$(OBJ) \ | ||||
|   f32_to_f16$(OBJ) \ | ||||
|   f32_to_f64$(OBJ) \ | ||||
|   f32_to_extF80M$(OBJ) \ | ||||
|   f32_to_f128M$(OBJ) \ | ||||
|   f32_roundToInt$(OBJ) \ | ||||
|   f32_add$(OBJ) \ | ||||
|   f32_sub$(OBJ) \ | ||||
|   f32_mul$(OBJ) \ | ||||
|   f32_mulAdd$(OBJ) \ | ||||
|   f32_div$(OBJ) \ | ||||
|   f32_rem$(OBJ) \ | ||||
|   f32_sqrt$(OBJ) \ | ||||
|   f32_eq$(OBJ) \ | ||||
|   f32_le$(OBJ) \ | ||||
|   f32_lt$(OBJ) \ | ||||
|   f32_eq_signaling$(OBJ) \ | ||||
|   f32_le_quiet$(OBJ) \ | ||||
|   f32_lt_quiet$(OBJ) \ | ||||
|   f32_isSignalingNaN$(OBJ) \ | ||||
|   f64_to_ui32$(OBJ) \ | ||||
|   f64_to_ui64$(OBJ) \ | ||||
|   f64_to_i32$(OBJ) \ | ||||
|   f64_to_i64$(OBJ) \ | ||||
|   f64_to_ui32_r_minMag$(OBJ) \ | ||||
|   f64_to_ui64_r_minMag$(OBJ) \ | ||||
|   f64_to_i32_r_minMag$(OBJ) \ | ||||
|   f64_to_i64_r_minMag$(OBJ) \ | ||||
|   f64_to_f16$(OBJ) \ | ||||
|   f64_to_f32$(OBJ) \ | ||||
|   f64_to_extF80M$(OBJ) \ | ||||
|   f64_to_f128M$(OBJ) \ | ||||
|   f64_roundToInt$(OBJ) \ | ||||
|   f64_add$(OBJ) \ | ||||
|   f64_sub$(OBJ) \ | ||||
|   f64_mul$(OBJ) \ | ||||
|   f64_mulAdd$(OBJ) \ | ||||
|   f64_div$(OBJ) \ | ||||
|   f64_rem$(OBJ) \ | ||||
|   f64_sqrt$(OBJ) \ | ||||
|   f64_eq$(OBJ) \ | ||||
|   f64_le$(OBJ) \ | ||||
|   f64_lt$(OBJ) \ | ||||
|   f64_eq_signaling$(OBJ) \ | ||||
|   f64_le_quiet$(OBJ) \ | ||||
|   f64_lt_quiet$(OBJ) \ | ||||
|   f64_isSignalingNaN$(OBJ) \ | ||||
|   extF80M_to_ui32$(OBJ) \ | ||||
|   extF80M_to_ui64$(OBJ) \ | ||||
|   extF80M_to_i32$(OBJ) \ | ||||
|   extF80M_to_i64$(OBJ) \ | ||||
|   extF80M_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_f16$(OBJ) \ | ||||
|   extF80M_to_f32$(OBJ) \ | ||||
|   extF80M_to_f64$(OBJ) \ | ||||
|   extF80M_to_f128M$(OBJ) \ | ||||
|   extF80M_roundToInt$(OBJ) \ | ||||
|   extF80M_add$(OBJ) \ | ||||
|   extF80M_sub$(OBJ) \ | ||||
|   extF80M_mul$(OBJ) \ | ||||
|   extF80M_div$(OBJ) \ | ||||
|   extF80M_rem$(OBJ) \ | ||||
|   extF80M_sqrt$(OBJ) \ | ||||
|   extF80M_eq$(OBJ) \ | ||||
|   extF80M_le$(OBJ) \ | ||||
|   extF80M_lt$(OBJ) \ | ||||
|   extF80M_eq_signaling$(OBJ) \ | ||||
|   extF80M_le_quiet$(OBJ) \ | ||||
|   extF80M_lt_quiet$(OBJ) \ | ||||
|   f128M_to_ui32$(OBJ) \ | ||||
|   f128M_to_ui64$(OBJ) \ | ||||
|   f128M_to_i32$(OBJ) \ | ||||
|   f128M_to_i64$(OBJ) \ | ||||
|   f128M_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128M_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128M_to_i32_r_minMag$(OBJ) \ | ||||
|   f128M_to_i64_r_minMag$(OBJ) \ | ||||
|   f128M_to_f16$(OBJ) \ | ||||
|   f128M_to_f32$(OBJ) \ | ||||
|   f128M_to_f64$(OBJ) \ | ||||
|   f128M_to_extF80M$(OBJ) \ | ||||
|   f128M_roundToInt$(OBJ) \ | ||||
|   f128M_add$(OBJ) \ | ||||
|   f128M_sub$(OBJ) \ | ||||
|   f128M_mul$(OBJ) \ | ||||
|   f128M_mulAdd$(OBJ) \ | ||||
|   f128M_div$(OBJ) \ | ||||
|   f128M_rem$(OBJ) \ | ||||
|   f128M_sqrt$(OBJ) \ | ||||
|   f128M_eq$(OBJ) \ | ||||
|   f128M_le$(OBJ) \ | ||||
|   f128M_lt$(OBJ) \ | ||||
|   f128M_eq_signaling$(OBJ) \ | ||||
|   f128M_le_quiet$(OBJ) \ | ||||
|   f128M_lt_quiet$(OBJ) \ | ||||
|  | ||||
| OBJS_ALL = $(OBJS_PRIMITIVES) $(OBJS_SPECIALIZE) $(OBJS_OTHERS) | ||||
|  | ||||
| $(OBJS_ALL): \ | ||||
|   $(OTHER_HEADERS) platform.h $(SOURCE_DIR)/include/primitiveTypes.h \ | ||||
|   $(SOURCE_DIR)/include/primitives.h | ||||
| $(OBJS_SPECIALIZE) $(OBJS_OTHERS): \ | ||||
|   $(SOURCE_DIR)/include/softfloat_types.h $(SOURCE_DIR)/include/internals.h \ | ||||
|   $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/specialize.h \ | ||||
|   $(SOURCE_DIR)/include/softfloat.h | ||||
|  | ||||
| $(OBJS_PRIMITIVES) $(OBJS_OTHERS): %$(OBJ): $(SOURCE_DIR)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$*.c | ||||
|  | ||||
| $(OBJS_SPECIALIZE): %$(OBJ): $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/$*.c | ||||
|  | ||||
| softfloat$(LIB): $(OBJS_ALL) | ||||
| 	$(DELETE) $@ | ||||
| 	$(MAKELIB) $^ | ||||
|  | ||||
| .PHONY: clean | ||||
| clean: | ||||
| 	$(DELETE) $(OBJS_ALL) softfloat$(LIB) | ||||
|  | ||||
|  | ||||
| #============================================================================= | ||||
| # | ||||
| # This Makefile is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| # Package, Release 3e, by John R. Hauser. | ||||
| # | ||||
| # Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| # University of California.  All rights reserved. | ||||
| # | ||||
| # Redistribution and use in source and binary forms, with or without | ||||
| # modification, are permitted provided that the following conditions are met: | ||||
| # | ||||
| #  1. Redistributions of source code must retain the above copyright notice, | ||||
| #     this list of conditions, and the following disclaimer. | ||||
| # | ||||
| #  2. Redistributions in binary form must reproduce the above copyright | ||||
| #     notice, this list of conditions, and the following disclaimer in the | ||||
| #     documentation and/or other materials provided with the distribution. | ||||
| # | ||||
| #  3. Neither the name of the University nor the names of its contributors | ||||
| #     may be used to endorse or promote products derived from this software | ||||
| #     without specific prior written permission. | ||||
| # | ||||
| # THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| # DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||||
| # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| # | ||||
| #============================================================================= | ||||
|  | ||||
| SOURCE_DIR ?= ../../source | ||||
| SPECIALIZE_TYPE ?= 8086-SSE | ||||
|  | ||||
| SOFTFLOAT_OPTS ?= \ | ||||
|   -DSOFTFLOAT_ROUND_ODD -DINLINE_LEVEL=5 -DSOFTFLOAT_FAST_DIV32TO16 \ | ||||
|   -DSOFTFLOAT_FAST_DIV64TO32 | ||||
|  | ||||
| DELETE = rm -f | ||||
| C_INCLUDES = -I. -I$(SOURCE_DIR)/$(SPECIALIZE_TYPE) -I$(SOURCE_DIR)/include | ||||
| COMPILE_C = \ | ||||
|   gcc -c -Werror-implicit-function-declaration $(SOFTFLOAT_OPTS) \ | ||||
|     $(C_INCLUDES) -O2 -o $@ | ||||
| MAKELIB = ar crs $@ | ||||
|  | ||||
| OBJ = .o | ||||
| LIB = .a | ||||
|  | ||||
| OTHER_HEADERS = | ||||
|  | ||||
| .PHONY: all | ||||
| all: softfloat$(LIB) | ||||
|  | ||||
| OBJS_PRIMITIVES = \ | ||||
|   s_compare96M$(OBJ) \ | ||||
|   s_compare128M$(OBJ) \ | ||||
|   s_shortShiftLeft64To96M$(OBJ) \ | ||||
|   s_shortShiftLeftM$(OBJ) \ | ||||
|   s_shiftLeftM$(OBJ) \ | ||||
|   s_shortShiftRightM$(OBJ) \ | ||||
|   s_shortShiftRightJam64$(OBJ) \ | ||||
|   s_shortShiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightJam32$(OBJ) \ | ||||
|   s_shiftRightJam64$(OBJ) \ | ||||
|   s_shiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightM$(OBJ) \ | ||||
|   s_countLeadingZeros8$(OBJ) \ | ||||
|   s_countLeadingZeros16$(OBJ) \ | ||||
|   s_countLeadingZeros32$(OBJ) \ | ||||
|   s_countLeadingZeros64$(OBJ) \ | ||||
|   s_addM$(OBJ) \ | ||||
|   s_addCarryM$(OBJ) \ | ||||
|   s_addComplCarryM$(OBJ) \ | ||||
|   s_negXM$(OBJ) \ | ||||
|   s_sub1XM$(OBJ) \ | ||||
|   s_subM$(OBJ) \ | ||||
|   s_mul64To128M$(OBJ) \ | ||||
|   s_mul128MTo256M$(OBJ) \ | ||||
|   s_approxRecip_1Ks$(OBJ) \ | ||||
|   s_approxRecip32_1$(OBJ) \ | ||||
|   s_approxRecipSqrt_1Ks$(OBJ) \ | ||||
|   s_approxRecipSqrt32_1$(OBJ) \ | ||||
|   s_remStepMBy32$(OBJ) \ | ||||
|  | ||||
| OBJS_SPECIALIZE = \ | ||||
|   softfloat_raiseFlags$(OBJ) \ | ||||
|   s_f16UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF16UI$(OBJ) \ | ||||
|   s_propagateNaNF16UI$(OBJ) \ | ||||
|   s_f32UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF32UI$(OBJ) \ | ||||
|   s_propagateNaNF32UI$(OBJ) \ | ||||
|   s_f64UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF64UI$(OBJ) \ | ||||
|   s_propagateNaNF64UI$(OBJ) \ | ||||
|   extF80M_isSignalingNaN$(OBJ) \ | ||||
|   s_extF80MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToExtF80M$(OBJ) \ | ||||
|   s_propagateNaNExtF80M$(OBJ) \ | ||||
|   f128M_isSignalingNaN$(OBJ) \ | ||||
|   s_f128MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF128M$(OBJ) \ | ||||
|   s_propagateNaNF128M$(OBJ) \ | ||||
|  | ||||
| OBJS_OTHERS = \ | ||||
|   s_roundToUI32$(OBJ) \ | ||||
|   s_roundMToUI64$(OBJ) \ | ||||
|   s_roundToI32$(OBJ) \ | ||||
|   s_roundMToI64$(OBJ) \ | ||||
|   s_normSubnormalF16Sig$(OBJ) \ | ||||
|   s_roundPackToF16$(OBJ) \ | ||||
|   s_normRoundPackToF16$(OBJ) \ | ||||
|   s_addMagsF16$(OBJ) \ | ||||
|   s_subMagsF16$(OBJ) \ | ||||
|   s_mulAddF16$(OBJ) \ | ||||
|   s_normSubnormalF32Sig$(OBJ) \ | ||||
|   s_roundPackToF32$(OBJ) \ | ||||
|   s_normRoundPackToF32$(OBJ) \ | ||||
|   s_addMagsF32$(OBJ) \ | ||||
|   s_subMagsF32$(OBJ) \ | ||||
|   s_mulAddF32$(OBJ) \ | ||||
|   s_normSubnormalF64Sig$(OBJ) \ | ||||
|   s_roundPackToF64$(OBJ) \ | ||||
|   s_normRoundPackToF64$(OBJ) \ | ||||
|   s_addMagsF64$(OBJ) \ | ||||
|   s_subMagsF64$(OBJ) \ | ||||
|   s_mulAddF64$(OBJ) \ | ||||
|   s_tryPropagateNaNExtF80M$(OBJ) \ | ||||
|   s_invalidExtF80M$(OBJ) \ | ||||
|   s_normExtF80SigM$(OBJ) \ | ||||
|   s_roundPackMToExtF80M$(OBJ) \ | ||||
|   s_normRoundPackMToExtF80M$(OBJ) \ | ||||
|   s_addExtF80M$(OBJ) \ | ||||
|   s_compareNonnormExtF80M$(OBJ) \ | ||||
|   s_isNaNF128M$(OBJ) \ | ||||
|   s_tryPropagateNaNF128M$(OBJ) \ | ||||
|   s_invalidF128M$(OBJ) \ | ||||
|   s_shiftNormSigF128M$(OBJ) \ | ||||
|   s_roundPackMToF128M$(OBJ) \ | ||||
|   s_normRoundPackMToF128M$(OBJ) \ | ||||
|   s_addF128M$(OBJ) \ | ||||
|   s_mulAddF128M$(OBJ) \ | ||||
|   softfloat_state$(OBJ) \ | ||||
|   ui32_to_f16$(OBJ) \ | ||||
|   ui32_to_f32$(OBJ) \ | ||||
|   ui32_to_f64$(OBJ) \ | ||||
|   ui32_to_extF80M$(OBJ) \ | ||||
|   ui32_to_f128M$(OBJ) \ | ||||
|   ui64_to_f16$(OBJ) \ | ||||
|   ui64_to_f32$(OBJ) \ | ||||
|   ui64_to_f64$(OBJ) \ | ||||
|   ui64_to_extF80M$(OBJ) \ | ||||
|   ui64_to_f128M$(OBJ) \ | ||||
|   i32_to_f16$(OBJ) \ | ||||
|   i32_to_f32$(OBJ) \ | ||||
|   i32_to_f64$(OBJ) \ | ||||
|   i32_to_extF80M$(OBJ) \ | ||||
|   i32_to_f128M$(OBJ) \ | ||||
|   i64_to_f16$(OBJ) \ | ||||
|   i64_to_f32$(OBJ) \ | ||||
|   i64_to_f64$(OBJ) \ | ||||
|   i64_to_extF80M$(OBJ) \ | ||||
|   i64_to_f128M$(OBJ) \ | ||||
|   f16_to_ui32$(OBJ) \ | ||||
|   f16_to_ui64$(OBJ) \ | ||||
|   f16_to_i32$(OBJ) \ | ||||
|   f16_to_i64$(OBJ) \ | ||||
|   f16_to_ui32_r_minMag$(OBJ) \ | ||||
|   f16_to_ui64_r_minMag$(OBJ) \ | ||||
|   f16_to_i32_r_minMag$(OBJ) \ | ||||
|   f16_to_i64_r_minMag$(OBJ) \ | ||||
|   f16_to_f32$(OBJ) \ | ||||
|   f16_to_f64$(OBJ) \ | ||||
|   f16_to_extF80M$(OBJ) \ | ||||
|   f16_to_f128M$(OBJ) \ | ||||
|   f16_roundToInt$(OBJ) \ | ||||
|   f16_add$(OBJ) \ | ||||
|   f16_sub$(OBJ) \ | ||||
|   f16_mul$(OBJ) \ | ||||
|   f16_mulAdd$(OBJ) \ | ||||
|   f16_div$(OBJ) \ | ||||
|   f16_rem$(OBJ) \ | ||||
|   f16_sqrt$(OBJ) \ | ||||
|   f16_eq$(OBJ) \ | ||||
|   f16_le$(OBJ) \ | ||||
|   f16_lt$(OBJ) \ | ||||
|   f16_eq_signaling$(OBJ) \ | ||||
|   f16_le_quiet$(OBJ) \ | ||||
|   f16_lt_quiet$(OBJ) \ | ||||
|   f16_isSignalingNaN$(OBJ) \ | ||||
|   f32_to_ui32$(OBJ) \ | ||||
|   f32_to_ui64$(OBJ) \ | ||||
|   f32_to_i32$(OBJ) \ | ||||
|   f32_to_i64$(OBJ) \ | ||||
|   f32_to_ui32_r_minMag$(OBJ) \ | ||||
|   f32_to_ui64_r_minMag$(OBJ) \ | ||||
|   f32_to_i32_r_minMag$(OBJ) \ | ||||
|   f32_to_i64_r_minMag$(OBJ) \ | ||||
|   f32_to_f16$(OBJ) \ | ||||
|   f32_to_f64$(OBJ) \ | ||||
|   f32_to_extF80M$(OBJ) \ | ||||
|   f32_to_f128M$(OBJ) \ | ||||
|   f32_roundToInt$(OBJ) \ | ||||
|   f32_add$(OBJ) \ | ||||
|   f32_sub$(OBJ) \ | ||||
|   f32_mul$(OBJ) \ | ||||
|   f32_mulAdd$(OBJ) \ | ||||
|   f32_div$(OBJ) \ | ||||
|   f32_rem$(OBJ) \ | ||||
|   f32_sqrt$(OBJ) \ | ||||
|   f32_eq$(OBJ) \ | ||||
|   f32_le$(OBJ) \ | ||||
|   f32_lt$(OBJ) \ | ||||
|   f32_eq_signaling$(OBJ) \ | ||||
|   f32_le_quiet$(OBJ) \ | ||||
|   f32_lt_quiet$(OBJ) \ | ||||
|   f32_isSignalingNaN$(OBJ) \ | ||||
|   f64_to_ui32$(OBJ) \ | ||||
|   f64_to_ui64$(OBJ) \ | ||||
|   f64_to_i32$(OBJ) \ | ||||
|   f64_to_i64$(OBJ) \ | ||||
|   f64_to_ui32_r_minMag$(OBJ) \ | ||||
|   f64_to_ui64_r_minMag$(OBJ) \ | ||||
|   f64_to_i32_r_minMag$(OBJ) \ | ||||
|   f64_to_i64_r_minMag$(OBJ) \ | ||||
|   f64_to_f16$(OBJ) \ | ||||
|   f64_to_f32$(OBJ) \ | ||||
|   f64_to_extF80M$(OBJ) \ | ||||
|   f64_to_f128M$(OBJ) \ | ||||
|   f64_roundToInt$(OBJ) \ | ||||
|   f64_add$(OBJ) \ | ||||
|   f64_sub$(OBJ) \ | ||||
|   f64_mul$(OBJ) \ | ||||
|   f64_mulAdd$(OBJ) \ | ||||
|   f64_div$(OBJ) \ | ||||
|   f64_rem$(OBJ) \ | ||||
|   f64_sqrt$(OBJ) \ | ||||
|   f64_eq$(OBJ) \ | ||||
|   f64_le$(OBJ) \ | ||||
|   f64_lt$(OBJ) \ | ||||
|   f64_eq_signaling$(OBJ) \ | ||||
|   f64_le_quiet$(OBJ) \ | ||||
|   f64_lt_quiet$(OBJ) \ | ||||
|   f64_isSignalingNaN$(OBJ) \ | ||||
|   extF80M_to_ui32$(OBJ) \ | ||||
|   extF80M_to_ui64$(OBJ) \ | ||||
|   extF80M_to_i32$(OBJ) \ | ||||
|   extF80M_to_i64$(OBJ) \ | ||||
|   extF80M_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_f16$(OBJ) \ | ||||
|   extF80M_to_f32$(OBJ) \ | ||||
|   extF80M_to_f64$(OBJ) \ | ||||
|   extF80M_to_f128M$(OBJ) \ | ||||
|   extF80M_roundToInt$(OBJ) \ | ||||
|   extF80M_add$(OBJ) \ | ||||
|   extF80M_sub$(OBJ) \ | ||||
|   extF80M_mul$(OBJ) \ | ||||
|   extF80M_div$(OBJ) \ | ||||
|   extF80M_rem$(OBJ) \ | ||||
|   extF80M_sqrt$(OBJ) \ | ||||
|   extF80M_eq$(OBJ) \ | ||||
|   extF80M_le$(OBJ) \ | ||||
|   extF80M_lt$(OBJ) \ | ||||
|   extF80M_eq_signaling$(OBJ) \ | ||||
|   extF80M_le_quiet$(OBJ) \ | ||||
|   extF80M_lt_quiet$(OBJ) \ | ||||
|   f128M_to_ui32$(OBJ) \ | ||||
|   f128M_to_ui64$(OBJ) \ | ||||
|   f128M_to_i32$(OBJ) \ | ||||
|   f128M_to_i64$(OBJ) \ | ||||
|   f128M_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128M_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128M_to_i32_r_minMag$(OBJ) \ | ||||
|   f128M_to_i64_r_minMag$(OBJ) \ | ||||
|   f128M_to_f16$(OBJ) \ | ||||
|   f128M_to_f32$(OBJ) \ | ||||
|   f128M_to_f64$(OBJ) \ | ||||
|   f128M_to_extF80M$(OBJ) \ | ||||
|   f128M_roundToInt$(OBJ) \ | ||||
|   f128M_add$(OBJ) \ | ||||
|   f128M_sub$(OBJ) \ | ||||
|   f128M_mul$(OBJ) \ | ||||
|   f128M_mulAdd$(OBJ) \ | ||||
|   f128M_div$(OBJ) \ | ||||
|   f128M_rem$(OBJ) \ | ||||
|   f128M_sqrt$(OBJ) \ | ||||
|   f128M_eq$(OBJ) \ | ||||
|   f128M_le$(OBJ) \ | ||||
|   f128M_lt$(OBJ) \ | ||||
|   f128M_eq_signaling$(OBJ) \ | ||||
|   f128M_le_quiet$(OBJ) \ | ||||
|   f128M_lt_quiet$(OBJ) \ | ||||
|  | ||||
| OBJS_ALL = $(OBJS_PRIMITIVES) $(OBJS_SPECIALIZE) $(OBJS_OTHERS) | ||||
|  | ||||
| $(OBJS_ALL): \ | ||||
|   $(OTHER_HEADERS) platform.h $(SOURCE_DIR)/include/primitiveTypes.h \ | ||||
|   $(SOURCE_DIR)/include/primitives.h | ||||
| $(OBJS_SPECIALIZE) $(OBJS_OTHERS): \ | ||||
|   $(SOURCE_DIR)/include/softfloat_types.h $(SOURCE_DIR)/include/internals.h \ | ||||
|   $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/specialize.h \ | ||||
|   $(SOURCE_DIR)/include/softfloat.h | ||||
|  | ||||
| $(OBJS_PRIMITIVES) $(OBJS_OTHERS): %$(OBJ): $(SOURCE_DIR)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$*.c | ||||
|  | ||||
| $(OBJS_SPECIALIZE): %$(OBJ): $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/$*.c | ||||
|  | ||||
| softfloat$(LIB): $(OBJS_ALL) | ||||
| 	$(DELETE) $@ | ||||
| 	$(MAKELIB) $^ | ||||
|  | ||||
| .PHONY: clean | ||||
| clean: | ||||
| 	$(DELETE) $(OBJS_ALL) softfloat$(LIB) | ||||
|  | ||||
|   | ||||
| @@ -1,52 +1,53 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #define LITTLEENDIAN 1 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #ifdef __GNUC_STDC_INLINE__ | ||||
| #define INLINE inline | ||||
| #else | ||||
| #define INLINE extern inline | ||||
| #endif | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #define SOFTFLOAT_BUILTIN_CLZ 1 | ||||
| #include "opts-GCC.h" | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define LITTLEENDIAN 1 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #ifdef __GNUC_STDC_INLINE__ | ||||
| #define INLINE inline | ||||
| #else | ||||
| #define INLINE extern inline | ||||
| #endif | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define SOFTFLOAT_BUILTIN_CLZ 1 | ||||
| #include "opts-GCC.h" | ||||
|  | ||||
|   | ||||
| @@ -1,390 +1,390 @@ | ||||
|  | ||||
| #============================================================================= | ||||
| # | ||||
| # This Makefile is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| # Package, Release 3e, by John R. Hauser. | ||||
| # | ||||
| # Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| # University of California.  All rights reserved. | ||||
| # | ||||
| # Redistribution and use in source and binary forms, with or without | ||||
| # modification, are permitted provided that the following conditions are met: | ||||
| # | ||||
| #  1. Redistributions of source code must retain the above copyright notice, | ||||
| #     this list of conditions, and the following disclaimer. | ||||
| # | ||||
| #  2. Redistributions in binary form must reproduce the above copyright | ||||
| #     notice, this list of conditions, and the following disclaimer in the | ||||
| #     documentation and/or other materials provided with the distribution. | ||||
| # | ||||
| #  3. Neither the name of the University nor the names of its contributors | ||||
| #     may be used to endorse or promote products derived from this software | ||||
| #     without specific prior written permission. | ||||
| # | ||||
| # THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| # DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||||
| # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| # | ||||
| #============================================================================= | ||||
|  | ||||
| SOURCE_DIR ?= ../../source | ||||
| SPECIALIZE_TYPE ?= 8086-SSE | ||||
|  | ||||
| SOFTFLOAT_OPTS ?= \ | ||||
|   -DSOFTFLOAT_ROUND_ODD -DINLINE_LEVEL=5 -DSOFTFLOAT_FAST_DIV32TO16 \ | ||||
|   -DSOFTFLOAT_FAST_DIV64TO32 | ||||
|  | ||||
| DELETE = rm -f | ||||
| C_INCLUDES = -I. -I$(SOURCE_DIR)/$(SPECIALIZE_TYPE) -I$(SOURCE_DIR)/include | ||||
| COMPILE_C = \ | ||||
|   x86_64-w64-mingw32-gcc -c -Werror-implicit-function-declaration \ | ||||
|     -DSOFTFLOAT_FAST_INT64 $(SOFTFLOAT_OPTS) $(C_INCLUDES) -O2 -o $@ | ||||
| MAKELIB = x86_64-w64-mingw32-ar crs $@ | ||||
|  | ||||
| OBJ = .o | ||||
| LIB = .a | ||||
|  | ||||
| OTHER_HEADERS = $(SOURCE_DIR)/include/opts-GCC.h | ||||
|  | ||||
| .PHONY: all | ||||
| all: softfloat$(LIB) | ||||
|  | ||||
| OBJS_PRIMITIVES = \ | ||||
|   s_eq128$(OBJ) \ | ||||
|   s_le128$(OBJ) \ | ||||
|   s_lt128$(OBJ) \ | ||||
|   s_shortShiftLeft128$(OBJ) \ | ||||
|   s_shortShiftRight128$(OBJ) \ | ||||
|   s_shortShiftRightJam64$(OBJ) \ | ||||
|   s_shortShiftRightJam64Extra$(OBJ) \ | ||||
|   s_shortShiftRightJam128$(OBJ) \ | ||||
|   s_shortShiftRightJam128Extra$(OBJ) \ | ||||
|   s_shiftRightJam32$(OBJ) \ | ||||
|   s_shiftRightJam64$(OBJ) \ | ||||
|   s_shiftRightJam64Extra$(OBJ) \ | ||||
|   s_shiftRightJam128$(OBJ) \ | ||||
|   s_shiftRightJam128Extra$(OBJ) \ | ||||
|   s_shiftRightJam256M$(OBJ) \ | ||||
|   s_countLeadingZeros8$(OBJ) \ | ||||
|   s_countLeadingZeros16$(OBJ) \ | ||||
|   s_countLeadingZeros32$(OBJ) \ | ||||
|   s_countLeadingZeros64$(OBJ) \ | ||||
|   s_add128$(OBJ) \ | ||||
|   s_add256M$(OBJ) \ | ||||
|   s_sub128$(OBJ) \ | ||||
|   s_sub256M$(OBJ) \ | ||||
|   s_mul64ByShifted32To128$(OBJ) \ | ||||
|   s_mul64To128$(OBJ) \ | ||||
|   s_mul128By32$(OBJ) \ | ||||
|   s_mul128To256M$(OBJ) \ | ||||
|   s_approxRecip_1Ks$(OBJ) \ | ||||
|   s_approxRecip32_1$(OBJ) \ | ||||
|   s_approxRecipSqrt_1Ks$(OBJ) \ | ||||
|   s_approxRecipSqrt32_1$(OBJ) \ | ||||
|  | ||||
| OBJS_SPECIALIZE = \ | ||||
|   softfloat_raiseFlags$(OBJ) \ | ||||
|   s_f16UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF16UI$(OBJ) \ | ||||
|   s_propagateNaNF16UI$(OBJ) \ | ||||
|   s_f32UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF32UI$(OBJ) \ | ||||
|   s_propagateNaNF32UI$(OBJ) \ | ||||
|   s_f64UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF64UI$(OBJ) \ | ||||
|   s_propagateNaNF64UI$(OBJ) \ | ||||
|   extF80M_isSignalingNaN$(OBJ) \ | ||||
|   s_extF80UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToExtF80UI$(OBJ) \ | ||||
|   s_propagateNaNExtF80UI$(OBJ) \ | ||||
|   f128M_isSignalingNaN$(OBJ) \ | ||||
|   s_f128UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF128UI$(OBJ) \ | ||||
|   s_propagateNaNF128UI$(OBJ) \ | ||||
|  | ||||
| OBJS_OTHERS = \ | ||||
|   s_roundToUI32$(OBJ) \ | ||||
|   s_roundToUI64$(OBJ) \ | ||||
|   s_roundToI32$(OBJ) \ | ||||
|   s_roundToI64$(OBJ) \ | ||||
|   s_normSubnormalF16Sig$(OBJ) \ | ||||
|   s_roundPackToF16$(OBJ) \ | ||||
|   s_normRoundPackToF16$(OBJ) \ | ||||
|   s_addMagsF16$(OBJ) \ | ||||
|   s_subMagsF16$(OBJ) \ | ||||
|   s_mulAddF16$(OBJ) \ | ||||
|   s_normSubnormalF32Sig$(OBJ) \ | ||||
|   s_roundPackToF32$(OBJ) \ | ||||
|   s_normRoundPackToF32$(OBJ) \ | ||||
|   s_addMagsF32$(OBJ) \ | ||||
|   s_subMagsF32$(OBJ) \ | ||||
|   s_mulAddF32$(OBJ) \ | ||||
|   s_normSubnormalF64Sig$(OBJ) \ | ||||
|   s_roundPackToF64$(OBJ) \ | ||||
|   s_normRoundPackToF64$(OBJ) \ | ||||
|   s_addMagsF64$(OBJ) \ | ||||
|   s_subMagsF64$(OBJ) \ | ||||
|   s_mulAddF64$(OBJ) \ | ||||
|   s_normSubnormalExtF80Sig$(OBJ) \ | ||||
|   s_roundPackToExtF80$(OBJ) \ | ||||
|   s_normRoundPackToExtF80$(OBJ) \ | ||||
|   s_addMagsExtF80$(OBJ) \ | ||||
|   s_subMagsExtF80$(OBJ) \ | ||||
|   s_normSubnormalF128Sig$(OBJ) \ | ||||
|   s_roundPackToF128$(OBJ) \ | ||||
|   s_normRoundPackToF128$(OBJ) \ | ||||
|   s_addMagsF128$(OBJ) \ | ||||
|   s_subMagsF128$(OBJ) \ | ||||
|   s_mulAddF128$(OBJ) \ | ||||
|   softfloat_state$(OBJ) \ | ||||
|   ui32_to_f16$(OBJ) \ | ||||
|   ui32_to_f32$(OBJ) \ | ||||
|   ui32_to_f64$(OBJ) \ | ||||
|   ui32_to_extF80$(OBJ) \ | ||||
|   ui32_to_extF80M$(OBJ) \ | ||||
|   ui32_to_f128$(OBJ) \ | ||||
|   ui32_to_f128M$(OBJ) \ | ||||
|   ui64_to_f16$(OBJ) \ | ||||
|   ui64_to_f32$(OBJ) \ | ||||
|   ui64_to_f64$(OBJ) \ | ||||
|   ui64_to_extF80$(OBJ) \ | ||||
|   ui64_to_extF80M$(OBJ) \ | ||||
|   ui64_to_f128$(OBJ) \ | ||||
|   ui64_to_f128M$(OBJ) \ | ||||
|   i32_to_f16$(OBJ) \ | ||||
|   i32_to_f32$(OBJ) \ | ||||
|   i32_to_f64$(OBJ) \ | ||||
|   i32_to_extF80$(OBJ) \ | ||||
|   i32_to_extF80M$(OBJ) \ | ||||
|   i32_to_f128$(OBJ) \ | ||||
|   i32_to_f128M$(OBJ) \ | ||||
|   i64_to_f16$(OBJ) \ | ||||
|   i64_to_f32$(OBJ) \ | ||||
|   i64_to_f64$(OBJ) \ | ||||
|   i64_to_extF80$(OBJ) \ | ||||
|   i64_to_extF80M$(OBJ) \ | ||||
|   i64_to_f128$(OBJ) \ | ||||
|   i64_to_f128M$(OBJ) \ | ||||
|   f16_to_ui32$(OBJ) \ | ||||
|   f16_to_ui64$(OBJ) \ | ||||
|   f16_to_i32$(OBJ) \ | ||||
|   f16_to_i64$(OBJ) \ | ||||
|   f16_to_ui32_r_minMag$(OBJ) \ | ||||
|   f16_to_ui64_r_minMag$(OBJ) \ | ||||
|   f16_to_i32_r_minMag$(OBJ) \ | ||||
|   f16_to_i64_r_minMag$(OBJ) \ | ||||
|   f16_to_f32$(OBJ) \ | ||||
|   f16_to_f64$(OBJ) \ | ||||
|   f16_to_extF80$(OBJ) \ | ||||
|   f16_to_extF80M$(OBJ) \ | ||||
|   f16_to_f128$(OBJ) \ | ||||
|   f16_to_f128M$(OBJ) \ | ||||
|   f16_roundToInt$(OBJ) \ | ||||
|   f16_add$(OBJ) \ | ||||
|   f16_sub$(OBJ) \ | ||||
|   f16_mul$(OBJ) \ | ||||
|   f16_mulAdd$(OBJ) \ | ||||
|   f16_div$(OBJ) \ | ||||
|   f16_rem$(OBJ) \ | ||||
|   f16_sqrt$(OBJ) \ | ||||
|   f16_eq$(OBJ) \ | ||||
|   f16_le$(OBJ) \ | ||||
|   f16_lt$(OBJ) \ | ||||
|   f16_eq_signaling$(OBJ) \ | ||||
|   f16_le_quiet$(OBJ) \ | ||||
|   f16_lt_quiet$(OBJ) \ | ||||
|   f16_isSignalingNaN$(OBJ) \ | ||||
|   f32_to_ui32$(OBJ) \ | ||||
|   f32_to_ui64$(OBJ) \ | ||||
|   f32_to_i32$(OBJ) \ | ||||
|   f32_to_i64$(OBJ) \ | ||||
|   f32_to_ui32_r_minMag$(OBJ) \ | ||||
|   f32_to_ui64_r_minMag$(OBJ) \ | ||||
|   f32_to_i32_r_minMag$(OBJ) \ | ||||
|   f32_to_i64_r_minMag$(OBJ) \ | ||||
|   f32_to_f16$(OBJ) \ | ||||
|   f32_to_f64$(OBJ) \ | ||||
|   f32_to_extF80$(OBJ) \ | ||||
|   f32_to_extF80M$(OBJ) \ | ||||
|   f32_to_f128$(OBJ) \ | ||||
|   f32_to_f128M$(OBJ) \ | ||||
|   f32_roundToInt$(OBJ) \ | ||||
|   f32_add$(OBJ) \ | ||||
|   f32_sub$(OBJ) \ | ||||
|   f32_mul$(OBJ) \ | ||||
|   f32_mulAdd$(OBJ) \ | ||||
|   f32_div$(OBJ) \ | ||||
|   f32_rem$(OBJ) \ | ||||
|   f32_sqrt$(OBJ) \ | ||||
|   f32_eq$(OBJ) \ | ||||
|   f32_le$(OBJ) \ | ||||
|   f32_lt$(OBJ) \ | ||||
|   f32_eq_signaling$(OBJ) \ | ||||
|   f32_le_quiet$(OBJ) \ | ||||
|   f32_lt_quiet$(OBJ) \ | ||||
|   f32_isSignalingNaN$(OBJ) \ | ||||
|   f64_to_ui32$(OBJ) \ | ||||
|   f64_to_ui64$(OBJ) \ | ||||
|   f64_to_i32$(OBJ) \ | ||||
|   f64_to_i64$(OBJ) \ | ||||
|   f64_to_ui32_r_minMag$(OBJ) \ | ||||
|   f64_to_ui64_r_minMag$(OBJ) \ | ||||
|   f64_to_i32_r_minMag$(OBJ) \ | ||||
|   f64_to_i64_r_minMag$(OBJ) \ | ||||
|   f64_to_f16$(OBJ) \ | ||||
|   f64_to_f32$(OBJ) \ | ||||
|   f64_to_extF80$(OBJ) \ | ||||
|   f64_to_extF80M$(OBJ) \ | ||||
|   f64_to_f128$(OBJ) \ | ||||
|   f64_to_f128M$(OBJ) \ | ||||
|   f64_roundToInt$(OBJ) \ | ||||
|   f64_add$(OBJ) \ | ||||
|   f64_sub$(OBJ) \ | ||||
|   f64_mul$(OBJ) \ | ||||
|   f64_mulAdd$(OBJ) \ | ||||
|   f64_div$(OBJ) \ | ||||
|   f64_rem$(OBJ) \ | ||||
|   f64_sqrt$(OBJ) \ | ||||
|   f64_eq$(OBJ) \ | ||||
|   f64_le$(OBJ) \ | ||||
|   f64_lt$(OBJ) \ | ||||
|   f64_eq_signaling$(OBJ) \ | ||||
|   f64_le_quiet$(OBJ) \ | ||||
|   f64_lt_quiet$(OBJ) \ | ||||
|   f64_isSignalingNaN$(OBJ) \ | ||||
|   extF80_to_ui32$(OBJ) \ | ||||
|   extF80_to_ui64$(OBJ) \ | ||||
|   extF80_to_i32$(OBJ) \ | ||||
|   extF80_to_i64$(OBJ) \ | ||||
|   extF80_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80_to_f16$(OBJ) \ | ||||
|   extF80_to_f32$(OBJ) \ | ||||
|   extF80_to_f64$(OBJ) \ | ||||
|   extF80_to_f128$(OBJ) \ | ||||
|   extF80_roundToInt$(OBJ) \ | ||||
|   extF80_add$(OBJ) \ | ||||
|   extF80_sub$(OBJ) \ | ||||
|   extF80_mul$(OBJ) \ | ||||
|   extF80_div$(OBJ) \ | ||||
|   extF80_rem$(OBJ) \ | ||||
|   extF80_sqrt$(OBJ) \ | ||||
|   extF80_eq$(OBJ) \ | ||||
|   extF80_le$(OBJ) \ | ||||
|   extF80_lt$(OBJ) \ | ||||
|   extF80_eq_signaling$(OBJ) \ | ||||
|   extF80_le_quiet$(OBJ) \ | ||||
|   extF80_lt_quiet$(OBJ) \ | ||||
|   extF80_isSignalingNaN$(OBJ) \ | ||||
|   extF80M_to_ui32$(OBJ) \ | ||||
|   extF80M_to_ui64$(OBJ) \ | ||||
|   extF80M_to_i32$(OBJ) \ | ||||
|   extF80M_to_i64$(OBJ) \ | ||||
|   extF80M_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_f16$(OBJ) \ | ||||
|   extF80M_to_f32$(OBJ) \ | ||||
|   extF80M_to_f64$(OBJ) \ | ||||
|   extF80M_to_f128M$(OBJ) \ | ||||
|   extF80M_roundToInt$(OBJ) \ | ||||
|   extF80M_add$(OBJ) \ | ||||
|   extF80M_sub$(OBJ) \ | ||||
|   extF80M_mul$(OBJ) \ | ||||
|   extF80M_div$(OBJ) \ | ||||
|   extF80M_rem$(OBJ) \ | ||||
|   extF80M_sqrt$(OBJ) \ | ||||
|   extF80M_eq$(OBJ) \ | ||||
|   extF80M_le$(OBJ) \ | ||||
|   extF80M_lt$(OBJ) \ | ||||
|   extF80M_eq_signaling$(OBJ) \ | ||||
|   extF80M_le_quiet$(OBJ) \ | ||||
|   extF80M_lt_quiet$(OBJ) \ | ||||
|   f128_to_ui32$(OBJ) \ | ||||
|   f128_to_ui64$(OBJ) \ | ||||
|   f128_to_i32$(OBJ) \ | ||||
|   f128_to_i64$(OBJ) \ | ||||
|   f128_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128_to_i32_r_minMag$(OBJ) \ | ||||
|   f128_to_i64_r_minMag$(OBJ) \ | ||||
|   f128_to_f16$(OBJ) \ | ||||
|   f128_to_f32$(OBJ) \ | ||||
|   f128_to_extF80$(OBJ) \ | ||||
|   f128_to_f64$(OBJ) \ | ||||
|   f128_roundToInt$(OBJ) \ | ||||
|   f128_add$(OBJ) \ | ||||
|   f128_sub$(OBJ) \ | ||||
|   f128_mul$(OBJ) \ | ||||
|   f128_mulAdd$(OBJ) \ | ||||
|   f128_div$(OBJ) \ | ||||
|   f128_rem$(OBJ) \ | ||||
|   f128_sqrt$(OBJ) \ | ||||
|   f128_eq$(OBJ) \ | ||||
|   f128_le$(OBJ) \ | ||||
|   f128_lt$(OBJ) \ | ||||
|   f128_eq_signaling$(OBJ) \ | ||||
|   f128_le_quiet$(OBJ) \ | ||||
|   f128_lt_quiet$(OBJ) \ | ||||
|   f128_isSignalingNaN$(OBJ) \ | ||||
|   f128M_to_ui32$(OBJ) \ | ||||
|   f128M_to_ui64$(OBJ) \ | ||||
|   f128M_to_i32$(OBJ) \ | ||||
|   f128M_to_i64$(OBJ) \ | ||||
|   f128M_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128M_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128M_to_i32_r_minMag$(OBJ) \ | ||||
|   f128M_to_i64_r_minMag$(OBJ) \ | ||||
|   f128M_to_f16$(OBJ) \ | ||||
|   f128M_to_f32$(OBJ) \ | ||||
|   f128M_to_extF80M$(OBJ) \ | ||||
|   f128M_to_f64$(OBJ) \ | ||||
|   f128M_roundToInt$(OBJ) \ | ||||
|   f128M_add$(OBJ) \ | ||||
|   f128M_sub$(OBJ) \ | ||||
|   f128M_mul$(OBJ) \ | ||||
|   f128M_mulAdd$(OBJ) \ | ||||
|   f128M_div$(OBJ) \ | ||||
|   f128M_rem$(OBJ) \ | ||||
|   f128M_sqrt$(OBJ) \ | ||||
|   f128M_eq$(OBJ) \ | ||||
|   f128M_le$(OBJ) \ | ||||
|   f128M_lt$(OBJ) \ | ||||
|   f128M_eq_signaling$(OBJ) \ | ||||
|   f128M_le_quiet$(OBJ) \ | ||||
|   f128M_lt_quiet$(OBJ) \ | ||||
|  | ||||
| OBJS_ALL = $(OBJS_PRIMITIVES) $(OBJS_SPECIALIZE) $(OBJS_OTHERS) | ||||
|  | ||||
| $(OBJS_ALL): \ | ||||
|   $(OTHER_HEADERS) platform.h $(SOURCE_DIR)/include/primitiveTypes.h \ | ||||
|   $(SOURCE_DIR)/include/primitives.h | ||||
| $(OBJS_SPECIALIZE) $(OBJS_OTHERS): \ | ||||
|   $(SOURCE_DIR)/include/softfloat_types.h $(SOURCE_DIR)/include/internals.h \ | ||||
|   $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/specialize.h \ | ||||
|   $(SOURCE_DIR)/include/softfloat.h | ||||
|  | ||||
| $(OBJS_PRIMITIVES) $(OBJS_OTHERS): %$(OBJ): $(SOURCE_DIR)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$*.c | ||||
|  | ||||
| $(OBJS_SPECIALIZE): %$(OBJ): $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/$*.c | ||||
|  | ||||
| softfloat$(LIB): $(OBJS_ALL) | ||||
| 	$(DELETE) $@ | ||||
| 	$(MAKELIB) $^ | ||||
|  | ||||
| .PHONY: clean | ||||
| clean: | ||||
| 	$(DELETE) $(OBJS_ALL) softfloat$(LIB) | ||||
|  | ||||
|  | ||||
| #============================================================================= | ||||
| # | ||||
| # This Makefile is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| # Package, Release 3e, by John R. Hauser. | ||||
| # | ||||
| # Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| # University of California.  All rights reserved. | ||||
| # | ||||
| # Redistribution and use in source and binary forms, with or without | ||||
| # modification, are permitted provided that the following conditions are met: | ||||
| # | ||||
| #  1. Redistributions of source code must retain the above copyright notice, | ||||
| #     this list of conditions, and the following disclaimer. | ||||
| # | ||||
| #  2. Redistributions in binary form must reproduce the above copyright | ||||
| #     notice, this list of conditions, and the following disclaimer in the | ||||
| #     documentation and/or other materials provided with the distribution. | ||||
| # | ||||
| #  3. Neither the name of the University nor the names of its contributors | ||||
| #     may be used to endorse or promote products derived from this software | ||||
| #     without specific prior written permission. | ||||
| # | ||||
| # THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| # DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||||
| # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| # | ||||
| #============================================================================= | ||||
|  | ||||
| SOURCE_DIR ?= ../../source | ||||
| SPECIALIZE_TYPE ?= 8086-SSE | ||||
|  | ||||
| SOFTFLOAT_OPTS ?= \ | ||||
|   -DSOFTFLOAT_ROUND_ODD -DINLINE_LEVEL=5 -DSOFTFLOAT_FAST_DIV32TO16 \ | ||||
|   -DSOFTFLOAT_FAST_DIV64TO32 | ||||
|  | ||||
| DELETE = rm -f | ||||
| C_INCLUDES = -I. -I$(SOURCE_DIR)/$(SPECIALIZE_TYPE) -I$(SOURCE_DIR)/include | ||||
| COMPILE_C = \ | ||||
|   x86_64-w64-mingw32-gcc -c -Werror-implicit-function-declaration \ | ||||
|     -DSOFTFLOAT_FAST_INT64 $(SOFTFLOAT_OPTS) $(C_INCLUDES) -O2 -o $@ | ||||
| MAKELIB = x86_64-w64-mingw32-ar crs $@ | ||||
|  | ||||
| OBJ = .o | ||||
| LIB = .a | ||||
|  | ||||
| OTHER_HEADERS = $(SOURCE_DIR)/include/opts-GCC.h | ||||
|  | ||||
| .PHONY: all | ||||
| all: softfloat$(LIB) | ||||
|  | ||||
| OBJS_PRIMITIVES = \ | ||||
|   s_eq128$(OBJ) \ | ||||
|   s_le128$(OBJ) \ | ||||
|   s_lt128$(OBJ) \ | ||||
|   s_shortShiftLeft128$(OBJ) \ | ||||
|   s_shortShiftRight128$(OBJ) \ | ||||
|   s_shortShiftRightJam64$(OBJ) \ | ||||
|   s_shortShiftRightJam64Extra$(OBJ) \ | ||||
|   s_shortShiftRightJam128$(OBJ) \ | ||||
|   s_shortShiftRightJam128Extra$(OBJ) \ | ||||
|   s_shiftRightJam32$(OBJ) \ | ||||
|   s_shiftRightJam64$(OBJ) \ | ||||
|   s_shiftRightJam64Extra$(OBJ) \ | ||||
|   s_shiftRightJam128$(OBJ) \ | ||||
|   s_shiftRightJam128Extra$(OBJ) \ | ||||
|   s_shiftRightJam256M$(OBJ) \ | ||||
|   s_countLeadingZeros8$(OBJ) \ | ||||
|   s_countLeadingZeros16$(OBJ) \ | ||||
|   s_countLeadingZeros32$(OBJ) \ | ||||
|   s_countLeadingZeros64$(OBJ) \ | ||||
|   s_add128$(OBJ) \ | ||||
|   s_add256M$(OBJ) \ | ||||
|   s_sub128$(OBJ) \ | ||||
|   s_sub256M$(OBJ) \ | ||||
|   s_mul64ByShifted32To128$(OBJ) \ | ||||
|   s_mul64To128$(OBJ) \ | ||||
|   s_mul128By32$(OBJ) \ | ||||
|   s_mul128To256M$(OBJ) \ | ||||
|   s_approxRecip_1Ks$(OBJ) \ | ||||
|   s_approxRecip32_1$(OBJ) \ | ||||
|   s_approxRecipSqrt_1Ks$(OBJ) \ | ||||
|   s_approxRecipSqrt32_1$(OBJ) \ | ||||
|  | ||||
| OBJS_SPECIALIZE = \ | ||||
|   softfloat_raiseFlags$(OBJ) \ | ||||
|   s_f16UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF16UI$(OBJ) \ | ||||
|   s_propagateNaNF16UI$(OBJ) \ | ||||
|   s_f32UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF32UI$(OBJ) \ | ||||
|   s_propagateNaNF32UI$(OBJ) \ | ||||
|   s_f64UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF64UI$(OBJ) \ | ||||
|   s_propagateNaNF64UI$(OBJ) \ | ||||
|   extF80M_isSignalingNaN$(OBJ) \ | ||||
|   s_extF80UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToExtF80UI$(OBJ) \ | ||||
|   s_propagateNaNExtF80UI$(OBJ) \ | ||||
|   f128M_isSignalingNaN$(OBJ) \ | ||||
|   s_f128UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF128UI$(OBJ) \ | ||||
|   s_propagateNaNF128UI$(OBJ) \ | ||||
|  | ||||
| OBJS_OTHERS = \ | ||||
|   s_roundToUI32$(OBJ) \ | ||||
|   s_roundToUI64$(OBJ) \ | ||||
|   s_roundToI32$(OBJ) \ | ||||
|   s_roundToI64$(OBJ) \ | ||||
|   s_normSubnormalF16Sig$(OBJ) \ | ||||
|   s_roundPackToF16$(OBJ) \ | ||||
|   s_normRoundPackToF16$(OBJ) \ | ||||
|   s_addMagsF16$(OBJ) \ | ||||
|   s_subMagsF16$(OBJ) \ | ||||
|   s_mulAddF16$(OBJ) \ | ||||
|   s_normSubnormalF32Sig$(OBJ) \ | ||||
|   s_roundPackToF32$(OBJ) \ | ||||
|   s_normRoundPackToF32$(OBJ) \ | ||||
|   s_addMagsF32$(OBJ) \ | ||||
|   s_subMagsF32$(OBJ) \ | ||||
|   s_mulAddF32$(OBJ) \ | ||||
|   s_normSubnormalF64Sig$(OBJ) \ | ||||
|   s_roundPackToF64$(OBJ) \ | ||||
|   s_normRoundPackToF64$(OBJ) \ | ||||
|   s_addMagsF64$(OBJ) \ | ||||
|   s_subMagsF64$(OBJ) \ | ||||
|   s_mulAddF64$(OBJ) \ | ||||
|   s_normSubnormalExtF80Sig$(OBJ) \ | ||||
|   s_roundPackToExtF80$(OBJ) \ | ||||
|   s_normRoundPackToExtF80$(OBJ) \ | ||||
|   s_addMagsExtF80$(OBJ) \ | ||||
|   s_subMagsExtF80$(OBJ) \ | ||||
|   s_normSubnormalF128Sig$(OBJ) \ | ||||
|   s_roundPackToF128$(OBJ) \ | ||||
|   s_normRoundPackToF128$(OBJ) \ | ||||
|   s_addMagsF128$(OBJ) \ | ||||
|   s_subMagsF128$(OBJ) \ | ||||
|   s_mulAddF128$(OBJ) \ | ||||
|   softfloat_state$(OBJ) \ | ||||
|   ui32_to_f16$(OBJ) \ | ||||
|   ui32_to_f32$(OBJ) \ | ||||
|   ui32_to_f64$(OBJ) \ | ||||
|   ui32_to_extF80$(OBJ) \ | ||||
|   ui32_to_extF80M$(OBJ) \ | ||||
|   ui32_to_f128$(OBJ) \ | ||||
|   ui32_to_f128M$(OBJ) \ | ||||
|   ui64_to_f16$(OBJ) \ | ||||
|   ui64_to_f32$(OBJ) \ | ||||
|   ui64_to_f64$(OBJ) \ | ||||
|   ui64_to_extF80$(OBJ) \ | ||||
|   ui64_to_extF80M$(OBJ) \ | ||||
|   ui64_to_f128$(OBJ) \ | ||||
|   ui64_to_f128M$(OBJ) \ | ||||
|   i32_to_f16$(OBJ) \ | ||||
|   i32_to_f32$(OBJ) \ | ||||
|   i32_to_f64$(OBJ) \ | ||||
|   i32_to_extF80$(OBJ) \ | ||||
|   i32_to_extF80M$(OBJ) \ | ||||
|   i32_to_f128$(OBJ) \ | ||||
|   i32_to_f128M$(OBJ) \ | ||||
|   i64_to_f16$(OBJ) \ | ||||
|   i64_to_f32$(OBJ) \ | ||||
|   i64_to_f64$(OBJ) \ | ||||
|   i64_to_extF80$(OBJ) \ | ||||
|   i64_to_extF80M$(OBJ) \ | ||||
|   i64_to_f128$(OBJ) \ | ||||
|   i64_to_f128M$(OBJ) \ | ||||
|   f16_to_ui32$(OBJ) \ | ||||
|   f16_to_ui64$(OBJ) \ | ||||
|   f16_to_i32$(OBJ) \ | ||||
|   f16_to_i64$(OBJ) \ | ||||
|   f16_to_ui32_r_minMag$(OBJ) \ | ||||
|   f16_to_ui64_r_minMag$(OBJ) \ | ||||
|   f16_to_i32_r_minMag$(OBJ) \ | ||||
|   f16_to_i64_r_minMag$(OBJ) \ | ||||
|   f16_to_f32$(OBJ) \ | ||||
|   f16_to_f64$(OBJ) \ | ||||
|   f16_to_extF80$(OBJ) \ | ||||
|   f16_to_extF80M$(OBJ) \ | ||||
|   f16_to_f128$(OBJ) \ | ||||
|   f16_to_f128M$(OBJ) \ | ||||
|   f16_roundToInt$(OBJ) \ | ||||
|   f16_add$(OBJ) \ | ||||
|   f16_sub$(OBJ) \ | ||||
|   f16_mul$(OBJ) \ | ||||
|   f16_mulAdd$(OBJ) \ | ||||
|   f16_div$(OBJ) \ | ||||
|   f16_rem$(OBJ) \ | ||||
|   f16_sqrt$(OBJ) \ | ||||
|   f16_eq$(OBJ) \ | ||||
|   f16_le$(OBJ) \ | ||||
|   f16_lt$(OBJ) \ | ||||
|   f16_eq_signaling$(OBJ) \ | ||||
|   f16_le_quiet$(OBJ) \ | ||||
|   f16_lt_quiet$(OBJ) \ | ||||
|   f16_isSignalingNaN$(OBJ) \ | ||||
|   f32_to_ui32$(OBJ) \ | ||||
|   f32_to_ui64$(OBJ) \ | ||||
|   f32_to_i32$(OBJ) \ | ||||
|   f32_to_i64$(OBJ) \ | ||||
|   f32_to_ui32_r_minMag$(OBJ) \ | ||||
|   f32_to_ui64_r_minMag$(OBJ) \ | ||||
|   f32_to_i32_r_minMag$(OBJ) \ | ||||
|   f32_to_i64_r_minMag$(OBJ) \ | ||||
|   f32_to_f16$(OBJ) \ | ||||
|   f32_to_f64$(OBJ) \ | ||||
|   f32_to_extF80$(OBJ) \ | ||||
|   f32_to_extF80M$(OBJ) \ | ||||
|   f32_to_f128$(OBJ) \ | ||||
|   f32_to_f128M$(OBJ) \ | ||||
|   f32_roundToInt$(OBJ) \ | ||||
|   f32_add$(OBJ) \ | ||||
|   f32_sub$(OBJ) \ | ||||
|   f32_mul$(OBJ) \ | ||||
|   f32_mulAdd$(OBJ) \ | ||||
|   f32_div$(OBJ) \ | ||||
|   f32_rem$(OBJ) \ | ||||
|   f32_sqrt$(OBJ) \ | ||||
|   f32_eq$(OBJ) \ | ||||
|   f32_le$(OBJ) \ | ||||
|   f32_lt$(OBJ) \ | ||||
|   f32_eq_signaling$(OBJ) \ | ||||
|   f32_le_quiet$(OBJ) \ | ||||
|   f32_lt_quiet$(OBJ) \ | ||||
|   f32_isSignalingNaN$(OBJ) \ | ||||
|   f64_to_ui32$(OBJ) \ | ||||
|   f64_to_ui64$(OBJ) \ | ||||
|   f64_to_i32$(OBJ) \ | ||||
|   f64_to_i64$(OBJ) \ | ||||
|   f64_to_ui32_r_minMag$(OBJ) \ | ||||
|   f64_to_ui64_r_minMag$(OBJ) \ | ||||
|   f64_to_i32_r_minMag$(OBJ) \ | ||||
|   f64_to_i64_r_minMag$(OBJ) \ | ||||
|   f64_to_f16$(OBJ) \ | ||||
|   f64_to_f32$(OBJ) \ | ||||
|   f64_to_extF80$(OBJ) \ | ||||
|   f64_to_extF80M$(OBJ) \ | ||||
|   f64_to_f128$(OBJ) \ | ||||
|   f64_to_f128M$(OBJ) \ | ||||
|   f64_roundToInt$(OBJ) \ | ||||
|   f64_add$(OBJ) \ | ||||
|   f64_sub$(OBJ) \ | ||||
|   f64_mul$(OBJ) \ | ||||
|   f64_mulAdd$(OBJ) \ | ||||
|   f64_div$(OBJ) \ | ||||
|   f64_rem$(OBJ) \ | ||||
|   f64_sqrt$(OBJ) \ | ||||
|   f64_eq$(OBJ) \ | ||||
|   f64_le$(OBJ) \ | ||||
|   f64_lt$(OBJ) \ | ||||
|   f64_eq_signaling$(OBJ) \ | ||||
|   f64_le_quiet$(OBJ) \ | ||||
|   f64_lt_quiet$(OBJ) \ | ||||
|   f64_isSignalingNaN$(OBJ) \ | ||||
|   extF80_to_ui32$(OBJ) \ | ||||
|   extF80_to_ui64$(OBJ) \ | ||||
|   extF80_to_i32$(OBJ) \ | ||||
|   extF80_to_i64$(OBJ) \ | ||||
|   extF80_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80_to_f16$(OBJ) \ | ||||
|   extF80_to_f32$(OBJ) \ | ||||
|   extF80_to_f64$(OBJ) \ | ||||
|   extF80_to_f128$(OBJ) \ | ||||
|   extF80_roundToInt$(OBJ) \ | ||||
|   extF80_add$(OBJ) \ | ||||
|   extF80_sub$(OBJ) \ | ||||
|   extF80_mul$(OBJ) \ | ||||
|   extF80_div$(OBJ) \ | ||||
|   extF80_rem$(OBJ) \ | ||||
|   extF80_sqrt$(OBJ) \ | ||||
|   extF80_eq$(OBJ) \ | ||||
|   extF80_le$(OBJ) \ | ||||
|   extF80_lt$(OBJ) \ | ||||
|   extF80_eq_signaling$(OBJ) \ | ||||
|   extF80_le_quiet$(OBJ) \ | ||||
|   extF80_lt_quiet$(OBJ) \ | ||||
|   extF80_isSignalingNaN$(OBJ) \ | ||||
|   extF80M_to_ui32$(OBJ) \ | ||||
|   extF80M_to_ui64$(OBJ) \ | ||||
|   extF80M_to_i32$(OBJ) \ | ||||
|   extF80M_to_i64$(OBJ) \ | ||||
|   extF80M_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_f16$(OBJ) \ | ||||
|   extF80M_to_f32$(OBJ) \ | ||||
|   extF80M_to_f64$(OBJ) \ | ||||
|   extF80M_to_f128M$(OBJ) \ | ||||
|   extF80M_roundToInt$(OBJ) \ | ||||
|   extF80M_add$(OBJ) \ | ||||
|   extF80M_sub$(OBJ) \ | ||||
|   extF80M_mul$(OBJ) \ | ||||
|   extF80M_div$(OBJ) \ | ||||
|   extF80M_rem$(OBJ) \ | ||||
|   extF80M_sqrt$(OBJ) \ | ||||
|   extF80M_eq$(OBJ) \ | ||||
|   extF80M_le$(OBJ) \ | ||||
|   extF80M_lt$(OBJ) \ | ||||
|   extF80M_eq_signaling$(OBJ) \ | ||||
|   extF80M_le_quiet$(OBJ) \ | ||||
|   extF80M_lt_quiet$(OBJ) \ | ||||
|   f128_to_ui32$(OBJ) \ | ||||
|   f128_to_ui64$(OBJ) \ | ||||
|   f128_to_i32$(OBJ) \ | ||||
|   f128_to_i64$(OBJ) \ | ||||
|   f128_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128_to_i32_r_minMag$(OBJ) \ | ||||
|   f128_to_i64_r_minMag$(OBJ) \ | ||||
|   f128_to_f16$(OBJ) \ | ||||
|   f128_to_f32$(OBJ) \ | ||||
|   f128_to_extF80$(OBJ) \ | ||||
|   f128_to_f64$(OBJ) \ | ||||
|   f128_roundToInt$(OBJ) \ | ||||
|   f128_add$(OBJ) \ | ||||
|   f128_sub$(OBJ) \ | ||||
|   f128_mul$(OBJ) \ | ||||
|   f128_mulAdd$(OBJ) \ | ||||
|   f128_div$(OBJ) \ | ||||
|   f128_rem$(OBJ) \ | ||||
|   f128_sqrt$(OBJ) \ | ||||
|   f128_eq$(OBJ) \ | ||||
|   f128_le$(OBJ) \ | ||||
|   f128_lt$(OBJ) \ | ||||
|   f128_eq_signaling$(OBJ) \ | ||||
|   f128_le_quiet$(OBJ) \ | ||||
|   f128_lt_quiet$(OBJ) \ | ||||
|   f128_isSignalingNaN$(OBJ) \ | ||||
|   f128M_to_ui32$(OBJ) \ | ||||
|   f128M_to_ui64$(OBJ) \ | ||||
|   f128M_to_i32$(OBJ) \ | ||||
|   f128M_to_i64$(OBJ) \ | ||||
|   f128M_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128M_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128M_to_i32_r_minMag$(OBJ) \ | ||||
|   f128M_to_i64_r_minMag$(OBJ) \ | ||||
|   f128M_to_f16$(OBJ) \ | ||||
|   f128M_to_f32$(OBJ) \ | ||||
|   f128M_to_extF80M$(OBJ) \ | ||||
|   f128M_to_f64$(OBJ) \ | ||||
|   f128M_roundToInt$(OBJ) \ | ||||
|   f128M_add$(OBJ) \ | ||||
|   f128M_sub$(OBJ) \ | ||||
|   f128M_mul$(OBJ) \ | ||||
|   f128M_mulAdd$(OBJ) \ | ||||
|   f128M_div$(OBJ) \ | ||||
|   f128M_rem$(OBJ) \ | ||||
|   f128M_sqrt$(OBJ) \ | ||||
|   f128M_eq$(OBJ) \ | ||||
|   f128M_le$(OBJ) \ | ||||
|   f128M_lt$(OBJ) \ | ||||
|   f128M_eq_signaling$(OBJ) \ | ||||
|   f128M_le_quiet$(OBJ) \ | ||||
|   f128M_lt_quiet$(OBJ) \ | ||||
|  | ||||
| OBJS_ALL = $(OBJS_PRIMITIVES) $(OBJS_SPECIALIZE) $(OBJS_OTHERS) | ||||
|  | ||||
| $(OBJS_ALL): \ | ||||
|   $(OTHER_HEADERS) platform.h $(SOURCE_DIR)/include/primitiveTypes.h \ | ||||
|   $(SOURCE_DIR)/include/primitives.h | ||||
| $(OBJS_SPECIALIZE) $(OBJS_OTHERS): \ | ||||
|   $(SOURCE_DIR)/include/softfloat_types.h $(SOURCE_DIR)/include/internals.h \ | ||||
|   $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/specialize.h \ | ||||
|   $(SOURCE_DIR)/include/softfloat.h | ||||
|  | ||||
| $(OBJS_PRIMITIVES) $(OBJS_OTHERS): %$(OBJ): $(SOURCE_DIR)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$*.c | ||||
|  | ||||
| $(OBJS_SPECIALIZE): %$(OBJ): $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/$*.c | ||||
|  | ||||
| softfloat$(LIB): $(OBJS_ALL) | ||||
| 	$(DELETE) $@ | ||||
| 	$(MAKELIB) $^ | ||||
|  | ||||
| .PHONY: clean | ||||
| clean: | ||||
| 	$(DELETE) $(OBJS_ALL) softfloat$(LIB) | ||||
|  | ||||
|   | ||||
| @@ -1,53 +1,54 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #define LITTLEENDIAN 1 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #ifdef __GNUC_STDC_INLINE__ | ||||
| #define INLINE inline | ||||
| #else | ||||
| #define INLINE extern inline | ||||
| #endif | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| #define SOFTFLOAT_BUILTIN_CLZ 1 | ||||
| #define SOFTFLOAT_INTRINSIC_INT128 1 | ||||
| #include "opts-GCC.h" | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define LITTLEENDIAN 1 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #ifdef __GNUC_STDC_INLINE__ | ||||
| #define INLINE inline | ||||
| #else | ||||
| #define INLINE extern inline | ||||
| #endif | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define SOFTFLOAT_BUILTIN_CLZ 1 | ||||
| #define SOFTFLOAT_INTRINSIC_INT128 1 | ||||
| #include "opts-GCC.h" | ||||
|  | ||||
|   | ||||
| @@ -1,391 +1,396 @@ | ||||
|  | ||||
| #============================================================================= | ||||
| # | ||||
| # This Makefile template is part of the SoftFloat IEEE Floating-Point | ||||
| # Arithmetic Package, Release 3e, by John R. Hauser. | ||||
| # | ||||
| # Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| # University of California.  All rights reserved. | ||||
| # | ||||
| # Redistribution and use in source and binary forms, with or without | ||||
| # modification, are permitted provided that the following conditions are met: | ||||
| # | ||||
| #  1. Redistributions of source code must retain the above copyright notice, | ||||
| #     this list of conditions, and the following disclaimer. | ||||
| # | ||||
| #  2. Redistributions in binary form must reproduce the above copyright | ||||
| #     notice, this list of conditions, and the following disclaimer in the | ||||
| #     documentation and/or other materials provided with the distribution. | ||||
| # | ||||
| #  3. Neither the name of the University nor the names of its contributors | ||||
| #     may be used to endorse or promote products derived from this software | ||||
| #     without specific prior written permission. | ||||
| # | ||||
| # THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| # DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||||
| # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| # | ||||
| #============================================================================= | ||||
|  | ||||
| # Edit lines marked with `==>'.  See "SoftFloat-source.html". | ||||
|  | ||||
| ==> SOURCE_DIR ?= ../../source | ||||
| ==> SPECIALIZE_TYPE ?= 8086 | ||||
|  | ||||
| ==> SOFTFLOAT_OPTS ?= \ | ||||
| ==>   -DSOFTFLOAT_ROUND_ODD -DINLINE_LEVEL=5 -DSOFTFLOAT_FAST_DIV32TO16 \ | ||||
| ==>   -DSOFTFLOAT_FAST_DIV64TO32 | ||||
|  | ||||
| ==> DELETE = rm -f | ||||
| ==> C_INCLUDES = -I. -I$(SOURCE_DIR)/$(SPECIALIZE_TYPE) -I$(SOURCE_DIR)/include | ||||
| ==> COMPILE_C = \ | ||||
| ==>   cc -c -DSOFTFLOAT_FAST_INT64 $(SOFTFLOAT_OPTS) $(C_INCLUDES) -O2 -o $@ | ||||
| ==> MAKELIB = ar crs $@ | ||||
|  | ||||
| ==> OBJ = .o | ||||
| ==> LIB = .a | ||||
|  | ||||
| ==> OTHER_HEADERS = | ||||
|  | ||||
| .PHONY: all | ||||
| all: softfloat$(LIB) | ||||
|  | ||||
| OBJS_PRIMITIVES = \ | ||||
|   s_eq128$(OBJ) \ | ||||
|   s_le128$(OBJ) \ | ||||
|   s_lt128$(OBJ) \ | ||||
|   s_shortShiftLeft128$(OBJ) \ | ||||
|   s_shortShiftRight128$(OBJ) \ | ||||
|   s_shortShiftRightJam64$(OBJ) \ | ||||
|   s_shortShiftRightJam64Extra$(OBJ) \ | ||||
|   s_shortShiftRightJam128$(OBJ) \ | ||||
|   s_shortShiftRightJam128Extra$(OBJ) \ | ||||
|   s_shiftRightJam32$(OBJ) \ | ||||
|   s_shiftRightJam64$(OBJ) \ | ||||
|   s_shiftRightJam64Extra$(OBJ) \ | ||||
|   s_shiftRightJam128$(OBJ) \ | ||||
|   s_shiftRightJam128Extra$(OBJ) \ | ||||
|   s_shiftRightJam256M$(OBJ) \ | ||||
|   s_countLeadingZeros8$(OBJ) \ | ||||
|   s_countLeadingZeros16$(OBJ) \ | ||||
|   s_countLeadingZeros32$(OBJ) \ | ||||
|   s_countLeadingZeros64$(OBJ) \ | ||||
|   s_add128$(OBJ) \ | ||||
|   s_add256M$(OBJ) \ | ||||
|   s_sub128$(OBJ) \ | ||||
|   s_sub256M$(OBJ) \ | ||||
|   s_mul64ByShifted32To128$(OBJ) \ | ||||
|   s_mul64To128$(OBJ) \ | ||||
|   s_mul128By32$(OBJ) \ | ||||
|   s_mul128To256M$(OBJ) \ | ||||
|   s_approxRecip_1Ks$(OBJ) \ | ||||
|   s_approxRecip32_1$(OBJ) \ | ||||
|   s_approxRecipSqrt_1Ks$(OBJ) \ | ||||
|   s_approxRecipSqrt32_1$(OBJ) \ | ||||
|  | ||||
| OBJS_SPECIALIZE = \ | ||||
|   softfloat_raiseFlags$(OBJ) \ | ||||
|   s_f16UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF16UI$(OBJ) \ | ||||
|   s_propagateNaNF16UI$(OBJ) \ | ||||
|   s_f32UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF32UI$(OBJ) \ | ||||
|   s_propagateNaNF32UI$(OBJ) \ | ||||
|   s_f64UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF64UI$(OBJ) \ | ||||
|   s_propagateNaNF64UI$(OBJ) \ | ||||
|   extF80M_isSignalingNaN$(OBJ) \ | ||||
|   s_extF80UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToExtF80UI$(OBJ) \ | ||||
|   s_propagateNaNExtF80UI$(OBJ) \ | ||||
|   f128M_isSignalingNaN$(OBJ) \ | ||||
|   s_f128UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF128UI$(OBJ) \ | ||||
|   s_propagateNaNF128UI$(OBJ) \ | ||||
|  | ||||
| OBJS_OTHERS = \ | ||||
|   s_roundToUI32$(OBJ) \ | ||||
|   s_roundToUI64$(OBJ) \ | ||||
|   s_roundToI32$(OBJ) \ | ||||
|   s_roundToI64$(OBJ) \ | ||||
|   s_normSubnormalF16Sig$(OBJ) \ | ||||
|   s_roundPackToF16$(OBJ) \ | ||||
|   s_normRoundPackToF16$(OBJ) \ | ||||
|   s_addMagsF16$(OBJ) \ | ||||
|   s_subMagsF16$(OBJ) \ | ||||
|   s_mulAddF16$(OBJ) \ | ||||
|   s_normSubnormalF32Sig$(OBJ) \ | ||||
|   s_roundPackToF32$(OBJ) \ | ||||
|   s_normRoundPackToF32$(OBJ) \ | ||||
|   s_addMagsF32$(OBJ) \ | ||||
|   s_subMagsF32$(OBJ) \ | ||||
|   s_mulAddF32$(OBJ) \ | ||||
|   s_normSubnormalF64Sig$(OBJ) \ | ||||
|   s_roundPackToF64$(OBJ) \ | ||||
|   s_normRoundPackToF64$(OBJ) \ | ||||
|   s_addMagsF64$(OBJ) \ | ||||
|   s_subMagsF64$(OBJ) \ | ||||
|   s_mulAddF64$(OBJ) \ | ||||
|   s_normSubnormalExtF80Sig$(OBJ) \ | ||||
|   s_roundPackToExtF80$(OBJ) \ | ||||
|   s_normRoundPackToExtF80$(OBJ) \ | ||||
|   s_addMagsExtF80$(OBJ) \ | ||||
|   s_subMagsExtF80$(OBJ) \ | ||||
|   s_normSubnormalF128Sig$(OBJ) \ | ||||
|   s_roundPackToF128$(OBJ) \ | ||||
|   s_normRoundPackToF128$(OBJ) \ | ||||
|   s_addMagsF128$(OBJ) \ | ||||
|   s_subMagsF128$(OBJ) \ | ||||
|   s_mulAddF128$(OBJ) \ | ||||
|   softfloat_state$(OBJ) \ | ||||
|   ui32_to_f16$(OBJ) \ | ||||
|   ui32_to_f32$(OBJ) \ | ||||
|   ui32_to_f64$(OBJ) \ | ||||
|   ui32_to_extF80$(OBJ) \ | ||||
|   ui32_to_extF80M$(OBJ) \ | ||||
|   ui32_to_f128$(OBJ) \ | ||||
|   ui32_to_f128M$(OBJ) \ | ||||
|   ui64_to_f16$(OBJ) \ | ||||
|   ui64_to_f32$(OBJ) \ | ||||
|   ui64_to_f64$(OBJ) \ | ||||
|   ui64_to_extF80$(OBJ) \ | ||||
|   ui64_to_extF80M$(OBJ) \ | ||||
|   ui64_to_f128$(OBJ) \ | ||||
|   ui64_to_f128M$(OBJ) \ | ||||
|   i32_to_f16$(OBJ) \ | ||||
|   i32_to_f32$(OBJ) \ | ||||
|   i32_to_f64$(OBJ) \ | ||||
|   i32_to_extF80$(OBJ) \ | ||||
|   i32_to_extF80M$(OBJ) \ | ||||
|   i32_to_f128$(OBJ) \ | ||||
|   i32_to_f128M$(OBJ) \ | ||||
|   i64_to_f16$(OBJ) \ | ||||
|   i64_to_f32$(OBJ) \ | ||||
|   i64_to_f64$(OBJ) \ | ||||
|   i64_to_extF80$(OBJ) \ | ||||
|   i64_to_extF80M$(OBJ) \ | ||||
|   i64_to_f128$(OBJ) \ | ||||
|   i64_to_f128M$(OBJ) \ | ||||
|   f16_to_ui32$(OBJ) \ | ||||
|   f16_to_ui64$(OBJ) \ | ||||
|   f16_to_i32$(OBJ) \ | ||||
|   f16_to_i64$(OBJ) \ | ||||
|   f16_to_ui32_r_minMag$(OBJ) \ | ||||
|   f16_to_ui64_r_minMag$(OBJ) \ | ||||
|   f16_to_i32_r_minMag$(OBJ) \ | ||||
|   f16_to_i64_r_minMag$(OBJ) \ | ||||
|   f16_to_f32$(OBJ) \ | ||||
|   f16_to_f64$(OBJ) \ | ||||
|   f16_to_extF80$(OBJ) \ | ||||
|   f16_to_extF80M$(OBJ) \ | ||||
|   f16_to_f128$(OBJ) \ | ||||
|   f16_to_f128M$(OBJ) \ | ||||
|   f16_roundToInt$(OBJ) \ | ||||
|   f16_add$(OBJ) \ | ||||
|   f16_sub$(OBJ) \ | ||||
|   f16_mul$(OBJ) \ | ||||
|   f16_mulAdd$(OBJ) \ | ||||
|   f16_div$(OBJ) \ | ||||
|   f16_rem$(OBJ) \ | ||||
|   f16_sqrt$(OBJ) \ | ||||
|   f16_eq$(OBJ) \ | ||||
|   f16_le$(OBJ) \ | ||||
|   f16_lt$(OBJ) \ | ||||
|   f16_eq_signaling$(OBJ) \ | ||||
|   f16_le_quiet$(OBJ) \ | ||||
|   f16_lt_quiet$(OBJ) \ | ||||
|   f16_isSignalingNaN$(OBJ) \ | ||||
|   f32_to_ui32$(OBJ) \ | ||||
|   f32_to_ui64$(OBJ) \ | ||||
|   f32_to_i32$(OBJ) \ | ||||
|   f32_to_i64$(OBJ) \ | ||||
|   f32_to_ui32_r_minMag$(OBJ) \ | ||||
|   f32_to_ui64_r_minMag$(OBJ) \ | ||||
|   f32_to_i32_r_minMag$(OBJ) \ | ||||
|   f32_to_i64_r_minMag$(OBJ) \ | ||||
|   f32_to_f16$(OBJ) \ | ||||
|   f32_to_f64$(OBJ) \ | ||||
|   f32_to_extF80$(OBJ) \ | ||||
|   f32_to_extF80M$(OBJ) \ | ||||
|   f32_to_f128$(OBJ) \ | ||||
|   f32_to_f128M$(OBJ) \ | ||||
|   f32_roundToInt$(OBJ) \ | ||||
|   f32_add$(OBJ) \ | ||||
|   f32_sub$(OBJ) \ | ||||
|   f32_mul$(OBJ) \ | ||||
|   f32_mulAdd$(OBJ) \ | ||||
|   f32_div$(OBJ) \ | ||||
|   f32_rem$(OBJ) \ | ||||
|   f32_sqrt$(OBJ) \ | ||||
|   f32_eq$(OBJ) \ | ||||
|   f32_le$(OBJ) \ | ||||
|   f32_lt$(OBJ) \ | ||||
|   f32_eq_signaling$(OBJ) \ | ||||
|   f32_le_quiet$(OBJ) \ | ||||
|   f32_lt_quiet$(OBJ) \ | ||||
|   f32_isSignalingNaN$(OBJ) \ | ||||
|   f64_to_ui32$(OBJ) \ | ||||
|   f64_to_ui64$(OBJ) \ | ||||
|   f64_to_i32$(OBJ) \ | ||||
|   f64_to_i64$(OBJ) \ | ||||
|   f64_to_ui32_r_minMag$(OBJ) \ | ||||
|   f64_to_ui64_r_minMag$(OBJ) \ | ||||
|   f64_to_i32_r_minMag$(OBJ) \ | ||||
|   f64_to_i64_r_minMag$(OBJ) \ | ||||
|   f64_to_f16$(OBJ) \ | ||||
|   f64_to_f32$(OBJ) \ | ||||
|   f64_to_extF80$(OBJ) \ | ||||
|   f64_to_extF80M$(OBJ) \ | ||||
|   f64_to_f128$(OBJ) \ | ||||
|   f64_to_f128M$(OBJ) \ | ||||
|   f64_roundToInt$(OBJ) \ | ||||
|   f64_add$(OBJ) \ | ||||
|   f64_sub$(OBJ) \ | ||||
|   f64_mul$(OBJ) \ | ||||
|   f64_mulAdd$(OBJ) \ | ||||
|   f64_div$(OBJ) \ | ||||
|   f64_rem$(OBJ) \ | ||||
|   f64_sqrt$(OBJ) \ | ||||
|   f64_eq$(OBJ) \ | ||||
|   f64_le$(OBJ) \ | ||||
|   f64_lt$(OBJ) \ | ||||
|   f64_eq_signaling$(OBJ) \ | ||||
|   f64_le_quiet$(OBJ) \ | ||||
|   f64_lt_quiet$(OBJ) \ | ||||
|   f64_isSignalingNaN$(OBJ) \ | ||||
|   extF80_to_ui32$(OBJ) \ | ||||
|   extF80_to_ui64$(OBJ) \ | ||||
|   extF80_to_i32$(OBJ) \ | ||||
|   extF80_to_i64$(OBJ) \ | ||||
|   extF80_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80_to_f16$(OBJ) \ | ||||
|   extF80_to_f32$(OBJ) \ | ||||
|   extF80_to_f64$(OBJ) \ | ||||
|   extF80_to_f128$(OBJ) \ | ||||
|   extF80_roundToInt$(OBJ) \ | ||||
|   extF80_add$(OBJ) \ | ||||
|   extF80_sub$(OBJ) \ | ||||
|   extF80_mul$(OBJ) \ | ||||
|   extF80_div$(OBJ) \ | ||||
|   extF80_rem$(OBJ) \ | ||||
|   extF80_sqrt$(OBJ) \ | ||||
|   extF80_eq$(OBJ) \ | ||||
|   extF80_le$(OBJ) \ | ||||
|   extF80_lt$(OBJ) \ | ||||
|   extF80_eq_signaling$(OBJ) \ | ||||
|   extF80_le_quiet$(OBJ) \ | ||||
|   extF80_lt_quiet$(OBJ) \ | ||||
|   extF80_isSignalingNaN$(OBJ) \ | ||||
|   extF80M_to_ui32$(OBJ) \ | ||||
|   extF80M_to_ui64$(OBJ) \ | ||||
|   extF80M_to_i32$(OBJ) \ | ||||
|   extF80M_to_i64$(OBJ) \ | ||||
|   extF80M_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_f16$(OBJ) \ | ||||
|   extF80M_to_f32$(OBJ) \ | ||||
|   extF80M_to_f64$(OBJ) \ | ||||
|   extF80M_to_f128M$(OBJ) \ | ||||
|   extF80M_roundToInt$(OBJ) \ | ||||
|   extF80M_add$(OBJ) \ | ||||
|   extF80M_sub$(OBJ) \ | ||||
|   extF80M_mul$(OBJ) \ | ||||
|   extF80M_div$(OBJ) \ | ||||
|   extF80M_rem$(OBJ) \ | ||||
|   extF80M_sqrt$(OBJ) \ | ||||
|   extF80M_eq$(OBJ) \ | ||||
|   extF80M_le$(OBJ) \ | ||||
|   extF80M_lt$(OBJ) \ | ||||
|   extF80M_eq_signaling$(OBJ) \ | ||||
|   extF80M_le_quiet$(OBJ) \ | ||||
|   extF80M_lt_quiet$(OBJ) \ | ||||
|   f128_to_ui32$(OBJ) \ | ||||
|   f128_to_ui64$(OBJ) \ | ||||
|   f128_to_i32$(OBJ) \ | ||||
|   f128_to_i64$(OBJ) \ | ||||
|   f128_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128_to_i32_r_minMag$(OBJ) \ | ||||
|   f128_to_i64_r_minMag$(OBJ) \ | ||||
|   f128_to_f16$(OBJ) \ | ||||
|   f128_to_f32$(OBJ) \ | ||||
|   f128_to_extF80$(OBJ) \ | ||||
|   f128_to_f64$(OBJ) \ | ||||
|   f128_roundToInt$(OBJ) \ | ||||
|   f128_add$(OBJ) \ | ||||
|   f128_sub$(OBJ) \ | ||||
|   f128_mul$(OBJ) \ | ||||
|   f128_mulAdd$(OBJ) \ | ||||
|   f128_div$(OBJ) \ | ||||
|   f128_rem$(OBJ) \ | ||||
|   f128_sqrt$(OBJ) \ | ||||
|   f128_eq$(OBJ) \ | ||||
|   f128_le$(OBJ) \ | ||||
|   f128_lt$(OBJ) \ | ||||
|   f128_eq_signaling$(OBJ) \ | ||||
|   f128_le_quiet$(OBJ) \ | ||||
|   f128_lt_quiet$(OBJ) \ | ||||
|   f128_isSignalingNaN$(OBJ) \ | ||||
|   f128M_to_ui32$(OBJ) \ | ||||
|   f128M_to_ui64$(OBJ) \ | ||||
|   f128M_to_i32$(OBJ) \ | ||||
|   f128M_to_i64$(OBJ) \ | ||||
|   f128M_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128M_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128M_to_i32_r_minMag$(OBJ) \ | ||||
|   f128M_to_i64_r_minMag$(OBJ) \ | ||||
|   f128M_to_f16$(OBJ) \ | ||||
|   f128M_to_f32$(OBJ) \ | ||||
|   f128M_to_extF80M$(OBJ) \ | ||||
|   f128M_to_f64$(OBJ) \ | ||||
|   f128M_roundToInt$(OBJ) \ | ||||
|   f128M_add$(OBJ) \ | ||||
|   f128M_sub$(OBJ) \ | ||||
|   f128M_mul$(OBJ) \ | ||||
|   f128M_mulAdd$(OBJ) \ | ||||
|   f128M_div$(OBJ) \ | ||||
|   f128M_rem$(OBJ) \ | ||||
|   f128M_sqrt$(OBJ) \ | ||||
|   f128M_eq$(OBJ) \ | ||||
|   f128M_le$(OBJ) \ | ||||
|   f128M_lt$(OBJ) \ | ||||
|   f128M_eq_signaling$(OBJ) \ | ||||
|   f128M_le_quiet$(OBJ) \ | ||||
|   f128M_lt_quiet$(OBJ) \ | ||||
|  | ||||
| OBJS_ALL = $(OBJS_PRIMITIVES) $(OBJS_SPECIALIZE) $(OBJS_OTHERS) | ||||
|  | ||||
| $(OBJS_ALL): \ | ||||
|   $(OTHER_HEADERS) platform.h $(SOURCE_DIR)/include/primitiveTypes.h \ | ||||
|   $(SOURCE_DIR)/include/primitives.h | ||||
| $(OBJS_SPECIALIZE) $(OBJS_OTHERS): \ | ||||
|   $(SOURCE_DIR)/include/softfloat_types.h $(SOURCE_DIR)/include/internals.h \ | ||||
|   $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/specialize.h \ | ||||
|   $(SOURCE_DIR)/include/softfloat.h | ||||
|  | ||||
| $(OBJS_PRIMITIVES) $(OBJS_OTHERS): %$(OBJ): $(SOURCE_DIR)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$*.c | ||||
|  | ||||
| $(OBJS_SPECIALIZE): %$(OBJ): $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/$*.c | ||||
|  | ||||
| softfloat$(LIB): $(OBJS_ALL) | ||||
| 	$(DELETE) $@ | ||||
| 	$(MAKELIB) $^ | ||||
|  | ||||
| .PHONY: clean | ||||
| clean: | ||||
| 	$(DELETE) $(OBJS_ALL) softfloat$(LIB) | ||||
|  | ||||
|  | ||||
| #============================================================================= | ||||
| # | ||||
| # This Makefile template is part of the SoftFloat IEEE Floating-Point | ||||
| # Arithmetic Package, Release 3e, by John R. Hauser. | ||||
| # | ||||
| # Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| # University of California.  All rights reserved. | ||||
| # | ||||
| # Redistribution and use in source and binary forms, with or without | ||||
| # modification, are permitted provided that the following conditions are met: | ||||
| # | ||||
| #  1. Redistributions of source code must retain the above copyright notice, | ||||
| #     this list of conditions, and the following disclaimer. | ||||
| # | ||||
| #  2. Redistributions in binary form must reproduce the above copyright | ||||
| #     notice, this list of conditions, and the following disclaimer in the | ||||
| #     documentation and/or other materials provided with the distribution. | ||||
| # | ||||
| #  3. Neither the name of the University nor the names of its contributors | ||||
| #     may be used to endorse or promote products derived from this software | ||||
| #     without specific prior written permission. | ||||
| # | ||||
| # THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| # DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||||
| # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| # | ||||
| #============================================================================= | ||||
|  | ||||
| # Edit lines marked with `==>'.  See "SoftFloat-source.html". | ||||
|  | ||||
| ==> SOURCE_DIR ?= ../../source | ||||
| ==> SPECIALIZE_TYPE ?= 8086 | ||||
|  | ||||
| ==> SOFTFLOAT_OPTS ?= \ | ||||
| ==>   -DSOFTFLOAT_ROUND_ODD -DINLINE_LEVEL=5 -DSOFTFLOAT_FAST_DIV32TO16 \ | ||||
| ==>   -DSOFTFLOAT_FAST_DIV64TO32 | ||||
|  | ||||
| ==> DELETE = rm -f | ||||
| ==> C_INCLUDES = -I. -I$(SOURCE_DIR)/$(SPECIALIZE_TYPE) -I$(SOURCE_DIR)/include | ||||
| ==> COMPILE_C = \ | ||||
| ==>   cc -c -DSOFTFLOAT_FAST_INT64 $(SOFTFLOAT_OPTS) $(C_INCLUDES) -O2 -o $@ | ||||
| ==> MAKELIB = ar crs $@ | ||||
|  | ||||
| ==> OBJ = .o | ||||
| ==> LIB = .a | ||||
|  | ||||
| ==> OTHER_HEADERS = | ||||
|  | ||||
| .PHONY: all | ||||
| all: softfloat$(LIB) | ||||
|  | ||||
| OBJS_PRIMITIVES = \ | ||||
|   s_eq128$(OBJ) \ | ||||
|   s_le128$(OBJ) \ | ||||
|   s_lt128$(OBJ) \ | ||||
|   s_shortShiftLeft128$(OBJ) \ | ||||
|   s_shortShiftRight128$(OBJ) \ | ||||
|   s_shortShiftRightJam64$(OBJ) \ | ||||
|   s_shortShiftRightJam64Extra$(OBJ) \ | ||||
|   s_shortShiftRightJam128$(OBJ) \ | ||||
|   s_shortShiftRightJam128Extra$(OBJ) \ | ||||
|   s_shiftRightJam32$(OBJ) \ | ||||
|   s_shiftRightJam64$(OBJ) \ | ||||
|   s_shiftRightJam64Extra$(OBJ) \ | ||||
|   s_shiftRightJam128$(OBJ) \ | ||||
|   s_shiftRightJam128Extra$(OBJ) \ | ||||
|   s_shiftRightJam256M$(OBJ) \ | ||||
|   s_countLeadingZeros8$(OBJ) \ | ||||
|   s_countLeadingZeros16$(OBJ) \ | ||||
|   s_countLeadingZeros32$(OBJ) \ | ||||
|   s_countLeadingZeros64$(OBJ) \ | ||||
|   s_add128$(OBJ) \ | ||||
|   s_add256M$(OBJ) \ | ||||
|   s_sub128$(OBJ) \ | ||||
|   s_sub256M$(OBJ) \ | ||||
|   s_mul64ByShifted32To128$(OBJ) \ | ||||
|   s_mul64To128$(OBJ) \ | ||||
|   s_mul128By32$(OBJ) \ | ||||
|   s_mul128To256M$(OBJ) \ | ||||
|   s_approxRecip_1Ks$(OBJ) \ | ||||
|   s_approxRecip32_1$(OBJ) \ | ||||
|   s_approxRecipSqrt_1Ks$(OBJ) \ | ||||
|   s_approxRecipSqrt32_1$(OBJ) \ | ||||
|  | ||||
| OBJS_SPECIALIZE = \ | ||||
|   softfloat_raiseFlags$(OBJ) \ | ||||
|   s_f16UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF16UI$(OBJ) \ | ||||
|   s_propagateNaNF16UI$(OBJ) \ | ||||
|   s_f32UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF32UI$(OBJ) \ | ||||
|   s_propagateNaNF32UI$(OBJ) \ | ||||
|   s_f64UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF64UI$(OBJ) \ | ||||
|   s_propagateNaNF64UI$(OBJ) \ | ||||
|   extF80M_isSignalingNaN$(OBJ) \ | ||||
|   s_extF80UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToExtF80UI$(OBJ) \ | ||||
|   s_propagateNaNExtF80UI$(OBJ) \ | ||||
|   f128M_isSignalingNaN$(OBJ) \ | ||||
|   s_f128UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF128UI$(OBJ) \ | ||||
|   s_propagateNaNF128UI$(OBJ) \ | ||||
|  | ||||
| OBJS_OTHERS = \ | ||||
|   s_roundToUI32$(OBJ) \ | ||||
|   s_roundToUI64$(OBJ) \ | ||||
|   s_roundToI32$(OBJ) \ | ||||
|   s_roundToI64$(OBJ) \ | ||||
|   s_normSubnormalBF16Sig$(OBJ) \ | ||||
|   s_roundPackToBF16$(OBJ) \ | ||||
|   s_normSubnormalF16Sig$(OBJ) \ | ||||
|   s_roundPackToF16$(OBJ) \ | ||||
|   s_normRoundPackToF16$(OBJ) \ | ||||
|   s_addMagsF16$(OBJ) \ | ||||
|   s_subMagsF16$(OBJ) \ | ||||
|   s_mulAddF16$(OBJ) \ | ||||
|   s_normSubnormalF32Sig$(OBJ) \ | ||||
|   s_roundPackToF32$(OBJ) \ | ||||
|   s_normRoundPackToF32$(OBJ) \ | ||||
|   s_addMagsF32$(OBJ) \ | ||||
|   s_subMagsF32$(OBJ) \ | ||||
|   s_mulAddF32$(OBJ) \ | ||||
|   s_normSubnormalF64Sig$(OBJ) \ | ||||
|   s_roundPackToF64$(OBJ) \ | ||||
|   s_normRoundPackToF64$(OBJ) \ | ||||
|   s_addMagsF64$(OBJ) \ | ||||
|   s_subMagsF64$(OBJ) \ | ||||
|   s_mulAddF64$(OBJ) \ | ||||
|   s_normSubnormalExtF80Sig$(OBJ) \ | ||||
|   s_roundPackToExtF80$(OBJ) \ | ||||
|   s_normRoundPackToExtF80$(OBJ) \ | ||||
|   s_addMagsExtF80$(OBJ) \ | ||||
|   s_subMagsExtF80$(OBJ) \ | ||||
|   s_normSubnormalF128Sig$(OBJ) \ | ||||
|   s_roundPackToF128$(OBJ) \ | ||||
|   s_normRoundPackToF128$(OBJ) \ | ||||
|   s_addMagsF128$(OBJ) \ | ||||
|   s_subMagsF128$(OBJ) \ | ||||
|   s_mulAddF128$(OBJ) \ | ||||
|   softfloat_state$(OBJ) \ | ||||
|   ui32_to_f16$(OBJ) \ | ||||
|   ui32_to_f32$(OBJ) \ | ||||
|   ui32_to_f64$(OBJ) \ | ||||
|   ui32_to_extF80$(OBJ) \ | ||||
|   ui32_to_extF80M$(OBJ) \ | ||||
|   ui32_to_f128$(OBJ) \ | ||||
|   ui32_to_f128M$(OBJ) \ | ||||
|   ui64_to_f16$(OBJ) \ | ||||
|   ui64_to_f32$(OBJ) \ | ||||
|   ui64_to_f64$(OBJ) \ | ||||
|   ui64_to_extF80$(OBJ) \ | ||||
|   ui64_to_extF80M$(OBJ) \ | ||||
|   ui64_to_f128$(OBJ) \ | ||||
|   ui64_to_f128M$(OBJ) \ | ||||
|   i32_to_f16$(OBJ) \ | ||||
|   i32_to_f32$(OBJ) \ | ||||
|   i32_to_f64$(OBJ) \ | ||||
|   i32_to_extF80$(OBJ) \ | ||||
|   i32_to_extF80M$(OBJ) \ | ||||
|   i32_to_f128$(OBJ) \ | ||||
|   i32_to_f128M$(OBJ) \ | ||||
|   i64_to_f16$(OBJ) \ | ||||
|   i64_to_f32$(OBJ) \ | ||||
|   i64_to_f64$(OBJ) \ | ||||
|   i64_to_extF80$(OBJ) \ | ||||
|   i64_to_extF80M$(OBJ) \ | ||||
|   i64_to_f128$(OBJ) \ | ||||
|   i64_to_f128M$(OBJ) \ | ||||
|   bf16_isSignalingNaN$(OBJ) \ | ||||
|   bf16_to_f32$(OBJ) \ | ||||
|   f16_to_ui32$(OBJ) \ | ||||
|   f16_to_ui64$(OBJ) \ | ||||
|   f16_to_i32$(OBJ) \ | ||||
|   f16_to_i64$(OBJ) \ | ||||
|   f16_to_ui32_r_minMag$(OBJ) \ | ||||
|   f16_to_ui64_r_minMag$(OBJ) \ | ||||
|   f16_to_i32_r_minMag$(OBJ) \ | ||||
|   f16_to_i64_r_minMag$(OBJ) \ | ||||
|   f16_to_f32$(OBJ) \ | ||||
|   f16_to_f64$(OBJ) \ | ||||
|   f16_to_extF80$(OBJ) \ | ||||
|   f16_to_extF80M$(OBJ) \ | ||||
|   f16_to_f128$(OBJ) \ | ||||
|   f16_to_f128M$(OBJ) \ | ||||
|   f16_roundToInt$(OBJ) \ | ||||
|   f16_add$(OBJ) \ | ||||
|   f16_sub$(OBJ) \ | ||||
|   f16_mul$(OBJ) \ | ||||
|   f16_mulAdd$(OBJ) \ | ||||
|   f16_div$(OBJ) \ | ||||
|   f16_rem$(OBJ) \ | ||||
|   f16_sqrt$(OBJ) \ | ||||
|   f16_eq$(OBJ) \ | ||||
|   f16_le$(OBJ) \ | ||||
|   f16_lt$(OBJ) \ | ||||
|   f16_eq_signaling$(OBJ) \ | ||||
|   f16_le_quiet$(OBJ) \ | ||||
|   f16_lt_quiet$(OBJ) \ | ||||
|   f16_isSignalingNaN$(OBJ) \ | ||||
|   f32_to_ui32$(OBJ) \ | ||||
|   f32_to_ui64$(OBJ) \ | ||||
|   f32_to_i32$(OBJ) \ | ||||
|   f32_to_i64$(OBJ) \ | ||||
|   f32_to_ui32_r_minMag$(OBJ) \ | ||||
|   f32_to_ui64_r_minMag$(OBJ) \ | ||||
|   f32_to_i32_r_minMag$(OBJ) \ | ||||
|   f32_to_i64_r_minMag$(OBJ) \ | ||||
|   f32_to_bf16$(OBJ) \ | ||||
|   f32_to_f16$(OBJ) \ | ||||
|   f32_to_f64$(OBJ) \ | ||||
|   f32_to_extF80$(OBJ) \ | ||||
|   f32_to_extF80M$(OBJ) \ | ||||
|   f32_to_f128$(OBJ) \ | ||||
|   f32_to_f128M$(OBJ) \ | ||||
|   f32_roundToInt$(OBJ) \ | ||||
|   f32_add$(OBJ) \ | ||||
|   f32_sub$(OBJ) \ | ||||
|   f32_mul$(OBJ) \ | ||||
|   f32_mulAdd$(OBJ) \ | ||||
|   f32_div$(OBJ) \ | ||||
|   f32_rem$(OBJ) \ | ||||
|   f32_sqrt$(OBJ) \ | ||||
|   f32_eq$(OBJ) \ | ||||
|   f32_le$(OBJ) \ | ||||
|   f32_lt$(OBJ) \ | ||||
|   f32_eq_signaling$(OBJ) \ | ||||
|   f32_le_quiet$(OBJ) \ | ||||
|   f32_lt_quiet$(OBJ) \ | ||||
|   f32_isSignalingNaN$(OBJ) \ | ||||
|   f64_to_ui32$(OBJ) \ | ||||
|   f64_to_ui64$(OBJ) \ | ||||
|   f64_to_i32$(OBJ) \ | ||||
|   f64_to_i64$(OBJ) \ | ||||
|   f64_to_ui32_r_minMag$(OBJ) \ | ||||
|   f64_to_ui64_r_minMag$(OBJ) \ | ||||
|   f64_to_i32_r_minMag$(OBJ) \ | ||||
|   f64_to_i64_r_minMag$(OBJ) \ | ||||
|   f64_to_f16$(OBJ) \ | ||||
|   f64_to_f32$(OBJ) \ | ||||
|   f64_to_extF80$(OBJ) \ | ||||
|   f64_to_extF80M$(OBJ) \ | ||||
|   f64_to_f128$(OBJ) \ | ||||
|   f64_to_f128M$(OBJ) \ | ||||
|   f64_roundToInt$(OBJ) \ | ||||
|   f64_add$(OBJ) \ | ||||
|   f64_sub$(OBJ) \ | ||||
|   f64_mul$(OBJ) \ | ||||
|   f64_mulAdd$(OBJ) \ | ||||
|   f64_div$(OBJ) \ | ||||
|   f64_rem$(OBJ) \ | ||||
|   f64_sqrt$(OBJ) \ | ||||
|   f64_eq$(OBJ) \ | ||||
|   f64_le$(OBJ) \ | ||||
|   f64_lt$(OBJ) \ | ||||
|   f64_eq_signaling$(OBJ) \ | ||||
|   f64_le_quiet$(OBJ) \ | ||||
|   f64_lt_quiet$(OBJ) \ | ||||
|   f64_isSignalingNaN$(OBJ) \ | ||||
|   extF80_to_ui32$(OBJ) \ | ||||
|   extF80_to_ui64$(OBJ) \ | ||||
|   extF80_to_i32$(OBJ) \ | ||||
|   extF80_to_i64$(OBJ) \ | ||||
|   extF80_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80_to_f16$(OBJ) \ | ||||
|   extF80_to_f32$(OBJ) \ | ||||
|   extF80_to_f64$(OBJ) \ | ||||
|   extF80_to_f128$(OBJ) \ | ||||
|   extF80_roundToInt$(OBJ) \ | ||||
|   extF80_add$(OBJ) \ | ||||
|   extF80_sub$(OBJ) \ | ||||
|   extF80_mul$(OBJ) \ | ||||
|   extF80_div$(OBJ) \ | ||||
|   extF80_rem$(OBJ) \ | ||||
|   extF80_sqrt$(OBJ) \ | ||||
|   extF80_eq$(OBJ) \ | ||||
|   extF80_le$(OBJ) \ | ||||
|   extF80_lt$(OBJ) \ | ||||
|   extF80_eq_signaling$(OBJ) \ | ||||
|   extF80_le_quiet$(OBJ) \ | ||||
|   extF80_lt_quiet$(OBJ) \ | ||||
|   extF80_isSignalingNaN$(OBJ) \ | ||||
|   extF80M_to_ui32$(OBJ) \ | ||||
|   extF80M_to_ui64$(OBJ) \ | ||||
|   extF80M_to_i32$(OBJ) \ | ||||
|   extF80M_to_i64$(OBJ) \ | ||||
|   extF80M_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_f16$(OBJ) \ | ||||
|   extF80M_to_f32$(OBJ) \ | ||||
|   extF80M_to_f64$(OBJ) \ | ||||
|   extF80M_to_f128M$(OBJ) \ | ||||
|   extF80M_roundToInt$(OBJ) \ | ||||
|   extF80M_add$(OBJ) \ | ||||
|   extF80M_sub$(OBJ) \ | ||||
|   extF80M_mul$(OBJ) \ | ||||
|   extF80M_div$(OBJ) \ | ||||
|   extF80M_rem$(OBJ) \ | ||||
|   extF80M_sqrt$(OBJ) \ | ||||
|   extF80M_eq$(OBJ) \ | ||||
|   extF80M_le$(OBJ) \ | ||||
|   extF80M_lt$(OBJ) \ | ||||
|   extF80M_eq_signaling$(OBJ) \ | ||||
|   extF80M_le_quiet$(OBJ) \ | ||||
|   extF80M_lt_quiet$(OBJ) \ | ||||
|   f128_to_ui32$(OBJ) \ | ||||
|   f128_to_ui64$(OBJ) \ | ||||
|   f128_to_i32$(OBJ) \ | ||||
|   f128_to_i64$(OBJ) \ | ||||
|   f128_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128_to_i32_r_minMag$(OBJ) \ | ||||
|   f128_to_i64_r_minMag$(OBJ) \ | ||||
|   f128_to_f16$(OBJ) \ | ||||
|   f128_to_f32$(OBJ) \ | ||||
|   f128_to_extF80$(OBJ) \ | ||||
|   f128_to_f64$(OBJ) \ | ||||
|   f128_roundToInt$(OBJ) \ | ||||
|   f128_add$(OBJ) \ | ||||
|   f128_sub$(OBJ) \ | ||||
|   f128_mul$(OBJ) \ | ||||
|   f128_mulAdd$(OBJ) \ | ||||
|   f128_div$(OBJ) \ | ||||
|   f128_rem$(OBJ) \ | ||||
|   f128_sqrt$(OBJ) \ | ||||
|   f128_eq$(OBJ) \ | ||||
|   f128_le$(OBJ) \ | ||||
|   f128_lt$(OBJ) \ | ||||
|   f128_eq_signaling$(OBJ) \ | ||||
|   f128_le_quiet$(OBJ) \ | ||||
|   f128_lt_quiet$(OBJ) \ | ||||
|   f128_isSignalingNaN$(OBJ) \ | ||||
|   f128M_to_ui32$(OBJ) \ | ||||
|   f128M_to_ui64$(OBJ) \ | ||||
|   f128M_to_i32$(OBJ) \ | ||||
|   f128M_to_i64$(OBJ) \ | ||||
|   f128M_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128M_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128M_to_i32_r_minMag$(OBJ) \ | ||||
|   f128M_to_i64_r_minMag$(OBJ) \ | ||||
|   f128M_to_f16$(OBJ) \ | ||||
|   f128M_to_f32$(OBJ) \ | ||||
|   f128M_to_extF80M$(OBJ) \ | ||||
|   f128M_to_f64$(OBJ) \ | ||||
|   f128M_roundToInt$(OBJ) \ | ||||
|   f128M_add$(OBJ) \ | ||||
|   f128M_sub$(OBJ) \ | ||||
|   f128M_mul$(OBJ) \ | ||||
|   f128M_mulAdd$(OBJ) \ | ||||
|   f128M_div$(OBJ) \ | ||||
|   f128M_rem$(OBJ) \ | ||||
|   f128M_sqrt$(OBJ) \ | ||||
|   f128M_eq$(OBJ) \ | ||||
|   f128M_le$(OBJ) \ | ||||
|   f128M_lt$(OBJ) \ | ||||
|   f128M_eq_signaling$(OBJ) \ | ||||
|   f128M_le_quiet$(OBJ) \ | ||||
|   f128M_lt_quiet$(OBJ) \ | ||||
|  | ||||
| OBJS_ALL = $(OBJS_PRIMITIVES) $(OBJS_SPECIALIZE) $(OBJS_OTHERS) | ||||
|  | ||||
| $(OBJS_ALL): \ | ||||
|   $(OTHER_HEADERS) platform.h $(SOURCE_DIR)/include/primitiveTypes.h \ | ||||
|   $(SOURCE_DIR)/include/primitives.h | ||||
| $(OBJS_SPECIALIZE) $(OBJS_OTHERS): \ | ||||
|   $(SOURCE_DIR)/include/softfloat_types.h $(SOURCE_DIR)/include/internals.h \ | ||||
|   $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/specialize.h \ | ||||
|   $(SOURCE_DIR)/include/softfloat.h | ||||
|  | ||||
| $(OBJS_PRIMITIVES) $(OBJS_OTHERS): %$(OBJ): $(SOURCE_DIR)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$*.c | ||||
|  | ||||
| $(OBJS_SPECIALIZE): %$(OBJ): $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/$*.c | ||||
|  | ||||
| softfloat$(LIB): $(OBJS_ALL) | ||||
| 	$(DELETE) $@ | ||||
| 	$(MAKELIB) $^ | ||||
|  | ||||
| .PHONY: clean | ||||
| clean: | ||||
| 	$(DELETE) $(OBJS_ALL) softfloat$(LIB) | ||||
|  | ||||
|   | ||||
| @@ -1,49 +1,50 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header template is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| // Edit lines marked with `==>'.  See "SoftFloat-source.html". | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| == > #define LITTLEENDIAN 1 | ||||
|  | ||||
|     /*---------------------------------------------------------------------------- | ||||
|      *----------------------------------------------------------------------------*/ | ||||
|     == > #define INLINE inline | ||||
|  | ||||
|     /*---------------------------------------------------------------------------- | ||||
|      *----------------------------------------------------------------------------*/ | ||||
|     == > #define THREAD_LOCAL _Thread_local | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header template is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| // Edit lines marked with `==>'.  See "SoftFloat-source.html". | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| ==> #define LITTLEENDIAN 1 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| ==> #define INLINE inline | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| ==> #define THREAD_LOCAL _Thread_local | ||||
|  | ||||
|   | ||||
| @@ -1,325 +1,325 @@ | ||||
|  | ||||
| #============================================================================= | ||||
| # | ||||
| # This Makefile template is part of the SoftFloat IEEE Floating-Point | ||||
| # Arithmetic Package, Release 3e, by John R. Hauser. | ||||
| # | ||||
| # Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| # University of California.  All rights reserved. | ||||
| # | ||||
| # Redistribution and use in source and binary forms, with or without | ||||
| # modification, are permitted provided that the following conditions are met: | ||||
| # | ||||
| #  1. Redistributions of source code must retain the above copyright notice, | ||||
| #     this list of conditions, and the following disclaimer. | ||||
| # | ||||
| #  2. Redistributions in binary form must reproduce the above copyright | ||||
| #     notice, this list of conditions, and the following disclaimer in the | ||||
| #     documentation and/or other materials provided with the distribution. | ||||
| # | ||||
| #  3. Neither the name of the University nor the names of its contributors | ||||
| #     may be used to endorse or promote products derived from this software | ||||
| #     without specific prior written permission. | ||||
| # | ||||
| # THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| # DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||||
| # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| # | ||||
| #============================================================================= | ||||
|  | ||||
| # Edit lines marked with `==>'.  See "SoftFloat-source.html". | ||||
|  | ||||
| ==> SOURCE_DIR ?= ../../source | ||||
| ==> SPECIALIZE_TYPE ?= 8086 | ||||
|  | ||||
| ==> SOFTFLOAT_OPTS ?= \ | ||||
| ==>   -DSOFTFLOAT_ROUND_ODD -DINLINE_LEVEL=5 -DSOFTFLOAT_FAST_DIV32TO16 \ | ||||
| ==>   -DSOFTFLOAT_FAST_DIV64TO32 | ||||
|  | ||||
| ==> DELETE = rm -f | ||||
| ==> C_INCLUDES = -I. -I$(SOURCE_DIR)/$(SPECIALIZE_TYPE) -I$(SOURCE_DIR)/include | ||||
| ==> COMPILE_C = cc -c $(SOFTFLOAT_OPTS) $(C_INCLUDES) -O2 -o $@ | ||||
| ==> MAKELIB = ar crs $@ | ||||
|  | ||||
| ==> OBJ = .o | ||||
| ==> LIB = .a | ||||
|  | ||||
| ==> OTHER_HEADERS = | ||||
|  | ||||
| .PHONY: all | ||||
| all: softfloat$(LIB) | ||||
|  | ||||
| OBJS_PRIMITIVES = \ | ||||
|   s_compare96M$(OBJ) \ | ||||
|   s_compare128M$(OBJ) \ | ||||
|   s_shortShiftLeft64To96M$(OBJ) \ | ||||
|   s_shortShiftLeftM$(OBJ) \ | ||||
|   s_shiftLeftM$(OBJ) \ | ||||
|   s_shortShiftRightM$(OBJ) \ | ||||
|   s_shortShiftRightJam64$(OBJ) \ | ||||
|   s_shortShiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightJam32$(OBJ) \ | ||||
|   s_shiftRightJam64$(OBJ) \ | ||||
|   s_shiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightM$(OBJ) \ | ||||
|   s_countLeadingZeros8$(OBJ) \ | ||||
|   s_countLeadingZeros16$(OBJ) \ | ||||
|   s_countLeadingZeros32$(OBJ) \ | ||||
|   s_countLeadingZeros64$(OBJ) \ | ||||
|   s_addM$(OBJ) \ | ||||
|   s_addCarryM$(OBJ) \ | ||||
|   s_addComplCarryM$(OBJ) \ | ||||
|   s_negXM$(OBJ) \ | ||||
|   s_sub1XM$(OBJ) \ | ||||
|   s_subM$(OBJ) \ | ||||
|   s_mul64To128M$(OBJ) \ | ||||
|   s_mul128MTo256M$(OBJ) \ | ||||
|   s_approxRecip_1Ks$(OBJ) \ | ||||
|   s_approxRecip32_1$(OBJ) \ | ||||
|   s_approxRecipSqrt_1Ks$(OBJ) \ | ||||
|   s_approxRecipSqrt32_1$(OBJ) \ | ||||
|   s_remStepMBy32$(OBJ) \ | ||||
|  | ||||
| OBJS_SPECIALIZE = \ | ||||
|   softfloat_raiseFlags$(OBJ) \ | ||||
|   s_f16UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF16UI$(OBJ) \ | ||||
|   s_propagateNaNF16UI$(OBJ) \ | ||||
|   s_f32UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF32UI$(OBJ) \ | ||||
|   s_propagateNaNF32UI$(OBJ) \ | ||||
|   s_f64UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF64UI$(OBJ) \ | ||||
|   s_propagateNaNF64UI$(OBJ) \ | ||||
|   extF80M_isSignalingNaN$(OBJ) \ | ||||
|   s_extF80MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToExtF80M$(OBJ) \ | ||||
|   s_propagateNaNExtF80M$(OBJ) \ | ||||
|   f128M_isSignalingNaN$(OBJ) \ | ||||
|   s_f128MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF128M$(OBJ) \ | ||||
|   s_propagateNaNF128M$(OBJ) \ | ||||
|  | ||||
| OBJS_OTHERS = \ | ||||
|   s_roundToUI32$(OBJ) \ | ||||
|   s_roundMToUI64$(OBJ) \ | ||||
|   s_roundToI32$(OBJ) \ | ||||
|   s_roundMToI64$(OBJ) \ | ||||
|   s_normSubnormalF16Sig$(OBJ) \ | ||||
|   s_roundPackToF16$(OBJ) \ | ||||
|   s_normRoundPackToF16$(OBJ) \ | ||||
|   s_addMagsF16$(OBJ) \ | ||||
|   s_subMagsF16$(OBJ) \ | ||||
|   s_mulAddF16$(OBJ) \ | ||||
|   s_normSubnormalF32Sig$(OBJ) \ | ||||
|   s_roundPackToF32$(OBJ) \ | ||||
|   s_normRoundPackToF32$(OBJ) \ | ||||
|   s_addMagsF32$(OBJ) \ | ||||
|   s_subMagsF32$(OBJ) \ | ||||
|   s_mulAddF32$(OBJ) \ | ||||
|   s_normSubnormalF64Sig$(OBJ) \ | ||||
|   s_roundPackToF64$(OBJ) \ | ||||
|   s_normRoundPackToF64$(OBJ) \ | ||||
|   s_addMagsF64$(OBJ) \ | ||||
|   s_subMagsF64$(OBJ) \ | ||||
|   s_mulAddF64$(OBJ) \ | ||||
|   s_tryPropagateNaNExtF80M$(OBJ) \ | ||||
|   s_invalidExtF80M$(OBJ) \ | ||||
|   s_normExtF80SigM$(OBJ) \ | ||||
|   s_roundPackMToExtF80M$(OBJ) \ | ||||
|   s_normRoundPackMToExtF80M$(OBJ) \ | ||||
|   s_addExtF80M$(OBJ) \ | ||||
|   s_compareNonnormExtF80M$(OBJ) \ | ||||
|   s_isNaNF128M$(OBJ) \ | ||||
|   s_tryPropagateNaNF128M$(OBJ) \ | ||||
|   s_invalidF128M$(OBJ) \ | ||||
|   s_shiftNormSigF128M$(OBJ) \ | ||||
|   s_roundPackMToF128M$(OBJ) \ | ||||
|   s_normRoundPackMToF128M$(OBJ) \ | ||||
|   s_addF128M$(OBJ) \ | ||||
|   s_mulAddF128M$(OBJ) \ | ||||
|   softfloat_state$(OBJ) \ | ||||
|   ui32_to_f16$(OBJ) \ | ||||
|   ui32_to_f32$(OBJ) \ | ||||
|   ui32_to_f64$(OBJ) \ | ||||
|   ui32_to_extF80M$(OBJ) \ | ||||
|   ui32_to_f128M$(OBJ) \ | ||||
|   ui64_to_f16$(OBJ) \ | ||||
|   ui64_to_f32$(OBJ) \ | ||||
|   ui64_to_f64$(OBJ) \ | ||||
|   ui64_to_extF80M$(OBJ) \ | ||||
|   ui64_to_f128M$(OBJ) \ | ||||
|   i32_to_f16$(OBJ) \ | ||||
|   i32_to_f32$(OBJ) \ | ||||
|   i32_to_f64$(OBJ) \ | ||||
|   i32_to_extF80M$(OBJ) \ | ||||
|   i32_to_f128M$(OBJ) \ | ||||
|   i64_to_f16$(OBJ) \ | ||||
|   i64_to_f32$(OBJ) \ | ||||
|   i64_to_f64$(OBJ) \ | ||||
|   i64_to_extF80M$(OBJ) \ | ||||
|   i64_to_f128M$(OBJ) \ | ||||
|   f16_to_ui32$(OBJ) \ | ||||
|   f16_to_ui64$(OBJ) \ | ||||
|   f16_to_i32$(OBJ) \ | ||||
|   f16_to_i64$(OBJ) \ | ||||
|   f16_to_ui32_r_minMag$(OBJ) \ | ||||
|   f16_to_ui64_r_minMag$(OBJ) \ | ||||
|   f16_to_i32_r_minMag$(OBJ) \ | ||||
|   f16_to_i64_r_minMag$(OBJ) \ | ||||
|   f16_to_f32$(OBJ) \ | ||||
|   f16_to_f64$(OBJ) \ | ||||
|   f16_to_extF80M$(OBJ) \ | ||||
|   f16_to_f128M$(OBJ) \ | ||||
|   f16_roundToInt$(OBJ) \ | ||||
|   f16_add$(OBJ) \ | ||||
|   f16_sub$(OBJ) \ | ||||
|   f16_mul$(OBJ) \ | ||||
|   f16_mulAdd$(OBJ) \ | ||||
|   f16_div$(OBJ) \ | ||||
|   f16_rem$(OBJ) \ | ||||
|   f16_sqrt$(OBJ) \ | ||||
|   f16_eq$(OBJ) \ | ||||
|   f16_le$(OBJ) \ | ||||
|   f16_lt$(OBJ) \ | ||||
|   f16_eq_signaling$(OBJ) \ | ||||
|   f16_le_quiet$(OBJ) \ | ||||
|   f16_lt_quiet$(OBJ) \ | ||||
|   f16_isSignalingNaN$(OBJ) \ | ||||
|   f32_to_ui32$(OBJ) \ | ||||
|   f32_to_ui64$(OBJ) \ | ||||
|   f32_to_i32$(OBJ) \ | ||||
|   f32_to_i64$(OBJ) \ | ||||
|   f32_to_ui32_r_minMag$(OBJ) \ | ||||
|   f32_to_ui64_r_minMag$(OBJ) \ | ||||
|   f32_to_i32_r_minMag$(OBJ) \ | ||||
|   f32_to_i64_r_minMag$(OBJ) \ | ||||
|   f32_to_f16$(OBJ) \ | ||||
|   f32_to_f64$(OBJ) \ | ||||
|   f32_to_extF80M$(OBJ) \ | ||||
|   f32_to_f128M$(OBJ) \ | ||||
|   f32_roundToInt$(OBJ) \ | ||||
|   f32_add$(OBJ) \ | ||||
|   f32_sub$(OBJ) \ | ||||
|   f32_mul$(OBJ) \ | ||||
|   f32_mulAdd$(OBJ) \ | ||||
|   f32_div$(OBJ) \ | ||||
|   f32_rem$(OBJ) \ | ||||
|   f32_sqrt$(OBJ) \ | ||||
|   f32_eq$(OBJ) \ | ||||
|   f32_le$(OBJ) \ | ||||
|   f32_lt$(OBJ) \ | ||||
|   f32_eq_signaling$(OBJ) \ | ||||
|   f32_le_quiet$(OBJ) \ | ||||
|   f32_lt_quiet$(OBJ) \ | ||||
|   f32_isSignalingNaN$(OBJ) \ | ||||
|   f64_to_ui32$(OBJ) \ | ||||
|   f64_to_ui64$(OBJ) \ | ||||
|   f64_to_i32$(OBJ) \ | ||||
|   f64_to_i64$(OBJ) \ | ||||
|   f64_to_ui32_r_minMag$(OBJ) \ | ||||
|   f64_to_ui64_r_minMag$(OBJ) \ | ||||
|   f64_to_i32_r_minMag$(OBJ) \ | ||||
|   f64_to_i64_r_minMag$(OBJ) \ | ||||
|   f64_to_f16$(OBJ) \ | ||||
|   f64_to_f32$(OBJ) \ | ||||
|   f64_to_extF80M$(OBJ) \ | ||||
|   f64_to_f128M$(OBJ) \ | ||||
|   f64_roundToInt$(OBJ) \ | ||||
|   f64_add$(OBJ) \ | ||||
|   f64_sub$(OBJ) \ | ||||
|   f64_mul$(OBJ) \ | ||||
|   f64_mulAdd$(OBJ) \ | ||||
|   f64_div$(OBJ) \ | ||||
|   f64_rem$(OBJ) \ | ||||
|   f64_sqrt$(OBJ) \ | ||||
|   f64_eq$(OBJ) \ | ||||
|   f64_le$(OBJ) \ | ||||
|   f64_lt$(OBJ) \ | ||||
|   f64_eq_signaling$(OBJ) \ | ||||
|   f64_le_quiet$(OBJ) \ | ||||
|   f64_lt_quiet$(OBJ) \ | ||||
|   f64_isSignalingNaN$(OBJ) \ | ||||
|   extF80M_to_ui32$(OBJ) \ | ||||
|   extF80M_to_ui64$(OBJ) \ | ||||
|   extF80M_to_i32$(OBJ) \ | ||||
|   extF80M_to_i64$(OBJ) \ | ||||
|   extF80M_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_f16$(OBJ) \ | ||||
|   extF80M_to_f32$(OBJ) \ | ||||
|   extF80M_to_f64$(OBJ) \ | ||||
|   extF80M_to_f128M$(OBJ) \ | ||||
|   extF80M_roundToInt$(OBJ) \ | ||||
|   extF80M_add$(OBJ) \ | ||||
|   extF80M_sub$(OBJ) \ | ||||
|   extF80M_mul$(OBJ) \ | ||||
|   extF80M_div$(OBJ) \ | ||||
|   extF80M_rem$(OBJ) \ | ||||
|   extF80M_sqrt$(OBJ) \ | ||||
|   extF80M_eq$(OBJ) \ | ||||
|   extF80M_le$(OBJ) \ | ||||
|   extF80M_lt$(OBJ) \ | ||||
|   extF80M_eq_signaling$(OBJ) \ | ||||
|   extF80M_le_quiet$(OBJ) \ | ||||
|   extF80M_lt_quiet$(OBJ) \ | ||||
|   f128M_to_ui32$(OBJ) \ | ||||
|   f128M_to_ui64$(OBJ) \ | ||||
|   f128M_to_i32$(OBJ) \ | ||||
|   f128M_to_i64$(OBJ) \ | ||||
|   f128M_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128M_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128M_to_i32_r_minMag$(OBJ) \ | ||||
|   f128M_to_i64_r_minMag$(OBJ) \ | ||||
|   f128M_to_f16$(OBJ) \ | ||||
|   f128M_to_f32$(OBJ) \ | ||||
|   f128M_to_f64$(OBJ) \ | ||||
|   f128M_to_extF80M$(OBJ) \ | ||||
|   f128M_roundToInt$(OBJ) \ | ||||
|   f128M_add$(OBJ) \ | ||||
|   f128M_sub$(OBJ) \ | ||||
|   f128M_mul$(OBJ) \ | ||||
|   f128M_mulAdd$(OBJ) \ | ||||
|   f128M_div$(OBJ) \ | ||||
|   f128M_rem$(OBJ) \ | ||||
|   f128M_sqrt$(OBJ) \ | ||||
|   f128M_eq$(OBJ) \ | ||||
|   f128M_le$(OBJ) \ | ||||
|   f128M_lt$(OBJ) \ | ||||
|   f128M_eq_signaling$(OBJ) \ | ||||
|   f128M_le_quiet$(OBJ) \ | ||||
|   f128M_lt_quiet$(OBJ) \ | ||||
|  | ||||
| OBJS_ALL = $(OBJS_PRIMITIVES) $(OBJS_SPECIALIZE) $(OBJS_OTHERS) | ||||
|  | ||||
| $(OBJS_ALL): \ | ||||
|   $(OTHER_HEADERS) platform.h $(SOURCE_DIR)/include/primitiveTypes.h \ | ||||
|   $(SOURCE_DIR)/include/primitives.h | ||||
| $(OBJS_SPECIALIZE) $(OBJS_OTHERS): \ | ||||
|   $(SOURCE_DIR)/include/softfloat_types.h $(SOURCE_DIR)/include/internals.h \ | ||||
|   $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/specialize.h \ | ||||
|   $(SOURCE_DIR)/include/softfloat.h | ||||
|  | ||||
| $(OBJS_PRIMITIVES) $(OBJS_OTHERS): %$(OBJ): $(SOURCE_DIR)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$*.c | ||||
|  | ||||
| $(OBJS_SPECIALIZE): %$(OBJ): $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/$*.c | ||||
|  | ||||
| softfloat$(LIB): $(OBJS_ALL) | ||||
| 	$(DELETE) $@ | ||||
| 	$(MAKELIB) $^ | ||||
|  | ||||
| .PHONY: clean | ||||
| clean: | ||||
| 	$(DELETE) $(OBJS_ALL) softfloat$(LIB) | ||||
|  | ||||
|  | ||||
| #============================================================================= | ||||
| # | ||||
| # This Makefile template is part of the SoftFloat IEEE Floating-Point | ||||
| # Arithmetic Package, Release 3e, by John R. Hauser. | ||||
| # | ||||
| # Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the | ||||
| # University of California.  All rights reserved. | ||||
| # | ||||
| # Redistribution and use in source and binary forms, with or without | ||||
| # modification, are permitted provided that the following conditions are met: | ||||
| # | ||||
| #  1. Redistributions of source code must retain the above copyright notice, | ||||
| #     this list of conditions, and the following disclaimer. | ||||
| # | ||||
| #  2. Redistributions in binary form must reproduce the above copyright | ||||
| #     notice, this list of conditions, and the following disclaimer in the | ||||
| #     documentation and/or other materials provided with the distribution. | ||||
| # | ||||
| #  3. Neither the name of the University nor the names of its contributors | ||||
| #     may be used to endorse or promote products derived from this software | ||||
| #     without specific prior written permission. | ||||
| # | ||||
| # THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| # DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||||
| # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| # | ||||
| #============================================================================= | ||||
|  | ||||
| # Edit lines marked with `==>'.  See "SoftFloat-source.html". | ||||
|  | ||||
| ==> SOURCE_DIR ?= ../../source | ||||
| ==> SPECIALIZE_TYPE ?= 8086 | ||||
|  | ||||
| ==> SOFTFLOAT_OPTS ?= \ | ||||
| ==>   -DSOFTFLOAT_ROUND_ODD -DINLINE_LEVEL=5 -DSOFTFLOAT_FAST_DIV32TO16 \ | ||||
| ==>   -DSOFTFLOAT_FAST_DIV64TO32 | ||||
|  | ||||
| ==> DELETE = rm -f | ||||
| ==> C_INCLUDES = -I. -I$(SOURCE_DIR)/$(SPECIALIZE_TYPE) -I$(SOURCE_DIR)/include | ||||
| ==> COMPILE_C = cc -c $(SOFTFLOAT_OPTS) $(C_INCLUDES) -O2 -o $@ | ||||
| ==> MAKELIB = ar crs $@ | ||||
|  | ||||
| ==> OBJ = .o | ||||
| ==> LIB = .a | ||||
|  | ||||
| ==> OTHER_HEADERS = | ||||
|  | ||||
| .PHONY: all | ||||
| all: softfloat$(LIB) | ||||
|  | ||||
| OBJS_PRIMITIVES = \ | ||||
|   s_compare96M$(OBJ) \ | ||||
|   s_compare128M$(OBJ) \ | ||||
|   s_shortShiftLeft64To96M$(OBJ) \ | ||||
|   s_shortShiftLeftM$(OBJ) \ | ||||
|   s_shiftLeftM$(OBJ) \ | ||||
|   s_shortShiftRightM$(OBJ) \ | ||||
|   s_shortShiftRightJam64$(OBJ) \ | ||||
|   s_shortShiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightJam32$(OBJ) \ | ||||
|   s_shiftRightJam64$(OBJ) \ | ||||
|   s_shiftRightJamM$(OBJ) \ | ||||
|   s_shiftRightM$(OBJ) \ | ||||
|   s_countLeadingZeros8$(OBJ) \ | ||||
|   s_countLeadingZeros16$(OBJ) \ | ||||
|   s_countLeadingZeros32$(OBJ) \ | ||||
|   s_countLeadingZeros64$(OBJ) \ | ||||
|   s_addM$(OBJ) \ | ||||
|   s_addCarryM$(OBJ) \ | ||||
|   s_addComplCarryM$(OBJ) \ | ||||
|   s_negXM$(OBJ) \ | ||||
|   s_sub1XM$(OBJ) \ | ||||
|   s_subM$(OBJ) \ | ||||
|   s_mul64To128M$(OBJ) \ | ||||
|   s_mul128MTo256M$(OBJ) \ | ||||
|   s_approxRecip_1Ks$(OBJ) \ | ||||
|   s_approxRecip32_1$(OBJ) \ | ||||
|   s_approxRecipSqrt_1Ks$(OBJ) \ | ||||
|   s_approxRecipSqrt32_1$(OBJ) \ | ||||
|   s_remStepMBy32$(OBJ) \ | ||||
|  | ||||
| OBJS_SPECIALIZE = \ | ||||
|   softfloat_raiseFlags$(OBJ) \ | ||||
|   s_f16UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF16UI$(OBJ) \ | ||||
|   s_propagateNaNF16UI$(OBJ) \ | ||||
|   s_f32UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF32UI$(OBJ) \ | ||||
|   s_propagateNaNF32UI$(OBJ) \ | ||||
|   s_f64UIToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF64UI$(OBJ) \ | ||||
|   s_propagateNaNF64UI$(OBJ) \ | ||||
|   extF80M_isSignalingNaN$(OBJ) \ | ||||
|   s_extF80MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToExtF80M$(OBJ) \ | ||||
|   s_propagateNaNExtF80M$(OBJ) \ | ||||
|   f128M_isSignalingNaN$(OBJ) \ | ||||
|   s_f128MToCommonNaN$(OBJ) \ | ||||
|   s_commonNaNToF128M$(OBJ) \ | ||||
|   s_propagateNaNF128M$(OBJ) \ | ||||
|  | ||||
| OBJS_OTHERS = \ | ||||
|   s_roundToUI32$(OBJ) \ | ||||
|   s_roundMToUI64$(OBJ) \ | ||||
|   s_roundToI32$(OBJ) \ | ||||
|   s_roundMToI64$(OBJ) \ | ||||
|   s_normSubnormalF16Sig$(OBJ) \ | ||||
|   s_roundPackToF16$(OBJ) \ | ||||
|   s_normRoundPackToF16$(OBJ) \ | ||||
|   s_addMagsF16$(OBJ) \ | ||||
|   s_subMagsF16$(OBJ) \ | ||||
|   s_mulAddF16$(OBJ) \ | ||||
|   s_normSubnormalF32Sig$(OBJ) \ | ||||
|   s_roundPackToF32$(OBJ) \ | ||||
|   s_normRoundPackToF32$(OBJ) \ | ||||
|   s_addMagsF32$(OBJ) \ | ||||
|   s_subMagsF32$(OBJ) \ | ||||
|   s_mulAddF32$(OBJ) \ | ||||
|   s_normSubnormalF64Sig$(OBJ) \ | ||||
|   s_roundPackToF64$(OBJ) \ | ||||
|   s_normRoundPackToF64$(OBJ) \ | ||||
|   s_addMagsF64$(OBJ) \ | ||||
|   s_subMagsF64$(OBJ) \ | ||||
|   s_mulAddF64$(OBJ) \ | ||||
|   s_tryPropagateNaNExtF80M$(OBJ) \ | ||||
|   s_invalidExtF80M$(OBJ) \ | ||||
|   s_normExtF80SigM$(OBJ) \ | ||||
|   s_roundPackMToExtF80M$(OBJ) \ | ||||
|   s_normRoundPackMToExtF80M$(OBJ) \ | ||||
|   s_addExtF80M$(OBJ) \ | ||||
|   s_compareNonnormExtF80M$(OBJ) \ | ||||
|   s_isNaNF128M$(OBJ) \ | ||||
|   s_tryPropagateNaNF128M$(OBJ) \ | ||||
|   s_invalidF128M$(OBJ) \ | ||||
|   s_shiftNormSigF128M$(OBJ) \ | ||||
|   s_roundPackMToF128M$(OBJ) \ | ||||
|   s_normRoundPackMToF128M$(OBJ) \ | ||||
|   s_addF128M$(OBJ) \ | ||||
|   s_mulAddF128M$(OBJ) \ | ||||
|   softfloat_state$(OBJ) \ | ||||
|   ui32_to_f16$(OBJ) \ | ||||
|   ui32_to_f32$(OBJ) \ | ||||
|   ui32_to_f64$(OBJ) \ | ||||
|   ui32_to_extF80M$(OBJ) \ | ||||
|   ui32_to_f128M$(OBJ) \ | ||||
|   ui64_to_f16$(OBJ) \ | ||||
|   ui64_to_f32$(OBJ) \ | ||||
|   ui64_to_f64$(OBJ) \ | ||||
|   ui64_to_extF80M$(OBJ) \ | ||||
|   ui64_to_f128M$(OBJ) \ | ||||
|   i32_to_f16$(OBJ) \ | ||||
|   i32_to_f32$(OBJ) \ | ||||
|   i32_to_f64$(OBJ) \ | ||||
|   i32_to_extF80M$(OBJ) \ | ||||
|   i32_to_f128M$(OBJ) \ | ||||
|   i64_to_f16$(OBJ) \ | ||||
|   i64_to_f32$(OBJ) \ | ||||
|   i64_to_f64$(OBJ) \ | ||||
|   i64_to_extF80M$(OBJ) \ | ||||
|   i64_to_f128M$(OBJ) \ | ||||
|   f16_to_ui32$(OBJ) \ | ||||
|   f16_to_ui64$(OBJ) \ | ||||
|   f16_to_i32$(OBJ) \ | ||||
|   f16_to_i64$(OBJ) \ | ||||
|   f16_to_ui32_r_minMag$(OBJ) \ | ||||
|   f16_to_ui64_r_minMag$(OBJ) \ | ||||
|   f16_to_i32_r_minMag$(OBJ) \ | ||||
|   f16_to_i64_r_minMag$(OBJ) \ | ||||
|   f16_to_f32$(OBJ) \ | ||||
|   f16_to_f64$(OBJ) \ | ||||
|   f16_to_extF80M$(OBJ) \ | ||||
|   f16_to_f128M$(OBJ) \ | ||||
|   f16_roundToInt$(OBJ) \ | ||||
|   f16_add$(OBJ) \ | ||||
|   f16_sub$(OBJ) \ | ||||
|   f16_mul$(OBJ) \ | ||||
|   f16_mulAdd$(OBJ) \ | ||||
|   f16_div$(OBJ) \ | ||||
|   f16_rem$(OBJ) \ | ||||
|   f16_sqrt$(OBJ) \ | ||||
|   f16_eq$(OBJ) \ | ||||
|   f16_le$(OBJ) \ | ||||
|   f16_lt$(OBJ) \ | ||||
|   f16_eq_signaling$(OBJ) \ | ||||
|   f16_le_quiet$(OBJ) \ | ||||
|   f16_lt_quiet$(OBJ) \ | ||||
|   f16_isSignalingNaN$(OBJ) \ | ||||
|   f32_to_ui32$(OBJ) \ | ||||
|   f32_to_ui64$(OBJ) \ | ||||
|   f32_to_i32$(OBJ) \ | ||||
|   f32_to_i64$(OBJ) \ | ||||
|   f32_to_ui32_r_minMag$(OBJ) \ | ||||
|   f32_to_ui64_r_minMag$(OBJ) \ | ||||
|   f32_to_i32_r_minMag$(OBJ) \ | ||||
|   f32_to_i64_r_minMag$(OBJ) \ | ||||
|   f32_to_f16$(OBJ) \ | ||||
|   f32_to_f64$(OBJ) \ | ||||
|   f32_to_extF80M$(OBJ) \ | ||||
|   f32_to_f128M$(OBJ) \ | ||||
|   f32_roundToInt$(OBJ) \ | ||||
|   f32_add$(OBJ) \ | ||||
|   f32_sub$(OBJ) \ | ||||
|   f32_mul$(OBJ) \ | ||||
|   f32_mulAdd$(OBJ) \ | ||||
|   f32_div$(OBJ) \ | ||||
|   f32_rem$(OBJ) \ | ||||
|   f32_sqrt$(OBJ) \ | ||||
|   f32_eq$(OBJ) \ | ||||
|   f32_le$(OBJ) \ | ||||
|   f32_lt$(OBJ) \ | ||||
|   f32_eq_signaling$(OBJ) \ | ||||
|   f32_le_quiet$(OBJ) \ | ||||
|   f32_lt_quiet$(OBJ) \ | ||||
|   f32_isSignalingNaN$(OBJ) \ | ||||
|   f64_to_ui32$(OBJ) \ | ||||
|   f64_to_ui64$(OBJ) \ | ||||
|   f64_to_i32$(OBJ) \ | ||||
|   f64_to_i64$(OBJ) \ | ||||
|   f64_to_ui32_r_minMag$(OBJ) \ | ||||
|   f64_to_ui64_r_minMag$(OBJ) \ | ||||
|   f64_to_i32_r_minMag$(OBJ) \ | ||||
|   f64_to_i64_r_minMag$(OBJ) \ | ||||
|   f64_to_f16$(OBJ) \ | ||||
|   f64_to_f32$(OBJ) \ | ||||
|   f64_to_extF80M$(OBJ) \ | ||||
|   f64_to_f128M$(OBJ) \ | ||||
|   f64_roundToInt$(OBJ) \ | ||||
|   f64_add$(OBJ) \ | ||||
|   f64_sub$(OBJ) \ | ||||
|   f64_mul$(OBJ) \ | ||||
|   f64_mulAdd$(OBJ) \ | ||||
|   f64_div$(OBJ) \ | ||||
|   f64_rem$(OBJ) \ | ||||
|   f64_sqrt$(OBJ) \ | ||||
|   f64_eq$(OBJ) \ | ||||
|   f64_le$(OBJ) \ | ||||
|   f64_lt$(OBJ) \ | ||||
|   f64_eq_signaling$(OBJ) \ | ||||
|   f64_le_quiet$(OBJ) \ | ||||
|   f64_lt_quiet$(OBJ) \ | ||||
|   f64_isSignalingNaN$(OBJ) \ | ||||
|   extF80M_to_ui32$(OBJ) \ | ||||
|   extF80M_to_ui64$(OBJ) \ | ||||
|   extF80M_to_i32$(OBJ) \ | ||||
|   extF80M_to_i64$(OBJ) \ | ||||
|   extF80M_to_ui32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_ui64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i32_r_minMag$(OBJ) \ | ||||
|   extF80M_to_i64_r_minMag$(OBJ) \ | ||||
|   extF80M_to_f16$(OBJ) \ | ||||
|   extF80M_to_f32$(OBJ) \ | ||||
|   extF80M_to_f64$(OBJ) \ | ||||
|   extF80M_to_f128M$(OBJ) \ | ||||
|   extF80M_roundToInt$(OBJ) \ | ||||
|   extF80M_add$(OBJ) \ | ||||
|   extF80M_sub$(OBJ) \ | ||||
|   extF80M_mul$(OBJ) \ | ||||
|   extF80M_div$(OBJ) \ | ||||
|   extF80M_rem$(OBJ) \ | ||||
|   extF80M_sqrt$(OBJ) \ | ||||
|   extF80M_eq$(OBJ) \ | ||||
|   extF80M_le$(OBJ) \ | ||||
|   extF80M_lt$(OBJ) \ | ||||
|   extF80M_eq_signaling$(OBJ) \ | ||||
|   extF80M_le_quiet$(OBJ) \ | ||||
|   extF80M_lt_quiet$(OBJ) \ | ||||
|   f128M_to_ui32$(OBJ) \ | ||||
|   f128M_to_ui64$(OBJ) \ | ||||
|   f128M_to_i32$(OBJ) \ | ||||
|   f128M_to_i64$(OBJ) \ | ||||
|   f128M_to_ui32_r_minMag$(OBJ) \ | ||||
|   f128M_to_ui64_r_minMag$(OBJ) \ | ||||
|   f128M_to_i32_r_minMag$(OBJ) \ | ||||
|   f128M_to_i64_r_minMag$(OBJ) \ | ||||
|   f128M_to_f16$(OBJ) \ | ||||
|   f128M_to_f32$(OBJ) \ | ||||
|   f128M_to_f64$(OBJ) \ | ||||
|   f128M_to_extF80M$(OBJ) \ | ||||
|   f128M_roundToInt$(OBJ) \ | ||||
|   f128M_add$(OBJ) \ | ||||
|   f128M_sub$(OBJ) \ | ||||
|   f128M_mul$(OBJ) \ | ||||
|   f128M_mulAdd$(OBJ) \ | ||||
|   f128M_div$(OBJ) \ | ||||
|   f128M_rem$(OBJ) \ | ||||
|   f128M_sqrt$(OBJ) \ | ||||
|   f128M_eq$(OBJ) \ | ||||
|   f128M_le$(OBJ) \ | ||||
|   f128M_lt$(OBJ) \ | ||||
|   f128M_eq_signaling$(OBJ) \ | ||||
|   f128M_le_quiet$(OBJ) \ | ||||
|   f128M_lt_quiet$(OBJ) \ | ||||
|  | ||||
| OBJS_ALL = $(OBJS_PRIMITIVES) $(OBJS_SPECIALIZE) $(OBJS_OTHERS) | ||||
|  | ||||
| $(OBJS_ALL): \ | ||||
|   $(OTHER_HEADERS) platform.h $(SOURCE_DIR)/include/primitiveTypes.h \ | ||||
|   $(SOURCE_DIR)/include/primitives.h | ||||
| $(OBJS_SPECIALIZE) $(OBJS_OTHERS): \ | ||||
|   $(SOURCE_DIR)/include/softfloat_types.h $(SOURCE_DIR)/include/internals.h \ | ||||
|   $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/specialize.h \ | ||||
|   $(SOURCE_DIR)/include/softfloat.h | ||||
|  | ||||
| $(OBJS_PRIMITIVES) $(OBJS_OTHERS): %$(OBJ): $(SOURCE_DIR)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$*.c | ||||
|  | ||||
| $(OBJS_SPECIALIZE): %$(OBJ): $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/%.c | ||||
| 	$(COMPILE_C) $(SOURCE_DIR)/$(SPECIALIZE_TYPE)/$*.c | ||||
|  | ||||
| softfloat$(LIB): $(OBJS_ALL) | ||||
| 	$(DELETE) $@ | ||||
| 	$(MAKELIB) $^ | ||||
|  | ||||
| .PHONY: clean | ||||
| clean: | ||||
| 	$(DELETE) $(OBJS_ALL) softfloat$(LIB) | ||||
|  | ||||
|   | ||||
| @@ -1,49 +1,50 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header template is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| // Edit lines marked with `==>'.  See "SoftFloat-source.html". | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
|  *----------------------------------------------------------------------------*/ | ||||
| == > #define LITTLEENDIAN 1 | ||||
|  | ||||
|     /*---------------------------------------------------------------------------- | ||||
|      *----------------------------------------------------------------------------*/ | ||||
|     == > #define INLINE inline | ||||
|  | ||||
|     /*---------------------------------------------------------------------------- | ||||
|      *----------------------------------------------------------------------------*/ | ||||
|     == > #define THREAD_LOCAL _Thread_local | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header template is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| // Edit lines marked with `==>'.  See "SoftFloat-source.html". | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| ==> #define LITTLEENDIAN 1 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| ==> #define INLINE inline | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| ==> #define THREAD_LOCAL _Thread_local | ||||
|  | ||||
|   | ||||
| @@ -1,258 +1,258 @@ | ||||
|  | ||||
| <HTML> | ||||
|  | ||||
| <HEAD> | ||||
| <TITLE>Berkeley SoftFloat History</TITLE> | ||||
| </HEAD> | ||||
|  | ||||
| <BODY> | ||||
|  | ||||
| <H1>History of Berkeley SoftFloat, to Release 3e</H1> | ||||
|  | ||||
| <P> | ||||
| John R. Hauser<BR> | ||||
| 2018 January 20<BR> | ||||
| </P> | ||||
|  | ||||
|  | ||||
| <H3>Release 3e (2018 January)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Changed the default numeric code for optional rounding mode <CODE>odd</CODE> | ||||
| (round to odd, also known as <EM>jamming</EM>) from 5 to 6. | ||||
|  | ||||
| <LI> | ||||
| Modified the behavior of rounding mode <CODE>odd</CODE> when rounding to an | ||||
| integer value (either conversion to an integer format or a | ||||
| ‘<CODE>roundToInt</CODE>’ function). | ||||
| Previously, for those cases only, rounding mode <CODE>odd</CODE> acted the same | ||||
| as rounding to minimum magnitude. | ||||
| Now all operations are rounded consistently. | ||||
|  | ||||
| <LI> | ||||
| Fixed some errors in the specialization code modeling Intel x86 floating-point, | ||||
| specifically the integers returned on invalid operations and the propagation of | ||||
| NaN payloads in a few rare cases. | ||||
|  | ||||
| <LI> | ||||
| Added specialization code modeling ARM floating-point, conforming to VFPv2 or | ||||
| later. | ||||
|  | ||||
| <LI> | ||||
| Added an example target for ARM processors. | ||||
|  | ||||
| <LI> | ||||
| Fixed a minor bug whereby function <CODE>f16_to_ui64</CODE> might return a | ||||
| different integer than expected in the case that the floating-point operand is | ||||
| negative. | ||||
|  | ||||
| <LI> | ||||
| Added example target-specific optimization for GCC, employing GCC instrinsics | ||||
| and support for <NOBR>128-bit</NOBR> integer arithmetic. | ||||
|  | ||||
| <LI> | ||||
| Made other minor improvements. | ||||
|  | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| <H3>Release 3d (2017 August)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Fixed bugs in the square root functions for <NOBR>64-bit</NOBR> | ||||
| double-precision, <NOBR>80-bit</NOBR> double-extended-precision, and | ||||
| <NOBR>128-bit</NOBR> quadruple-precision. | ||||
| For <NOBR>64-bit</NOBR> double-precision (<CODE>f64_sqrt</CODE>), the result | ||||
| could sometimes be off by <NOBR>1 unit</NOBR> in the last place | ||||
| (<NOBR>1 ulp</NOBR>) from what it should be. | ||||
| For the larger formats, the square root could be wrong in a large portion of | ||||
| the less-significant bits. | ||||
| (A bug in <CODE>f128_sqrt</CODE> was first reported by Alexei Sibidanov.) | ||||
|  | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| <H3>Release 3c (2017 February)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Added optional rounding mode <CODE>odd</CODE> (round to odd, also known as | ||||
| <EM>jamming</EM>). | ||||
|  | ||||
| <LI> | ||||
| Corrected the documentation concerning non-canonical representations in | ||||
| <NOBR>80-bit</NOBR> double-extended-precision. | ||||
|  | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| <H3>Release 3b (2016 July)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Implemented the common <NOBR>16-bit</NOBR> “half-precision” | ||||
| floating-point format (<CODE>float16_t</CODE>). | ||||
|  | ||||
| <LI> | ||||
| Made the integer values returned on invalid conversions to integer formats | ||||
| be determined by the port-specific specialization instead of being the same for | ||||
| all ports. | ||||
|  | ||||
| <LI> | ||||
| Added preprocessor macro <CODE>THREAD_LOCAL</CODE> to allow the floating-point | ||||
| state (modes and exception flags) to be made per-thread. | ||||
|  | ||||
| <LI> | ||||
| Modified the provided Makefiles to allow some options to be overridden from the | ||||
| <CODE>make</CODE> command. | ||||
|  | ||||
| <LI> | ||||
| Made other minor improvements. | ||||
|  | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| <H3>Release 3a (2015 October)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Replaced the license text supplied by the University of California, Berkeley. | ||||
|  | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| <H3>Release 3 (2015 February)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Complete rewrite, funded by the University of California, Berkeley, and | ||||
| consequently having a different use license than earlier releases. | ||||
| Major changes included renaming most types and functions, upgrading some | ||||
| algorithms, restructuring the source files, and making SoftFloat into a true | ||||
| library. | ||||
|  | ||||
| <LI> | ||||
| Added functions to convert between floating-point and unsigned integers, both | ||||
| <NOBR>32-bit</NOBR> and <NOBR>64-bit</NOBR> (<CODE>uint32_t</CODE> and | ||||
| <CODE>uint64_t</CODE>). | ||||
|  | ||||
| <LI> | ||||
| Added functions for fused multiply-add, for all supported floating-point | ||||
| formats except <NOBR>80-bit</NOBR> double-extended-precision. | ||||
|  | ||||
| <LI> | ||||
| Added support for a fifth rounding mode, <CODE>near_maxMag</CODE> (round to | ||||
| nearest, with ties to maximum magnitude, away from zero). | ||||
|  | ||||
| <LI> | ||||
| Dropped the <CODE>timesoftfloat</CODE> program (now part of the Berkeley | ||||
| TestFloat package). | ||||
|  | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| <H3>Release 2c (2015 January)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Fixed mistakes affecting some <NOBR>64-bit</NOBR> processors. | ||||
|  | ||||
| <LI> | ||||
| Further improved the documentation and the wording for the legal restrictions | ||||
| on using SoftFloat releases <NOBR>through 2c</NOBR> (not applicable to | ||||
| <NOBR>Release 3</NOBR> or later). | ||||
|  | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| <H3>Release 2b (2002 May)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Made minor updates to the documentation, including improved wording for the | ||||
| legal restrictions on using SoftFloat. | ||||
|  | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| <H3>Release 2a (1998 December)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Added functions to convert between <NOBR>64-bit</NOBR> integers | ||||
| (<CODE>int64</CODE>) and all supported floating-point formats. | ||||
|  | ||||
| <LI> | ||||
| Fixed a bug in all <NOBR>64-bit</NOBR>-version square root functions except | ||||
| <CODE>float32_sqrt</CODE> that caused the result sometimes to be off by | ||||
| <NOBR>1 unit</NOBR> in the last place (<NOBR>1 ulp</NOBR>) from what it should | ||||
| be. | ||||
| (Bug discovered by Paul Donahue.) | ||||
|  | ||||
| <LI> | ||||
| Improved the Makefiles. | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| <H3>Release 2 (1997 June)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Created the <NOBR>64-bit</NOBR> (<CODE>bits64</CODE>) version, adding the | ||||
| <CODE>floatx80</CODE> and <CODE>float128</CODE> formats. | ||||
|  | ||||
| <LI> | ||||
| Changed the source directory structure, splitting the sources into a | ||||
| <CODE>bits32</CODE> and a <CODE>bits64</CODE> version. | ||||
| Renamed <CODE>environment.h</CODE> to <CODE>milieu.h</CODE> to avoid confusion | ||||
| with environment variables. | ||||
|  | ||||
| <LI> | ||||
| Fixed a small error that caused <CODE>float64_round_to_int</CODE> often to | ||||
| round the wrong way in nearest/even mode when the operand was between | ||||
| 2<SUP>20</SUP> and 2<SUP>21</SUP> and halfway between two integers. | ||||
|  | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| <H3>Release 1a (1996 July)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Corrected a mistake that caused borderline underflow cases not to raise the | ||||
| underflow flag when they should have. | ||||
| (Problem reported by Doug Priest.) | ||||
|  | ||||
| <LI> | ||||
| Added the <CODE>float_detect_tininess</CODE> variable to control whether | ||||
| tininess is detected before or after rounding. | ||||
|  | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| <H3>Release 1 (1996 July)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Original release, based on work done for the International Computer Science | ||||
| Institute (ICSI) in Berkeley, California. | ||||
|  | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| </BODY> | ||||
|  | ||||
|  | ||||
| <HTML> | ||||
|  | ||||
| <HEAD> | ||||
| <TITLE>Berkeley SoftFloat History</TITLE> | ||||
| </HEAD> | ||||
|  | ||||
| <BODY> | ||||
|  | ||||
| <H1>History of Berkeley SoftFloat, to Release 3e</H1> | ||||
|  | ||||
| <P> | ||||
| John R. Hauser<BR> | ||||
| 2018 January 20<BR> | ||||
| </P> | ||||
|  | ||||
|  | ||||
| <H3>Release 3e (2018 January)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Changed the default numeric code for optional rounding mode <CODE>odd</CODE> | ||||
| (round to odd, also known as <EM>jamming</EM>) from 5 to 6. | ||||
|  | ||||
| <LI> | ||||
| Modified the behavior of rounding mode <CODE>odd</CODE> when rounding to an | ||||
| integer value (either conversion to an integer format or a | ||||
| ‘<CODE>roundToInt</CODE>’ function). | ||||
| Previously, for those cases only, rounding mode <CODE>odd</CODE> acted the same | ||||
| as rounding to minimum magnitude. | ||||
| Now all operations are rounded consistently. | ||||
|  | ||||
| <LI> | ||||
| Fixed some errors in the specialization code modeling Intel x86 floating-point, | ||||
| specifically the integers returned on invalid operations and the propagation of | ||||
| NaN payloads in a few rare cases. | ||||
|  | ||||
| <LI> | ||||
| Added specialization code modeling ARM floating-point, conforming to VFPv2 or | ||||
| later. | ||||
|  | ||||
| <LI> | ||||
| Added an example target for ARM processors. | ||||
|  | ||||
| <LI> | ||||
| Fixed a minor bug whereby function <CODE>f16_to_ui64</CODE> might return a | ||||
| different integer than expected in the case that the floating-point operand is | ||||
| negative. | ||||
|  | ||||
| <LI> | ||||
| Added example target-specific optimization for GCC, employing GCC instrinsics | ||||
| and support for <NOBR>128-bit</NOBR> integer arithmetic. | ||||
|  | ||||
| <LI> | ||||
| Made other minor improvements. | ||||
|  | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| <H3>Release 3d (2017 August)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Fixed bugs in the square root functions for <NOBR>64-bit</NOBR> | ||||
| double-precision, <NOBR>80-bit</NOBR> double-extended-precision, and | ||||
| <NOBR>128-bit</NOBR> quadruple-precision. | ||||
| For <NOBR>64-bit</NOBR> double-precision (<CODE>f64_sqrt</CODE>), the result | ||||
| could sometimes be off by <NOBR>1 unit</NOBR> in the last place | ||||
| (<NOBR>1 ulp</NOBR>) from what it should be. | ||||
| For the larger formats, the square root could be wrong in a large portion of | ||||
| the less-significant bits. | ||||
| (A bug in <CODE>f128_sqrt</CODE> was first reported by Alexei Sibidanov.) | ||||
|  | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| <H3>Release 3c (2017 February)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Added optional rounding mode <CODE>odd</CODE> (round to odd, also known as | ||||
| <EM>jamming</EM>). | ||||
|  | ||||
| <LI> | ||||
| Corrected the documentation concerning non-canonical representations in | ||||
| <NOBR>80-bit</NOBR> double-extended-precision. | ||||
|  | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| <H3>Release 3b (2016 July)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Implemented the common <NOBR>16-bit</NOBR> “half-precision” | ||||
| floating-point format (<CODE>float16_t</CODE>). | ||||
|  | ||||
| <LI> | ||||
| Made the integer values returned on invalid conversions to integer formats | ||||
| be determined by the port-specific specialization instead of being the same for | ||||
| all ports. | ||||
|  | ||||
| <LI> | ||||
| Added preprocessor macro <CODE>THREAD_LOCAL</CODE> to allow the floating-point | ||||
| state (modes and exception flags) to be made per-thread. | ||||
|  | ||||
| <LI> | ||||
| Modified the provided Makefiles to allow some options to be overridden from the | ||||
| <CODE>make</CODE> command. | ||||
|  | ||||
| <LI> | ||||
| Made other minor improvements. | ||||
|  | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| <H3>Release 3a (2015 October)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Replaced the license text supplied by the University of California, Berkeley. | ||||
|  | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| <H3>Release 3 (2015 February)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Complete rewrite, funded by the University of California, Berkeley, and | ||||
| consequently having a different use license than earlier releases. | ||||
| Major changes included renaming most types and functions, upgrading some | ||||
| algorithms, restructuring the source files, and making SoftFloat into a true | ||||
| library. | ||||
|  | ||||
| <LI> | ||||
| Added functions to convert between floating-point and unsigned integers, both | ||||
| <NOBR>32-bit</NOBR> and <NOBR>64-bit</NOBR> (<CODE>uint32_t</CODE> and | ||||
| <CODE>uint64_t</CODE>). | ||||
|  | ||||
| <LI> | ||||
| Added functions for fused multiply-add, for all supported floating-point | ||||
| formats except <NOBR>80-bit</NOBR> double-extended-precision. | ||||
|  | ||||
| <LI> | ||||
| Added support for a fifth rounding mode, <CODE>near_maxMag</CODE> (round to | ||||
| nearest, with ties to maximum magnitude, away from zero). | ||||
|  | ||||
| <LI> | ||||
| Dropped the <CODE>timesoftfloat</CODE> program (now part of the Berkeley | ||||
| TestFloat package). | ||||
|  | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| <H3>Release 2c (2015 January)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Fixed mistakes affecting some <NOBR>64-bit</NOBR> processors. | ||||
|  | ||||
| <LI> | ||||
| Further improved the documentation and the wording for the legal restrictions | ||||
| on using SoftFloat releases <NOBR>through 2c</NOBR> (not applicable to | ||||
| <NOBR>Release 3</NOBR> or later). | ||||
|  | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| <H3>Release 2b (2002 May)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Made minor updates to the documentation, including improved wording for the | ||||
| legal restrictions on using SoftFloat. | ||||
|  | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| <H3>Release 2a (1998 December)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Added functions to convert between <NOBR>64-bit</NOBR> integers | ||||
| (<CODE>int64</CODE>) and all supported floating-point formats. | ||||
|  | ||||
| <LI> | ||||
| Fixed a bug in all <NOBR>64-bit</NOBR>-version square root functions except | ||||
| <CODE>float32_sqrt</CODE> that caused the result sometimes to be off by | ||||
| <NOBR>1 unit</NOBR> in the last place (<NOBR>1 ulp</NOBR>) from what it should | ||||
| be. | ||||
| (Bug discovered by Paul Donahue.) | ||||
|  | ||||
| <LI> | ||||
| Improved the Makefiles. | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| <H3>Release 2 (1997 June)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Created the <NOBR>64-bit</NOBR> (<CODE>bits64</CODE>) version, adding the | ||||
| <CODE>floatx80</CODE> and <CODE>float128</CODE> formats. | ||||
|  | ||||
| <LI> | ||||
| Changed the source directory structure, splitting the sources into a | ||||
| <CODE>bits32</CODE> and a <CODE>bits64</CODE> version. | ||||
| Renamed <CODE>environment.h</CODE> to <CODE>milieu.h</CODE> to avoid confusion | ||||
| with environment variables. | ||||
|  | ||||
| <LI> | ||||
| Fixed a small error that caused <CODE>float64_round_to_int</CODE> often to | ||||
| round the wrong way in nearest/even mode when the operand was between | ||||
| 2<SUP>20</SUP> and 2<SUP>21</SUP> and halfway between two integers. | ||||
|  | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| <H3>Release 1a (1996 July)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Corrected a mistake that caused borderline underflow cases not to raise the | ||||
| underflow flag when they should have. | ||||
| (Problem reported by Doug Priest.) | ||||
|  | ||||
| <LI> | ||||
| Added the <CODE>float_detect_tininess</CODE> variable to control whether | ||||
| tininess is detected before or after rounding. | ||||
|  | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| <H3>Release 1 (1996 July)</H3> | ||||
|  | ||||
| <UL> | ||||
|  | ||||
| <LI> | ||||
| Original release, based on work done for the International Computer Science | ||||
| Institute (ICSI) in Berkeley, California. | ||||
|  | ||||
| </UL> | ||||
|  | ||||
|  | ||||
| </BODY> | ||||
|  | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,57 +1,57 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| bool extF80M_isSignalingNaN( const extFloat80_t *aPtr ) | ||||
| { | ||||
|     const struct extFloat80M *aSPtr; | ||||
|     uint64_t uiA0; | ||||
|  | ||||
|     aSPtr = (const struct extFloat80M *) aPtr; | ||||
|     if ( (aSPtr->signExp & 0x7FFF) != 0x7FFF ) return false; | ||||
|     uiA0 = aSPtr->signif; | ||||
|     return | ||||
|         ! (uiA0 & UINT64_C( 0x4000000000000000 )) | ||||
|             && (uiA0 & UINT64_C( 0x3FFFFFFFFFFFFFFF)); | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| bool extF80M_isSignalingNaN( const extFloat80_t *aPtr ) | ||||
| { | ||||
|     const struct extFloat80M *aSPtr; | ||||
|     uint64_t uiA0; | ||||
|  | ||||
|     aSPtr = (const struct extFloat80M *) aPtr; | ||||
|     if ( (aSPtr->signExp & 0x7FFF) != 0x7FFF ) return false; | ||||
|     uiA0 = aSPtr->signif; | ||||
|     return | ||||
|         ! (uiA0 & UINT64_C( 0x4000000000000000 )) | ||||
|             && (uiA0 & UINT64_C( 0x3FFFFFFFFFFFFFFF)); | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,60 +1,60 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| bool f128M_isSignalingNaN( const float128_t *aPtr ) | ||||
| { | ||||
|     const uint32_t *aWPtr; | ||||
|     uint32_t uiA96; | ||||
|  | ||||
|     aWPtr = (const uint32_t *) aPtr; | ||||
|     uiA96 = aWPtr[indexWordHi( 4 )]; | ||||
|     if ( (uiA96 & 0x7FFF8000) != 0x7FFF0000 ) return false; | ||||
|     return | ||||
|         ((uiA96 & 0x00007FFF) != 0) | ||||
|             || ((aWPtr[indexWord( 4, 2 )] | aWPtr[indexWord( 4, 1 )] | ||||
|                      | aWPtr[indexWord( 4, 0 )]) | ||||
|                     != 0); | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| bool f128M_isSignalingNaN( const float128_t *aPtr ) | ||||
| { | ||||
|     const uint32_t *aWPtr; | ||||
|     uint32_t uiA96; | ||||
|  | ||||
|     aWPtr = (const uint32_t *) aPtr; | ||||
|     uiA96 = aWPtr[indexWordHi( 4 )]; | ||||
|     if ( (uiA96 & 0x7FFF8000) != 0x7FFF0000 ) return false; | ||||
|     return | ||||
|         ((uiA96 & 0x00007FFF) != 0) | ||||
|             || ((aWPtr[indexWord( 4, 2 )] | aWPtr[indexWord( 4, 1 )] | ||||
|                      | aWPtr[indexWord( 4, 0 )]) | ||||
|                     != 0); | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
							
								
								
									
										59
									
								
								softfloat/source/8086-SSE/s_bf16UIToCommonNaN.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								softfloat/source/8086-SSE/s_bf16UIToCommonNaN.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,59 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming `uiA' has the bit pattern of a BF16 NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by `zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_bf16UIToCommonNaN( uint_fast16_t uiA, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( softfloat_isSigNaNBF16UI( uiA ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = uiA>>15; | ||||
|     zPtr->v64  = (uint_fast64_t) uiA<<56; | ||||
|     zPtr->v0   = 0; | ||||
|  | ||||
| } | ||||
|  | ||||
							
								
								
									
										51
									
								
								softfloat/source/8086-SSE/s_commonNaNToBF16UI.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								softfloat/source/8086-SSE/s_commonNaNToBF16UI.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into a BF16 NaN, and  | ||||
| | returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast16_t softfloat_commonNaNToBF16UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|  | ||||
|     return (uint_fast16_t) aPtr->sign<<15 | 0x7FC0 | aPtr->v64>>56; | ||||
|  | ||||
| } | ||||
|  | ||||
| @@ -1,56 +1,56 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into an 80-bit extended | ||||
| | floating-point NaN, and stores this NaN at the location pointed to by | ||||
| | `zSPtr'. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_commonNaNToExtF80M( | ||||
|      const struct commonNaN *aPtr, struct extFloat80M *zSPtr ) | ||||
| { | ||||
|  | ||||
|     zSPtr->signExp = packToExtF80UI64( aPtr->sign, 0x7FFF ); | ||||
|     zSPtr->signif = UINT64_C( 0xC000000000000000 ) | aPtr->v64>>1; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into an 80-bit extended | ||||
| | floating-point NaN, and stores this NaN at the location pointed to by | ||||
| | `zSPtr'. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_commonNaNToExtF80M( | ||||
|      const struct commonNaN *aPtr, struct extFloat80M *zSPtr ) | ||||
| { | ||||
|  | ||||
|     zSPtr->signExp = packToExtF80UI64( aPtr->sign, 0x7FFF ); | ||||
|     zSPtr->signif = UINT64_C( 0xC000000000000000 ) | aPtr->v64>>1; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,56 +1,56 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into an 80-bit extended | ||||
| | floating-point NaN, and returns the bit pattern of this value as an unsigned | ||||
| | integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_commonNaNToExtF80UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|     struct uint128 uiZ; | ||||
|  | ||||
|     uiZ.v64 = (uint_fast16_t) aPtr->sign<<15 | 0x7FFF; | ||||
|     uiZ.v0 = UINT64_C( 0xC000000000000000 ) | aPtr->v64>>1; | ||||
|     return uiZ; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into an 80-bit extended | ||||
| | floating-point NaN, and returns the bit pattern of this value as an unsigned | ||||
| | integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_commonNaNToExtF80UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|     struct uint128 uiZ; | ||||
|  | ||||
|     uiZ.v64 = (uint_fast16_t) aPtr->sign<<15 | 0x7FFF; | ||||
|     uiZ.v0 = UINT64_C( 0xC000000000000000 ) | aPtr->v64>>1; | ||||
|     return uiZ; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,56 +1,56 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into a 128-bit floating-point | ||||
| | NaN, and stores this NaN at the location pointed to by `zWPtr'.  Argument | ||||
| | `zWPtr' points to an array of four 32-bit elements that concatenate in the | ||||
| | platform's normal endian order to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_commonNaNToF128M( const struct commonNaN *aPtr, uint32_t *zWPtr ) | ||||
| { | ||||
|  | ||||
|     softfloat_shortShiftRight128M( (const uint32_t *) &aPtr->v0, 16, zWPtr ); | ||||
|     zWPtr[indexWordHi( 4 )] |= (uint32_t) aPtr->sign<<31 | 0x7FFF8000; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into a 128-bit floating-point | ||||
| | NaN, and stores this NaN at the location pointed to by `zWPtr'.  Argument | ||||
| | `zWPtr' points to an array of four 32-bit elements that concatenate in the | ||||
| | platform's normal endian order to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_commonNaNToF128M( const struct commonNaN *aPtr, uint32_t *zWPtr ) | ||||
| { | ||||
|  | ||||
|     softfloat_shortShiftRight128M( (const uint32_t *) &aPtr->v0, 16, zWPtr ); | ||||
|     zWPtr[indexWordHi( 4 )] |= (uint32_t) aPtr->sign<<31 | 0x7FFF8000; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,55 +1,55 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into a 128-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_commonNaNToF128UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|     struct uint128 uiZ; | ||||
|  | ||||
|     uiZ = softfloat_shortShiftRight128( aPtr->v64, aPtr->v0, 16 ); | ||||
|     uiZ.v64 |= (uint_fast64_t) aPtr->sign<<63 | UINT64_C( 0x7FFF800000000000 ); | ||||
|     return uiZ; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into a 128-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_commonNaNToF128UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|     struct uint128 uiZ; | ||||
|  | ||||
|     uiZ = softfloat_shortShiftRight128( aPtr->v64, aPtr->v0, 16 ); | ||||
|     uiZ.v64 |= (uint_fast64_t) aPtr->sign<<63 | UINT64_C( 0x7FFF800000000000 ); | ||||
|     return uiZ; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,51 +1,51 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into a 16-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast16_t softfloat_commonNaNToF16UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|  | ||||
|     return (uint_fast16_t) aPtr->sign<<15 | 0x7E00 | aPtr->v64>>54; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into a 16-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast16_t softfloat_commonNaNToF16UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|  | ||||
|     return (uint_fast16_t) aPtr->sign<<15 | 0x7E00 | aPtr->v64>>54; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,51 +1,51 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into a 32-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast32_t softfloat_commonNaNToF32UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|  | ||||
|     return (uint_fast32_t) aPtr->sign<<31 | 0x7FC00000 | aPtr->v64>>41; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into a 32-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast32_t softfloat_commonNaNToF32UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|  | ||||
|     return (uint_fast32_t) aPtr->sign<<31 | 0x7FC00000 | aPtr->v64>>41; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,53 +1,53 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into a 64-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast64_t softfloat_commonNaNToF64UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|  | ||||
|     return | ||||
|         (uint_fast64_t) aPtr->sign<<63 | UINT64_C( 0x7FF8000000000000 ) | ||||
|             | aPtr->v64>>12; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into a 64-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast64_t softfloat_commonNaNToF64UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|  | ||||
|     return | ||||
|         (uint_fast64_t) aPtr->sign<<63 | UINT64_C( 0x7FF8000000000000 ) | ||||
|             | aPtr->v64>>12; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,62 +1,62 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the 80-bit extended floating-point value pointed to by `aSPtr' is | ||||
| | a NaN, converts this NaN to the common NaN form, and stores the resulting | ||||
| | common NaN at the location pointed to by `zPtr'.  If the NaN is a signaling | ||||
| | NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_extF80MToCommonNaN( | ||||
|      const struct extFloat80M *aSPtr, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( extF80M_isSignalingNaN( (const extFloat80_t *) aSPtr ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = signExtF80UI64( aSPtr->signExp ); | ||||
|     zPtr->v64 = aSPtr->signif<<1; | ||||
|     zPtr->v0  = 0; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the 80-bit extended floating-point value pointed to by `aSPtr' is | ||||
| | a NaN, converts this NaN to the common NaN form, and stores the resulting | ||||
| | common NaN at the location pointed to by `zPtr'.  If the NaN is a signaling | ||||
| | NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_extF80MToCommonNaN( | ||||
|      const struct extFloat80M *aSPtr, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( extF80M_isSignalingNaN( (const extFloat80_t *) aSPtr ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = signExtF80UI64( aSPtr->signExp ); | ||||
|     zPtr->v64 = aSPtr->signif<<1; | ||||
|     zPtr->v0  = 0; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,62 +1,62 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the unsigned integer formed from concatenating `uiA64' and `uiA0' | ||||
| | has the bit pattern of an 80-bit extended floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by `zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_extF80UIToCommonNaN( | ||||
|      uint_fast16_t uiA64, uint_fast64_t uiA0, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( softfloat_isSigNaNExtF80UI( uiA64, uiA0 ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = uiA64>>15; | ||||
|     zPtr->v64  = uiA0<<1; | ||||
|     zPtr->v0   = 0; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the unsigned integer formed from concatenating `uiA64' and `uiA0' | ||||
| | has the bit pattern of an 80-bit extended floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by `zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_extF80UIToCommonNaN( | ||||
|      uint_fast16_t uiA64, uint_fast64_t uiA0, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( softfloat_isSigNaNExtF80UI( uiA64, uiA0 ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = uiA64>>15; | ||||
|     zPtr->v64  = uiA0<<1; | ||||
|     zPtr->v0   = 0; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,62 +1,62 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the 128-bit floating-point value pointed to by `aWPtr' is a NaN, | ||||
| | converts this NaN to the common NaN form, and stores the resulting common | ||||
| | NaN at the location pointed to by `zPtr'.  If the NaN is a signaling NaN, | ||||
| | the invalid exception is raised.  Argument `aWPtr' points to an array of | ||||
| | four 32-bit elements that concatenate in the platform's normal endian order | ||||
| | to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_f128MToCommonNaN( const uint32_t *aWPtr, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( f128M_isSignalingNaN( (const float128_t *) aWPtr ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = aWPtr[indexWordHi( 4 )]>>31; | ||||
|     softfloat_shortShiftLeft128M( aWPtr, 16, (uint32_t *) &zPtr->v0 ); | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the 128-bit floating-point value pointed to by `aWPtr' is a NaN, | ||||
| | converts this NaN to the common NaN form, and stores the resulting common | ||||
| | NaN at the location pointed to by `zPtr'.  If the NaN is a signaling NaN, | ||||
| | the invalid exception is raised.  Argument `aWPtr' points to an array of | ||||
| | four 32-bit elements that concatenate in the platform's normal endian order | ||||
| | to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_f128MToCommonNaN( const uint32_t *aWPtr, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( f128M_isSignalingNaN( (const float128_t *) aWPtr ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = aWPtr[indexWordHi( 4 )]>>31; | ||||
|     softfloat_shortShiftLeft128M( aWPtr, 16, (uint32_t *) &zPtr->v0 ); | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,65 +1,65 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the unsigned integer formed from concatenating `uiA64' and `uiA0' | ||||
| | has the bit pattern of a 128-bit floating-point NaN, converts this NaN to | ||||
| | the common NaN form, and stores the resulting common NaN at the location | ||||
| | pointed to by `zPtr'.  If the NaN is a signaling NaN, the invalid exception | ||||
| | is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_f128UIToCommonNaN( | ||||
|      uint_fast64_t uiA64, uint_fast64_t uiA0, struct commonNaN *zPtr ) | ||||
| { | ||||
|     struct uint128 NaNSig; | ||||
|  | ||||
|     if ( softfloat_isSigNaNF128UI( uiA64, uiA0 ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     NaNSig = softfloat_shortShiftLeft128( uiA64, uiA0, 16 ); | ||||
|     zPtr->sign = uiA64>>63; | ||||
|     zPtr->v64  = NaNSig.v64; | ||||
|     zPtr->v0   = NaNSig.v0; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the unsigned integer formed from concatenating `uiA64' and `uiA0' | ||||
| | has the bit pattern of a 128-bit floating-point NaN, converts this NaN to | ||||
| | the common NaN form, and stores the resulting common NaN at the location | ||||
| | pointed to by `zPtr'.  If the NaN is a signaling NaN, the invalid exception | ||||
| | is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_f128UIToCommonNaN( | ||||
|      uint_fast64_t uiA64, uint_fast64_t uiA0, struct commonNaN *zPtr ) | ||||
| { | ||||
|     struct uint128 NaNSig; | ||||
|  | ||||
|     if ( softfloat_isSigNaNF128UI( uiA64, uiA0 ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     NaNSig = softfloat_shortShiftLeft128( uiA64, uiA0, 16 ); | ||||
|     zPtr->sign = uiA64>>63; | ||||
|     zPtr->v64  = NaNSig.v64; | ||||
|     zPtr->v0   = NaNSig.v0; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,59 +1,59 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming `uiA' has the bit pattern of a 16-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by `zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f16UIToCommonNaN( uint_fast16_t uiA, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( softfloat_isSigNaNF16UI( uiA ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = uiA>>15; | ||||
|     zPtr->v64  = (uint_fast64_t) uiA<<54; | ||||
|     zPtr->v0   = 0; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming `uiA' has the bit pattern of a 16-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by `zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f16UIToCommonNaN( uint_fast16_t uiA, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( softfloat_isSigNaNF16UI( uiA ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = uiA>>15; | ||||
|     zPtr->v64  = (uint_fast64_t) uiA<<54; | ||||
|     zPtr->v0   = 0; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,59 +1,59 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming `uiA' has the bit pattern of a 32-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by `zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f32UIToCommonNaN( uint_fast32_t uiA, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( softfloat_isSigNaNF32UI( uiA ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = uiA>>31; | ||||
|     zPtr->v64  = (uint_fast64_t) uiA<<41; | ||||
|     zPtr->v0   = 0; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming `uiA' has the bit pattern of a 32-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by `zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f32UIToCommonNaN( uint_fast32_t uiA, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( softfloat_isSigNaNF32UI( uiA ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = uiA>>31; | ||||
|     zPtr->v64  = (uint_fast64_t) uiA<<41; | ||||
|     zPtr->v0   = 0; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,59 +1,59 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming `uiA' has the bit pattern of a 64-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by `zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f64UIToCommonNaN( uint_fast64_t uiA, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( softfloat_isSigNaNF64UI( uiA ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = uiA>>63; | ||||
|     zPtr->v64  = uiA<<12; | ||||
|     zPtr->v0   = 0; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming `uiA' has the bit pattern of a 64-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by `zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f64UIToCommonNaN( uint_fast64_t uiA, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( softfloat_isSigNaNF64UI( uiA ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = uiA>>63; | ||||
|     zPtr->v64  = uiA<<12; | ||||
|     zPtr->v0   = 0; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,107 +1,107 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming at least one of the two 80-bit extended floating-point values | ||||
| | pointed to by `aSPtr' and `bSPtr' is a NaN, stores the combined NaN result | ||||
| | at the location pointed to by `zSPtr'.  If either original floating-point | ||||
| | value is a signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_propagateNaNExtF80M( | ||||
|      const struct extFloat80M *aSPtr, | ||||
|      const struct extFloat80M *bSPtr, | ||||
|      struct extFloat80M *zSPtr | ||||
|  ) | ||||
| { | ||||
|     bool isSigNaNA; | ||||
|     const struct extFloat80M *sPtr; | ||||
|     bool isSigNaNB; | ||||
|     uint_fast16_t uiB64; | ||||
|     uint64_t uiB0; | ||||
|     uint_fast16_t uiA64; | ||||
|     uint64_t uiA0; | ||||
|     uint_fast16_t uiMagA64, uiMagB64; | ||||
|  | ||||
|     isSigNaNA = extF80M_isSignalingNaN( (const extFloat80_t *) aSPtr ); | ||||
|     sPtr = aSPtr; | ||||
|     if ( ! bSPtr ) { | ||||
|         if ( isSigNaNA ) softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         goto copy; | ||||
|     } | ||||
|     isSigNaNB = extF80M_isSignalingNaN( (const extFloat80_t *) bSPtr ); | ||||
|     if ( isSigNaNA | isSigNaNB ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) { | ||||
|             uiB64 = bSPtr->signExp; | ||||
|             if ( isSigNaNB ) goto returnLargerUIMag; | ||||
|             uiB0 = bSPtr->signif; | ||||
|             if ( isNaNExtF80UI( uiB64, uiB0 ) ) goto copyB; | ||||
|             goto copy; | ||||
|         } else { | ||||
|             uiA64 = aSPtr->signExp; | ||||
|             uiA0 = aSPtr->signif; | ||||
|             if ( isNaNExtF80UI( uiA64, uiA0 ) ) goto copy; | ||||
|             goto copyB; | ||||
|         } | ||||
|     } | ||||
|     uiB64 = bSPtr->signExp; | ||||
|  returnLargerUIMag: | ||||
|     uiA64 = aSPtr->signExp; | ||||
|     uiMagA64 = uiA64 & 0x7FFF; | ||||
|     uiMagB64 = uiB64 & 0x7FFF; | ||||
|     if ( uiMagA64 < uiMagB64 ) goto copyB; | ||||
|     if ( uiMagB64 < uiMagA64 ) goto copy; | ||||
|     uiA0 = aSPtr->signif; | ||||
|     uiB0 = bSPtr->signif; | ||||
|     if ( uiA0 < uiB0 ) goto copyB; | ||||
|     if ( uiB0 < uiA0 ) goto copy; | ||||
|     if ( uiA64 < uiB64 ) goto copy; | ||||
|  copyB: | ||||
|     sPtr = bSPtr; | ||||
|  copy: | ||||
|     zSPtr->signExp = sPtr->signExp; | ||||
|     zSPtr->signif = sPtr->signif | UINT64_C( 0xC000000000000000 ); | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming at least one of the two 80-bit extended floating-point values | ||||
| | pointed to by `aSPtr' and `bSPtr' is a NaN, stores the combined NaN result | ||||
| | at the location pointed to by `zSPtr'.  If either original floating-point | ||||
| | value is a signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_propagateNaNExtF80M( | ||||
|      const struct extFloat80M *aSPtr, | ||||
|      const struct extFloat80M *bSPtr, | ||||
|      struct extFloat80M *zSPtr | ||||
|  ) | ||||
| { | ||||
|     bool isSigNaNA; | ||||
|     const struct extFloat80M *sPtr; | ||||
|     bool isSigNaNB; | ||||
|     uint_fast16_t uiB64; | ||||
|     uint64_t uiB0; | ||||
|     uint_fast16_t uiA64; | ||||
|     uint64_t uiA0; | ||||
|     uint_fast16_t uiMagA64, uiMagB64; | ||||
|  | ||||
|     isSigNaNA = extF80M_isSignalingNaN( (const extFloat80_t *) aSPtr ); | ||||
|     sPtr = aSPtr; | ||||
|     if ( ! bSPtr ) { | ||||
|         if ( isSigNaNA ) softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         goto copy; | ||||
|     } | ||||
|     isSigNaNB = extF80M_isSignalingNaN( (const extFloat80_t *) bSPtr ); | ||||
|     if ( isSigNaNA | isSigNaNB ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) { | ||||
|             uiB64 = bSPtr->signExp; | ||||
|             if ( isSigNaNB ) goto returnLargerUIMag; | ||||
|             uiB0 = bSPtr->signif; | ||||
|             if ( isNaNExtF80UI( uiB64, uiB0 ) ) goto copyB; | ||||
|             goto copy; | ||||
|         } else { | ||||
|             uiA64 = aSPtr->signExp; | ||||
|             uiA0 = aSPtr->signif; | ||||
|             if ( isNaNExtF80UI( uiA64, uiA0 ) ) goto copy; | ||||
|             goto copyB; | ||||
|         } | ||||
|     } | ||||
|     uiB64 = bSPtr->signExp; | ||||
|  returnLargerUIMag: | ||||
|     uiA64 = aSPtr->signExp; | ||||
|     uiMagA64 = uiA64 & 0x7FFF; | ||||
|     uiMagB64 = uiB64 & 0x7FFF; | ||||
|     if ( uiMagA64 < uiMagB64 ) goto copyB; | ||||
|     if ( uiMagB64 < uiMagA64 ) goto copy; | ||||
|     uiA0 = aSPtr->signif; | ||||
|     uiB0 = bSPtr->signif; | ||||
|     if ( uiA0 < uiB0 ) goto copyB; | ||||
|     if ( uiB0 < uiA0 ) goto copy; | ||||
|     if ( uiA64 < uiB64 ) goto copy; | ||||
|  copyB: | ||||
|     sPtr = bSPtr; | ||||
|  copy: | ||||
|     zSPtr->signExp = sPtr->signExp; | ||||
|     zSPtr->signif = sPtr->signif | UINT64_C( 0xC000000000000000 ); | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,106 +1,106 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2018 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting the unsigned integer formed from concatenating 'uiA64' and | ||||
| | 'uiA0' as an 80-bit extended floating-point value, and likewise interpreting | ||||
| | the unsigned integer formed from concatenating 'uiB64' and 'uiB0' as another | ||||
| | 80-bit extended floating-point value, and assuming at least on of these | ||||
| | floating-point values is a NaN, returns the bit pattern of the combined NaN | ||||
| | result.  If either original floating-point value is a signaling NaN, the | ||||
| | invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 | ||||
|  softfloat_propagateNaNExtF80UI( | ||||
|      uint_fast16_t uiA64, | ||||
|      uint_fast64_t uiA0, | ||||
|      uint_fast16_t uiB64, | ||||
|      uint_fast64_t uiB0 | ||||
|  ) | ||||
| { | ||||
|     bool isSigNaNA, isSigNaNB; | ||||
|     uint_fast64_t uiNonsigA0, uiNonsigB0; | ||||
|     uint_fast16_t uiMagA64, uiMagB64; | ||||
|     struct uint128 uiZ; | ||||
|  | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     isSigNaNA = softfloat_isSigNaNExtF80UI( uiA64, uiA0 ); | ||||
|     isSigNaNB = softfloat_isSigNaNExtF80UI( uiB64, uiB0 ); | ||||
|     /*------------------------------------------------------------------------ | ||||
|     | Make NaNs non-signaling. | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     uiNonsigA0 = uiA0 | UINT64_C( 0xC000000000000000 ); | ||||
|     uiNonsigB0 = uiB0 | UINT64_C( 0xC000000000000000 ); | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     if ( isSigNaNA | isSigNaNB ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) { | ||||
|             if ( isSigNaNB ) goto returnLargerMag; | ||||
|             if ( isNaNExtF80UI( uiB64, uiB0 ) ) goto returnB; | ||||
|             goto returnA; | ||||
|         } else { | ||||
|             if ( isNaNExtF80UI( uiA64, uiA0 ) ) goto returnA; | ||||
|             goto returnB; | ||||
|         } | ||||
|     } | ||||
|  returnLargerMag: | ||||
|     uiMagA64 = uiA64 & 0x7FFF; | ||||
|     uiMagB64 = uiB64 & 0x7FFF; | ||||
|     if ( uiMagA64 < uiMagB64 ) goto returnB; | ||||
|     if ( uiMagB64 < uiMagA64 ) goto returnA; | ||||
|     if ( uiA0 < uiB0 ) goto returnB; | ||||
|     if ( uiB0 < uiA0 ) goto returnA; | ||||
|     if ( uiA64 < uiB64 ) goto returnA; | ||||
|  returnB: | ||||
|     uiZ.v64 = uiB64; | ||||
|     uiZ.v0  = uiNonsigB0; | ||||
|     return uiZ; | ||||
|  returnA: | ||||
|     uiZ.v64 = uiA64; | ||||
|     uiZ.v0  = uiNonsigA0; | ||||
|     return uiZ; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2018 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting the unsigned integer formed from concatenating 'uiA64' and | ||||
| | 'uiA0' as an 80-bit extended floating-point value, and likewise interpreting | ||||
| | the unsigned integer formed from concatenating 'uiB64' and 'uiB0' as another | ||||
| | 80-bit extended floating-point value, and assuming at least on of these | ||||
| | floating-point values is a NaN, returns the bit pattern of the combined NaN | ||||
| | result.  If either original floating-point value is a signaling NaN, the | ||||
| | invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 | ||||
|  softfloat_propagateNaNExtF80UI( | ||||
|      uint_fast16_t uiA64, | ||||
|      uint_fast64_t uiA0, | ||||
|      uint_fast16_t uiB64, | ||||
|      uint_fast64_t uiB0 | ||||
|  ) | ||||
| { | ||||
|     bool isSigNaNA, isSigNaNB; | ||||
|     uint_fast64_t uiNonsigA0, uiNonsigB0; | ||||
|     uint_fast16_t uiMagA64, uiMagB64; | ||||
|     struct uint128 uiZ; | ||||
|  | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     isSigNaNA = softfloat_isSigNaNExtF80UI( uiA64, uiA0 ); | ||||
|     isSigNaNB = softfloat_isSigNaNExtF80UI( uiB64, uiB0 ); | ||||
|     /*------------------------------------------------------------------------ | ||||
|     | Make NaNs non-signaling. | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     uiNonsigA0 = uiA0 | UINT64_C( 0xC000000000000000 ); | ||||
|     uiNonsigB0 = uiB0 | UINT64_C( 0xC000000000000000 ); | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     if ( isSigNaNA | isSigNaNB ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) { | ||||
|             if ( isSigNaNB ) goto returnLargerMag; | ||||
|             if ( isNaNExtF80UI( uiB64, uiB0 ) ) goto returnB; | ||||
|             goto returnA; | ||||
|         } else { | ||||
|             if ( isNaNExtF80UI( uiA64, uiA0 ) ) goto returnA; | ||||
|             goto returnB; | ||||
|         } | ||||
|     } | ||||
|  returnLargerMag: | ||||
|     uiMagA64 = uiA64 & 0x7FFF; | ||||
|     uiMagB64 = uiB64 & 0x7FFF; | ||||
|     if ( uiMagA64 < uiMagB64 ) goto returnB; | ||||
|     if ( uiMagB64 < uiMagA64 ) goto returnA; | ||||
|     if ( uiA0 < uiB0 ) goto returnB; | ||||
|     if ( uiB0 < uiA0 ) goto returnA; | ||||
|     if ( uiA64 < uiB64 ) goto returnA; | ||||
|  returnB: | ||||
|     uiZ.v64 = uiB64; | ||||
|     uiZ.v0  = uiNonsigB0; | ||||
|     return uiZ; | ||||
|  returnA: | ||||
|     uiZ.v64 = uiA64; | ||||
|     uiZ.v0  = uiNonsigA0; | ||||
|     return uiZ; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,76 +1,76 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming at least one of the two 128-bit floating-point values pointed to by | ||||
| | `aWPtr' and `bWPtr' is a NaN, stores the combined NaN result at the location | ||||
| | pointed to by `zWPtr'.  If either original floating-point value is a | ||||
| | signaling NaN, the invalid exception is raised.  Each of `aWPtr', `bWPtr', | ||||
| | and `zWPtr' points to an array of four 32-bit elements that concatenate in | ||||
| | the platform's normal endian order to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_propagateNaNF128M( | ||||
|      const uint32_t *aWPtr, const uint32_t *bWPtr, uint32_t *zWPtr ) | ||||
| { | ||||
|     bool isSigNaNA; | ||||
|     const uint32_t *ptr; | ||||
|  | ||||
|     ptr = aWPtr; | ||||
|     isSigNaNA = f128M_isSignalingNaN( (const float128_t *) aWPtr ); | ||||
|     if ( | ||||
|         isSigNaNA | ||||
|             || (bWPtr && f128M_isSignalingNaN( (const float128_t *) bWPtr )) | ||||
|     ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) goto copy; | ||||
|     } | ||||
|     if ( ! softfloat_isNaNF128M( aWPtr ) ) ptr = bWPtr; | ||||
|  copy: | ||||
|     zWPtr[indexWordHi( 4 )] = ptr[indexWordHi( 4 )] | 0x00008000; | ||||
|     zWPtr[indexWord( 4, 2 )] = ptr[indexWord( 4, 2 )]; | ||||
|     zWPtr[indexWord( 4, 1 )] = ptr[indexWord( 4, 1 )]; | ||||
|     zWPtr[indexWord( 4, 0 )] = ptr[indexWord( 4, 0 )]; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming at least one of the two 128-bit floating-point values pointed to by | ||||
| | `aWPtr' and `bWPtr' is a NaN, stores the combined NaN result at the location | ||||
| | pointed to by `zWPtr'.  If either original floating-point value is a | ||||
| | signaling NaN, the invalid exception is raised.  Each of `aWPtr', `bWPtr', | ||||
| | and `zWPtr' points to an array of four 32-bit elements that concatenate in | ||||
| | the platform's normal endian order to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_propagateNaNF128M( | ||||
|      const uint32_t *aWPtr, const uint32_t *bWPtr, uint32_t *zWPtr ) | ||||
| { | ||||
|     bool isSigNaNA; | ||||
|     const uint32_t *ptr; | ||||
|  | ||||
|     ptr = aWPtr; | ||||
|     isSigNaNA = f128M_isSignalingNaN( (const float128_t *) aWPtr ); | ||||
|     if ( | ||||
|         isSigNaNA | ||||
|             || (bWPtr && f128M_isSignalingNaN( (const float128_t *) bWPtr )) | ||||
|     ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) goto copy; | ||||
|     } | ||||
|     if ( ! softfloat_isNaNF128M( aWPtr ) ) ptr = bWPtr; | ||||
|  copy: | ||||
|     zWPtr[indexWordHi( 4 )] = ptr[indexWordHi( 4 )] | 0x00008000; | ||||
|     zWPtr[indexWord( 4, 2 )] = ptr[indexWord( 4, 2 )]; | ||||
|     zWPtr[indexWord( 4, 1 )] = ptr[indexWord( 4, 1 )]; | ||||
|     zWPtr[indexWord( 4, 0 )] = ptr[indexWord( 4, 0 )]; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,81 +1,81 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting the unsigned integer formed from concatenating `uiA64' and | ||||
| | `uiA0' as a 128-bit floating-point value, and likewise interpreting the | ||||
| | unsigned integer formed from concatenating `uiB64' and `uiB0' as another | ||||
| | 128-bit floating-point value, and assuming at least on of these floating- | ||||
| | point values is a NaN, returns the bit pattern of the combined NaN result. | ||||
| | If either original floating-point value is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 | ||||
|  softfloat_propagateNaNF128UI( | ||||
|      uint_fast64_t uiA64, | ||||
|      uint_fast64_t uiA0, | ||||
|      uint_fast64_t uiB64, | ||||
|      uint_fast64_t uiB0 | ||||
|  ) | ||||
| { | ||||
|     bool isSigNaNA; | ||||
|     struct uint128 uiZ; | ||||
|  | ||||
|     isSigNaNA = softfloat_isSigNaNF128UI( uiA64, uiA0 ); | ||||
|     if ( isSigNaNA || softfloat_isSigNaNF128UI( uiB64, uiB0 ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) goto returnNonsigA; | ||||
|     } | ||||
|     if ( isNaNF128UI( uiA64, uiA0 ) ) { | ||||
|  returnNonsigA: | ||||
|         uiZ.v64 = uiA64; | ||||
|         uiZ.v0  = uiA0; | ||||
|     } else { | ||||
|         uiZ.v64 = uiB64; | ||||
|         uiZ.v0  = uiB0; | ||||
|     } | ||||
|     uiZ.v64 |= UINT64_C( 0x0000800000000000 ); | ||||
|     return uiZ; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting the unsigned integer formed from concatenating `uiA64' and | ||||
| | `uiA0' as a 128-bit floating-point value, and likewise interpreting the | ||||
| | unsigned integer formed from concatenating `uiB64' and `uiB0' as another | ||||
| | 128-bit floating-point value, and assuming at least on of these floating- | ||||
| | point values is a NaN, returns the bit pattern of the combined NaN result. | ||||
| | If either original floating-point value is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 | ||||
|  softfloat_propagateNaNF128UI( | ||||
|      uint_fast64_t uiA64, | ||||
|      uint_fast64_t uiA0, | ||||
|      uint_fast64_t uiB64, | ||||
|      uint_fast64_t uiB0 | ||||
|  ) | ||||
| { | ||||
|     bool isSigNaNA; | ||||
|     struct uint128 uiZ; | ||||
|  | ||||
|     isSigNaNA = softfloat_isSigNaNF128UI( uiA64, uiA0 ); | ||||
|     if ( isSigNaNA || softfloat_isSigNaNF128UI( uiB64, uiB0 ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) goto returnNonsigA; | ||||
|     } | ||||
|     if ( isNaNF128UI( uiA64, uiA0 ) ) { | ||||
|  returnNonsigA: | ||||
|         uiZ.v64 = uiA64; | ||||
|         uiZ.v0  = uiA0; | ||||
|     } else { | ||||
|         uiZ.v64 = uiB64; | ||||
|         uiZ.v0  = uiB0; | ||||
|     } | ||||
|     uiZ.v64 |= UINT64_C( 0x0000800000000000 ); | ||||
|     return uiZ; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,63 +1,63 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting `uiA' and `uiB' as the bit patterns of two 16-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either `uiA' or `uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast16_t | ||||
|  softfloat_propagateNaNF16UI( uint_fast16_t uiA, uint_fast16_t uiB ) | ||||
| { | ||||
|     bool isSigNaNA; | ||||
|  | ||||
|     isSigNaNA = softfloat_isSigNaNF16UI( uiA ); | ||||
|     if ( isSigNaNA || softfloat_isSigNaNF16UI( uiB ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) return uiA | 0x0200; | ||||
|     } | ||||
|     return (isNaNF16UI( uiA ) ? uiA : uiB) | 0x0200; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting `uiA' and `uiB' as the bit patterns of two 16-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either `uiA' or `uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast16_t | ||||
|  softfloat_propagateNaNF16UI( uint_fast16_t uiA, uint_fast16_t uiB ) | ||||
| { | ||||
|     bool isSigNaNA; | ||||
|  | ||||
|     isSigNaNA = softfloat_isSigNaNF16UI( uiA ); | ||||
|     if ( isSigNaNA || softfloat_isSigNaNF16UI( uiB ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) return uiA | 0x0200; | ||||
|     } | ||||
|     return (isNaNF16UI( uiA ) ? uiA : uiB) | 0x0200; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,63 +1,63 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting `uiA' and `uiB' as the bit patterns of two 32-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either `uiA' or `uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast32_t | ||||
|  softfloat_propagateNaNF32UI( uint_fast32_t uiA, uint_fast32_t uiB ) | ||||
| { | ||||
|     bool isSigNaNA; | ||||
|  | ||||
|     isSigNaNA = softfloat_isSigNaNF32UI( uiA ); | ||||
|     if ( isSigNaNA || softfloat_isSigNaNF32UI( uiB ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) return uiA | 0x00400000; | ||||
|     } | ||||
|     return (isNaNF32UI( uiA ) ? uiA : uiB) | 0x00400000; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting `uiA' and `uiB' as the bit patterns of two 32-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either `uiA' or `uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast32_t | ||||
|  softfloat_propagateNaNF32UI( uint_fast32_t uiA, uint_fast32_t uiB ) | ||||
| { | ||||
|     bool isSigNaNA; | ||||
|  | ||||
|     isSigNaNA = softfloat_isSigNaNF32UI( uiA ); | ||||
|     if ( isSigNaNA || softfloat_isSigNaNF32UI( uiB ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) return uiA | 0x00400000; | ||||
|     } | ||||
|     return (isNaNF32UI( uiA ) ? uiA : uiB) | 0x00400000; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,63 +1,63 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting `uiA' and `uiB' as the bit patterns of two 64-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either `uiA' or `uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast64_t | ||||
|  softfloat_propagateNaNF64UI( uint_fast64_t uiA, uint_fast64_t uiB ) | ||||
| { | ||||
|     bool isSigNaNA; | ||||
|  | ||||
|     isSigNaNA = softfloat_isSigNaNF64UI( uiA ); | ||||
|     if ( isSigNaNA || softfloat_isSigNaNF64UI( uiB ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) return uiA | UINT64_C( 0x0008000000000000 ); | ||||
|     } | ||||
|     return (isNaNF64UI( uiA ) ? uiA : uiB) | UINT64_C( 0x0008000000000000 ); | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting `uiA' and `uiB' as the bit patterns of two 64-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either `uiA' or `uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast64_t | ||||
|  softfloat_propagateNaNF64UI( uint_fast64_t uiA, uint_fast64_t uiB ) | ||||
| { | ||||
|     bool isSigNaNA; | ||||
|  | ||||
|     isSigNaNA = softfloat_isSigNaNF64UI( uiA ); | ||||
|     if ( isSigNaNA || softfloat_isSigNaNF64UI( uiB ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) return uiA | UINT64_C( 0x0008000000000000 ); | ||||
|     } | ||||
|     return (isNaNF64UI( uiA ) ? uiA : uiB) | UINT64_C( 0x0008000000000000 ); | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,52 +1,52 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include "platform.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Raises the exceptions specified by `flags'.  Floating-point traps can be | ||||
| | defined here if desired.  It is currently not possible for such a trap | ||||
| | to substitute a result value.  If traps are not implemented, this routine | ||||
| | should be simply `softfloat_exceptionFlags |= flags;'. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_raiseFlags( uint_fast8_t flags ) | ||||
| { | ||||
|  | ||||
|     softfloat_exceptionFlags |= flags; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include "platform.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Raises the exceptions specified by `flags'.  Floating-point traps can be | ||||
| | defined here if desired.  It is currently not possible for such a trap | ||||
| | to substitute a result value.  If traps are not implemented, this routine | ||||
| | should be simply `softfloat_exceptionFlags |= flags;'. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_raiseFlags( uint_fast8_t flags ) | ||||
| { | ||||
|  | ||||
|     softfloat_exceptionFlags |= flags; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,346 +1,367 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2018 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #ifndef specialize_h | ||||
| #define specialize_h 1 | ||||
|  | ||||
| #include "primitiveTypes.h" | ||||
| #include "softfloat.h" | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Default value for 'softfloat_detectTininess'. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define init_detectTininess softfloat_tininess_afterRounding | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The values to return on conversions to 32-bit integer formats that raise an | ||||
| | invalid exception. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define ui32_fromPosOverflow 0xFFFFFFFF | ||||
| #define ui32_fromNegOverflow 0xFFFFFFFF | ||||
| #define ui32_fromNaN 0xFFFFFFFF | ||||
| #define i32_fromPosOverflow (-0x7FFFFFFF - 1) | ||||
| #define i32_fromNegOverflow (-0x7FFFFFFF - 1) | ||||
| #define i32_fromNaN (-0x7FFFFFFF - 1) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The values to return on conversions to 64-bit integer formats that raise an | ||||
| | invalid exception. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define ui64_fromPosOverflow UINT64_C(0xFFFFFFFFFFFFFFFF) | ||||
| #define ui64_fromNegOverflow UINT64_C(0xFFFFFFFFFFFFFFFF) | ||||
| #define ui64_fromNaN UINT64_C(0xFFFFFFFFFFFFFFFF) | ||||
| #define i64_fromPosOverflow (-INT64_C(0x7FFFFFFFFFFFFFFF) - 1) | ||||
| #define i64_fromNegOverflow (-INT64_C(0x7FFFFFFFFFFFFFFF) - 1) | ||||
| #define i64_fromNaN (-INT64_C(0x7FFFFFFFFFFFFFFF) - 1) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | "Common NaN" structure, used to transfer NaN representations from one format | ||||
| | to another. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct commonNaN { | ||||
|     bool sign; | ||||
| #ifdef LITTLEENDIAN | ||||
|     uint64_t v0, v64; | ||||
| #else | ||||
|     uint64_t v64, v0; | ||||
| #endif | ||||
| }; | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 16-bit floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNF16UI 0xFE00 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Returns true when 16-bit unsigned integer 'uiA' has the bit pattern of a | ||||
| | 16-bit floating-point signaling NaN. | ||||
| | Note:  This macro evaluates its argument more than once. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define softfloat_isSigNaNF16UI(uiA) ((((uiA)&0x7E00) == 0x7C00) && ((uiA)&0x01FF)) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming 'uiA' has the bit pattern of a 16-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by 'zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f16UIToCommonNaN(uint_fast16_t uiA, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 16-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast16_t softfloat_commonNaNToF16UI(const struct commonNaN* aPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting 'uiA' and 'uiB' as the bit patterns of two 16-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either 'uiA' or 'uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast16_t softfloat_propagateNaNF16UI(uint_fast16_t uiA, uint_fast16_t uiB); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 32-bit floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNF32UI 0xFFC00000 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Returns true when 32-bit unsigned integer 'uiA' has the bit pattern of a | ||||
| | 32-bit floating-point signaling NaN. | ||||
| | Note:  This macro evaluates its argument more than once. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define softfloat_isSigNaNF32UI(uiA) ((((uiA)&0x7FC00000) == 0x7F800000) && ((uiA)&0x003FFFFF)) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming 'uiA' has the bit pattern of a 32-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by 'zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f32UIToCommonNaN(uint_fast32_t uiA, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 32-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast32_t softfloat_commonNaNToF32UI(const struct commonNaN* aPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting 'uiA' and 'uiB' as the bit patterns of two 32-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either 'uiA' or 'uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast32_t softfloat_propagateNaNF32UI(uint_fast32_t uiA, uint_fast32_t uiB); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 64-bit floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNF64UI UINT64_C(0xFFF8000000000000) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Returns true when 64-bit unsigned integer 'uiA' has the bit pattern of a | ||||
| | 64-bit floating-point signaling NaN. | ||||
| | Note:  This macro evaluates its argument more than once. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define softfloat_isSigNaNF64UI(uiA)                                                                                                       \ | ||||
|     ((((uiA)&UINT64_C(0x7FF8000000000000)) == UINT64_C(0x7FF0000000000000)) && ((uiA)&UINT64_C(0x0007FFFFFFFFFFFF))) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming 'uiA' has the bit pattern of a 64-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by 'zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f64UIToCommonNaN(uint_fast64_t uiA, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 64-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast64_t softfloat_commonNaNToF64UI(const struct commonNaN* aPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting 'uiA' and 'uiB' as the bit patterns of two 64-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either 'uiA' or 'uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast64_t softfloat_propagateNaNF64UI(uint_fast64_t uiA, uint_fast64_t uiB); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 80-bit extended floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNExtF80UI64 0xFFFF | ||||
| #define defaultNaNExtF80UI0 UINT64_C(0xC000000000000000) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Returns true when the 80-bit unsigned integer formed from concatenating | ||||
| | 16-bit 'uiA64' and 64-bit 'uiA0' has the bit pattern of an 80-bit extended | ||||
| | floating-point signaling NaN. | ||||
| | Note:  This macro evaluates its arguments more than once. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define softfloat_isSigNaNExtF80UI(uiA64, uiA0)                                                                                            \ | ||||
|     ((((uiA64)&0x7FFF) == 0x7FFF) && !((uiA0)&UINT64_C(0x4000000000000000)) && ((uiA0)&UINT64_C(0x3FFFFFFFFFFFFFFF))) | ||||
|  | ||||
| #ifdef SOFTFLOAT_FAST_INT64 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The following functions are needed only when 'SOFTFLOAT_FAST_INT64' is | ||||
| | defined. | ||||
| *----------------------------------------------------------------------------*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the unsigned integer formed from concatenating 'uiA64' and 'uiA0' | ||||
| | has the bit pattern of an 80-bit extended floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by 'zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_extF80UIToCommonNaN(uint_fast16_t uiA64, uint_fast64_t uiA0, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into an 80-bit extended | ||||
| | floating-point NaN, and returns the bit pattern of this value as an unsigned | ||||
| | integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_commonNaNToExtF80UI(const struct commonNaN* aPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting the unsigned integer formed from concatenating 'uiA64' and | ||||
| | 'uiA0' as an 80-bit extended floating-point value, and likewise interpreting | ||||
| | the unsigned integer formed from concatenating 'uiB64' and 'uiB0' as another | ||||
| | 80-bit extended floating-point value, and assuming at least on of these | ||||
| | floating-point values is a NaN, returns the bit pattern of the combined NaN | ||||
| | result.  If either original floating-point value is a signaling NaN, the | ||||
| | invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_propagateNaNExtF80UI(uint_fast16_t uiA64, uint_fast64_t uiA0, uint_fast16_t uiB64, uint_fast64_t uiB0); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 128-bit floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNF128UI64 UINT64_C(0xFFFF800000000000) | ||||
| #define defaultNaNF128UI0 UINT64_C(0) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Returns true when the 128-bit unsigned integer formed from concatenating | ||||
| | 64-bit 'uiA64' and 64-bit 'uiA0' has the bit pattern of a 128-bit floating- | ||||
| | point signaling NaN. | ||||
| | Note:  This macro evaluates its arguments more than once. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define softfloat_isSigNaNF128UI(uiA64, uiA0)                                                                                              \ | ||||
|     ((((uiA64)&UINT64_C(0x7FFF800000000000)) == UINT64_C(0x7FFF000000000000)) && ((uiA0) || ((uiA64)&UINT64_C(0x00007FFFFFFFFFFF)))) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the unsigned integer formed from concatenating 'uiA64' and 'uiA0' | ||||
| | has the bit pattern of a 128-bit floating-point NaN, converts this NaN to | ||||
| | the common NaN form, and stores the resulting common NaN at the location | ||||
| | pointed to by 'zPtr'.  If the NaN is a signaling NaN, the invalid exception | ||||
| | is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f128UIToCommonNaN(uint_fast64_t uiA64, uint_fast64_t uiA0, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 128-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_commonNaNToF128UI(const struct commonNaN*); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting the unsigned integer formed from concatenating 'uiA64' and | ||||
| | 'uiA0' as a 128-bit floating-point value, and likewise interpreting the | ||||
| | unsigned integer formed from concatenating 'uiB64' and 'uiB0' as another | ||||
| | 128-bit floating-point value, and assuming at least on of these floating- | ||||
| | point values is a NaN, returns the bit pattern of the combined NaN result. | ||||
| | If either original floating-point value is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_propagateNaNF128UI(uint_fast64_t uiA64, uint_fast64_t uiA0, uint_fast64_t uiB64, uint_fast64_t uiB0); | ||||
|  | ||||
| #else | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The following functions are needed only when 'SOFTFLOAT_FAST_INT64' is not | ||||
| | defined. | ||||
| *----------------------------------------------------------------------------*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the 80-bit extended floating-point value pointed to by 'aSPtr' is | ||||
| | a NaN, converts this NaN to the common NaN form, and stores the resulting | ||||
| | common NaN at the location pointed to by 'zPtr'.  If the NaN is a signaling | ||||
| | NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_extF80MToCommonNaN(const struct extFloat80M* aSPtr, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into an 80-bit extended | ||||
| | floating-point NaN, and stores this NaN at the location pointed to by | ||||
| | 'zSPtr'. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_commonNaNToExtF80M(const struct commonNaN* aPtr, struct extFloat80M* zSPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming at least one of the two 80-bit extended floating-point values | ||||
| | pointed to by 'aSPtr' and 'bSPtr' is a NaN, stores the combined NaN result | ||||
| | at the location pointed to by 'zSPtr'.  If either original floating-point | ||||
| | value is a signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_propagateNaNExtF80M(const struct extFloat80M* aSPtr, const struct extFloat80M* bSPtr, struct extFloat80M* zSPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 128-bit floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNF128UI96 0xFFFF8000 | ||||
| #define defaultNaNF128UI64 0 | ||||
| #define defaultNaNF128UI32 0 | ||||
| #define defaultNaNF128UI0 0 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the 128-bit floating-point value pointed to by 'aWPtr' is a NaN, | ||||
| | converts this NaN to the common NaN form, and stores the resulting common | ||||
| | NaN at the location pointed to by 'zPtr'.  If the NaN is a signaling NaN, | ||||
| | the invalid exception is raised.  Argument 'aWPtr' points to an array of | ||||
| | four 32-bit elements that concatenate in the platform's normal endian order | ||||
| | to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f128MToCommonNaN(const uint32_t* aWPtr, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 128-bit floating-point | ||||
| | NaN, and stores this NaN at the location pointed to by 'zWPtr'.  Argument | ||||
| | 'zWPtr' points to an array of four 32-bit elements that concatenate in the | ||||
| | platform's normal endian order to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_commonNaNToF128M(const struct commonNaN* aPtr, uint32_t* zWPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming at least one of the two 128-bit floating-point values pointed to by | ||||
| | 'aWPtr' and 'bWPtr' is a NaN, stores the combined NaN result at the location | ||||
| | pointed to by 'zWPtr'.  If either original floating-point value is a | ||||
| | signaling NaN, the invalid exception is raised.  Each of 'aWPtr', 'bWPtr', | ||||
| | and 'zWPtr' points to an array of four 32-bit elements that concatenate in | ||||
| | the platform's normal endian order to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_propagateNaNF128M(const uint32_t* aWPtr, const uint32_t* bWPtr, uint32_t* zWPtr); | ||||
|  | ||||
| #endif | ||||
|  | ||||
| #endif | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2018 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #ifndef specialize_h | ||||
| #define specialize_h 1 | ||||
|  | ||||
| #include "primitiveTypes.h" | ||||
| #include "softfloat.h" | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Default value for 'softfloat_detectTininess'. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define init_detectTininess softfloat_tininess_afterRounding | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The values to return on conversions to 32-bit integer formats that raise an | ||||
| | invalid exception. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define ui32_fromPosOverflow 0xFFFFFFFF | ||||
| #define ui32_fromNegOverflow 0xFFFFFFFF | ||||
| #define ui32_fromNaN 0xFFFFFFFF | ||||
| #define i32_fromPosOverflow (-0x7FFFFFFF - 1) | ||||
| #define i32_fromNegOverflow (-0x7FFFFFFF - 1) | ||||
| #define i32_fromNaN (-0x7FFFFFFF - 1) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The values to return on conversions to 64-bit integer formats that raise an | ||||
| | invalid exception. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define ui64_fromPosOverflow UINT64_C(0xFFFFFFFFFFFFFFFF) | ||||
| #define ui64_fromNegOverflow UINT64_C(0xFFFFFFFFFFFFFFFF) | ||||
| #define ui64_fromNaN UINT64_C(0xFFFFFFFFFFFFFFFF) | ||||
| #define i64_fromPosOverflow (-INT64_C(0x7FFFFFFFFFFFFFFF) - 1) | ||||
| #define i64_fromNegOverflow (-INT64_C(0x7FFFFFFFFFFFFFFF) - 1) | ||||
| #define i64_fromNaN (-INT64_C(0x7FFFFFFFFFFFFFFF) - 1) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | "Common NaN" structure, used to transfer NaN representations from one format | ||||
| | to another. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct commonNaN { | ||||
|     bool sign; | ||||
| #ifdef LITTLEENDIAN | ||||
|     uint64_t v0, v64; | ||||
| #else | ||||
|     uint64_t v64, v0; | ||||
| #endif | ||||
| }; | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 16-bit floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNF16UI 0xFE00 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Returns true when 16-bit unsigned integer 'uiA' has the bit pattern of a | ||||
| | 16-bit floating-point signaling NaN. | ||||
| | Note:  This macro evaluates its argument more than once. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define softfloat_isSigNaNF16UI(uiA) ((((uiA)&0x7E00) == 0x7C00) && ((uiA)&0x01FF)) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming 'uiA' has the bit pattern of a 16-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by 'zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f16UIToCommonNaN(uint_fast16_t uiA, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 16-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast16_t softfloat_commonNaNToF16UI(const struct commonNaN* aPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting 'uiA' and 'uiB' as the bit patterns of two 16-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either 'uiA' or 'uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast16_t softfloat_propagateNaNF16UI(uint_fast16_t uiA, uint_fast16_t uiB); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Returns true when 16-bit unsigned integer 'uiA' has the bit pattern of a | ||||
| | 16-bit brain floating-point (BF16) signaling NaN. | ||||
| | Note:  This macro evaluates its argument more than once. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define softfloat_isSigNaNBF16UI(uiA) ((((uiA)&0x7FC0) == 0x7F80) && ((uiA)&0x003F)) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming 'uiA' has the bit pattern of a 16-bit BF16 floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by 'zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_bf16UIToCommonNaN(uint_fast16_t uiA, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 16-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast16_t softfloat_commonNaNToBF16UI(const struct commonNaN* aPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 32-bit floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNF32UI 0xFFC00000 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Returns true when 32-bit unsigned integer 'uiA' has the bit pattern of a | ||||
| | 32-bit floating-point signaling NaN. | ||||
| | Note:  This macro evaluates its argument more than once. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define softfloat_isSigNaNF32UI(uiA) ((((uiA)&0x7FC00000) == 0x7F800000) && ((uiA)&0x003FFFFF)) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming 'uiA' has the bit pattern of a 32-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by 'zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f32UIToCommonNaN(uint_fast32_t uiA, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 32-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast32_t softfloat_commonNaNToF32UI(const struct commonNaN* aPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting 'uiA' and 'uiB' as the bit patterns of two 32-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either 'uiA' or 'uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast32_t softfloat_propagateNaNF32UI(uint_fast32_t uiA, uint_fast32_t uiB); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 64-bit floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNF64UI UINT64_C(0xFFF8000000000000) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Returns true when 64-bit unsigned integer 'uiA' has the bit pattern of a | ||||
| | 64-bit floating-point signaling NaN. | ||||
| | Note:  This macro evaluates its argument more than once. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define softfloat_isSigNaNF64UI(uiA)                                                                                                       \ | ||||
|     ((((uiA)&UINT64_C(0x7FF8000000000000)) == UINT64_C(0x7FF0000000000000)) && ((uiA)&UINT64_C(0x0007FFFFFFFFFFFF))) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming 'uiA' has the bit pattern of a 64-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by 'zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f64UIToCommonNaN(uint_fast64_t uiA, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 64-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast64_t softfloat_commonNaNToF64UI(const struct commonNaN* aPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting 'uiA' and 'uiB' as the bit patterns of two 64-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either 'uiA' or 'uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast64_t softfloat_propagateNaNF64UI(uint_fast64_t uiA, uint_fast64_t uiB); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 80-bit extended floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNExtF80UI64 0xFFFF | ||||
| #define defaultNaNExtF80UI0 UINT64_C(0xC000000000000000) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Returns true when the 80-bit unsigned integer formed from concatenating | ||||
| | 16-bit 'uiA64' and 64-bit 'uiA0' has the bit pattern of an 80-bit extended | ||||
| | floating-point signaling NaN. | ||||
| | Note:  This macro evaluates its arguments more than once. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define softfloat_isSigNaNExtF80UI(uiA64, uiA0)                                                                                            \ | ||||
|     ((((uiA64)&0x7FFF) == 0x7FFF) && !((uiA0)&UINT64_C(0x4000000000000000)) && ((uiA0)&UINT64_C(0x3FFFFFFFFFFFFFFF))) | ||||
|  | ||||
| #ifdef SOFTFLOAT_FAST_INT64 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The following functions are needed only when 'SOFTFLOAT_FAST_INT64' is | ||||
| | defined. | ||||
| *----------------------------------------------------------------------------*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the unsigned integer formed from concatenating 'uiA64' and 'uiA0' | ||||
| | has the bit pattern of an 80-bit extended floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by 'zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_extF80UIToCommonNaN(uint_fast16_t uiA64, uint_fast64_t uiA0, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into an 80-bit extended | ||||
| | floating-point NaN, and returns the bit pattern of this value as an unsigned | ||||
| | integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_commonNaNToExtF80UI(const struct commonNaN* aPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting the unsigned integer formed from concatenating 'uiA64' and | ||||
| | 'uiA0' as an 80-bit extended floating-point value, and likewise interpreting | ||||
| | the unsigned integer formed from concatenating 'uiB64' and 'uiB0' as another | ||||
| | 80-bit extended floating-point value, and assuming at least on of these | ||||
| | floating-point values is a NaN, returns the bit pattern of the combined NaN | ||||
| | result.  If either original floating-point value is a signaling NaN, the | ||||
| | invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_propagateNaNExtF80UI(uint_fast16_t uiA64, uint_fast64_t uiA0, uint_fast16_t uiB64, uint_fast64_t uiB0); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 128-bit floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNF128UI64 UINT64_C(0xFFFF800000000000) | ||||
| #define defaultNaNF128UI0 UINT64_C(0) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Returns true when the 128-bit unsigned integer formed from concatenating | ||||
| | 64-bit 'uiA64' and 64-bit 'uiA0' has the bit pattern of a 128-bit floating- | ||||
| | point signaling NaN. | ||||
| | Note:  This macro evaluates its arguments more than once. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define softfloat_isSigNaNF128UI(uiA64, uiA0)                                                                                              \ | ||||
|     ((((uiA64)&UINT64_C(0x7FFF800000000000)) == UINT64_C(0x7FFF000000000000)) && ((uiA0) || ((uiA64)&UINT64_C(0x00007FFFFFFFFFFF)))) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the unsigned integer formed from concatenating 'uiA64' and 'uiA0' | ||||
| | has the bit pattern of a 128-bit floating-point NaN, converts this NaN to | ||||
| | the common NaN form, and stores the resulting common NaN at the location | ||||
| | pointed to by 'zPtr'.  If the NaN is a signaling NaN, the invalid exception | ||||
| | is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f128UIToCommonNaN(uint_fast64_t uiA64, uint_fast64_t uiA0, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 128-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_commonNaNToF128UI(const struct commonNaN*); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting the unsigned integer formed from concatenating 'uiA64' and | ||||
| | 'uiA0' as a 128-bit floating-point value, and likewise interpreting the | ||||
| | unsigned integer formed from concatenating 'uiB64' and 'uiB0' as another | ||||
| | 128-bit floating-point value, and assuming at least on of these floating- | ||||
| | point values is a NaN, returns the bit pattern of the combined NaN result. | ||||
| | If either original floating-point value is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_propagateNaNF128UI(uint_fast64_t uiA64, uint_fast64_t uiA0, uint_fast64_t uiB64, uint_fast64_t uiB0); | ||||
|  | ||||
| #else | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The following functions are needed only when 'SOFTFLOAT_FAST_INT64' is not | ||||
| | defined. | ||||
| *----------------------------------------------------------------------------*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the 80-bit extended floating-point value pointed to by 'aSPtr' is | ||||
| | a NaN, converts this NaN to the common NaN form, and stores the resulting | ||||
| | common NaN at the location pointed to by 'zPtr'.  If the NaN is a signaling | ||||
| | NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_extF80MToCommonNaN(const struct extFloat80M* aSPtr, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into an 80-bit extended | ||||
| | floating-point NaN, and stores this NaN at the location pointed to by | ||||
| | 'zSPtr'. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_commonNaNToExtF80M(const struct commonNaN* aPtr, struct extFloat80M* zSPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming at least one of the two 80-bit extended floating-point values | ||||
| | pointed to by 'aSPtr' and 'bSPtr' is a NaN, stores the combined NaN result | ||||
| | at the location pointed to by 'zSPtr'.  If either original floating-point | ||||
| | value is a signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_propagateNaNExtF80M(const struct extFloat80M* aSPtr, const struct extFloat80M* bSPtr, struct extFloat80M* zSPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 128-bit floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNF128UI96 0xFFFF8000 | ||||
| #define defaultNaNF128UI64 0 | ||||
| #define defaultNaNF128UI32 0 | ||||
| #define defaultNaNF128UI0 0 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the 128-bit floating-point value pointed to by 'aWPtr' is a NaN, | ||||
| | converts this NaN to the common NaN form, and stores the resulting common | ||||
| | NaN at the location pointed to by 'zPtr'.  If the NaN is a signaling NaN, | ||||
| | the invalid exception is raised.  Argument 'aWPtr' points to an array of | ||||
| | four 32-bit elements that concatenate in the platform's normal endian order | ||||
| | to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f128MToCommonNaN(const uint32_t* aWPtr, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 128-bit floating-point | ||||
| | NaN, and stores this NaN at the location pointed to by 'zWPtr'.  Argument | ||||
| | 'zWPtr' points to an array of four 32-bit elements that concatenate in the | ||||
| | platform's normal endian order to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_commonNaNToF128M(const struct commonNaN* aPtr, uint32_t* zWPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming at least one of the two 128-bit floating-point values pointed to by | ||||
| | 'aWPtr' and 'bWPtr' is a NaN, stores the combined NaN result at the location | ||||
| | pointed to by 'zWPtr'.  If either original floating-point value is a | ||||
| | signaling NaN, the invalid exception is raised.  Each of 'aWPtr', 'bWPtr', | ||||
| | and 'zWPtr' points to an array of four 32-bit elements that concatenate in | ||||
| | the platform's normal endian order to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_propagateNaNF128M(const uint32_t* aWPtr, const uint32_t* bWPtr, uint32_t* zWPtr); | ||||
|  | ||||
| #endif | ||||
|  | ||||
| #endif | ||||
|   | ||||
| @@ -1,57 +1,57 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| bool extF80M_isSignalingNaN( const extFloat80_t *aPtr ) | ||||
| { | ||||
|     const struct extFloat80M *aSPtr; | ||||
|     uint64_t uiA0; | ||||
|  | ||||
|     aSPtr = (const struct extFloat80M *) aPtr; | ||||
|     if ( (aSPtr->signExp & 0x7FFF) != 0x7FFF ) return false; | ||||
|     uiA0 = aSPtr->signif; | ||||
|     return | ||||
|         ! (uiA0 & UINT64_C( 0x4000000000000000 )) | ||||
|             && (uiA0 & UINT64_C( 0x3FFFFFFFFFFFFFFF)); | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| bool extF80M_isSignalingNaN( const extFloat80_t *aPtr ) | ||||
| { | ||||
|     const struct extFloat80M *aSPtr; | ||||
|     uint64_t uiA0; | ||||
|  | ||||
|     aSPtr = (const struct extFloat80M *) aPtr; | ||||
|     if ( (aSPtr->signExp & 0x7FFF) != 0x7FFF ) return false; | ||||
|     uiA0 = aSPtr->signif; | ||||
|     return | ||||
|         ! (uiA0 & UINT64_C( 0x4000000000000000 )) | ||||
|             && (uiA0 & UINT64_C( 0x3FFFFFFFFFFFFFFF)); | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,60 +1,60 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| bool f128M_isSignalingNaN( const float128_t *aPtr ) | ||||
| { | ||||
|     const uint32_t *aWPtr; | ||||
|     uint32_t uiA96; | ||||
|  | ||||
|     aWPtr = (const uint32_t *) aPtr; | ||||
|     uiA96 = aWPtr[indexWordHi( 4 )]; | ||||
|     if ( (uiA96 & 0x7FFF8000) != 0x7FFF0000 ) return false; | ||||
|     return | ||||
|         ((uiA96 & 0x00007FFF) != 0) | ||||
|             || ((aWPtr[indexWord( 4, 2 )] | aWPtr[indexWord( 4, 1 )] | ||||
|                      | aWPtr[indexWord( 4, 0 )]) | ||||
|                     != 0); | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| bool f128M_isSignalingNaN( const float128_t *aPtr ) | ||||
| { | ||||
|     const uint32_t *aWPtr; | ||||
|     uint32_t uiA96; | ||||
|  | ||||
|     aWPtr = (const uint32_t *) aPtr; | ||||
|     uiA96 = aWPtr[indexWordHi( 4 )]; | ||||
|     if ( (uiA96 & 0x7FFF8000) != 0x7FFF0000 ) return false; | ||||
|     return | ||||
|         ((uiA96 & 0x00007FFF) != 0) | ||||
|             || ((aWPtr[indexWord( 4, 2 )] | aWPtr[indexWord( 4, 1 )] | ||||
|                      | aWPtr[indexWord( 4, 0 )]) | ||||
|                     != 0); | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,56 +1,56 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into an 80-bit extended | ||||
| | floating-point NaN, and stores this NaN at the location pointed to by | ||||
| | `zSPtr'. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_commonNaNToExtF80M( | ||||
|      const struct commonNaN *aPtr, struct extFloat80M *zSPtr ) | ||||
| { | ||||
|  | ||||
|     zSPtr->signExp = packToExtF80UI64( aPtr->sign, 0x7FFF ); | ||||
|     zSPtr->signif = UINT64_C( 0xC000000000000000 ) | aPtr->v64>>1; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into an 80-bit extended | ||||
| | floating-point NaN, and stores this NaN at the location pointed to by | ||||
| | `zSPtr'. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_commonNaNToExtF80M( | ||||
|      const struct commonNaN *aPtr, struct extFloat80M *zSPtr ) | ||||
| { | ||||
|  | ||||
|     zSPtr->signExp = packToExtF80UI64( aPtr->sign, 0x7FFF ); | ||||
|     zSPtr->signif = UINT64_C( 0xC000000000000000 ) | aPtr->v64>>1; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,56 +1,56 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into an 80-bit extended | ||||
| | floating-point NaN, and returns the bit pattern of this value as an unsigned | ||||
| | integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_commonNaNToExtF80UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|     struct uint128 uiZ; | ||||
|  | ||||
|     uiZ.v64 = (uint_fast16_t) aPtr->sign<<15 | 0x7FFF; | ||||
|     uiZ.v0 = UINT64_C( 0xC000000000000000 ) | aPtr->v64>>1; | ||||
|     return uiZ; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into an 80-bit extended | ||||
| | floating-point NaN, and returns the bit pattern of this value as an unsigned | ||||
| | integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_commonNaNToExtF80UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|     struct uint128 uiZ; | ||||
|  | ||||
|     uiZ.v64 = (uint_fast16_t) aPtr->sign<<15 | 0x7FFF; | ||||
|     uiZ.v0 = UINT64_C( 0xC000000000000000 ) | aPtr->v64>>1; | ||||
|     return uiZ; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,56 +1,56 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into a 128-bit floating-point | ||||
| | NaN, and stores this NaN at the location pointed to by `zWPtr'.  Argument | ||||
| | `zWPtr' points to an array of four 32-bit elements that concatenate in the | ||||
| | platform's normal endian order to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_commonNaNToF128M( const struct commonNaN *aPtr, uint32_t *zWPtr ) | ||||
| { | ||||
|  | ||||
|     softfloat_shortShiftRight128M( (const uint32_t *) &aPtr->v0, 16, zWPtr ); | ||||
|     zWPtr[indexWordHi( 4 )] |= (uint32_t) aPtr->sign<<31 | 0x7FFF8000; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into a 128-bit floating-point | ||||
| | NaN, and stores this NaN at the location pointed to by `zWPtr'.  Argument | ||||
| | `zWPtr' points to an array of four 32-bit elements that concatenate in the | ||||
| | platform's normal endian order to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_commonNaNToF128M( const struct commonNaN *aPtr, uint32_t *zWPtr ) | ||||
| { | ||||
|  | ||||
|     softfloat_shortShiftRight128M( (const uint32_t *) &aPtr->v0, 16, zWPtr ); | ||||
|     zWPtr[indexWordHi( 4 )] |= (uint32_t) aPtr->sign<<31 | 0x7FFF8000; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,55 +1,55 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into a 128-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_commonNaNToF128UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|     struct uint128 uiZ; | ||||
|  | ||||
|     uiZ = softfloat_shortShiftRight128( aPtr->v64, aPtr->v0, 16 ); | ||||
|     uiZ.v64 |= (uint_fast64_t) aPtr->sign<<63 | UINT64_C( 0x7FFF800000000000 ); | ||||
|     return uiZ; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into a 128-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_commonNaNToF128UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|     struct uint128 uiZ; | ||||
|  | ||||
|     uiZ = softfloat_shortShiftRight128( aPtr->v64, aPtr->v0, 16 ); | ||||
|     uiZ.v64 |= (uint_fast64_t) aPtr->sign<<63 | UINT64_C( 0x7FFF800000000000 ); | ||||
|     return uiZ; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,51 +1,51 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into a 16-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast16_t softfloat_commonNaNToF16UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|  | ||||
|     return (uint_fast16_t) aPtr->sign<<15 | 0x7E00 | aPtr->v64>>54; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into a 16-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast16_t softfloat_commonNaNToF16UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|  | ||||
|     return (uint_fast16_t) aPtr->sign<<15 | 0x7E00 | aPtr->v64>>54; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,51 +1,51 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into a 32-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast32_t softfloat_commonNaNToF32UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|  | ||||
|     return (uint_fast32_t) aPtr->sign<<31 | 0x7FC00000 | aPtr->v64>>41; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into a 32-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast32_t softfloat_commonNaNToF32UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|  | ||||
|     return (uint_fast32_t) aPtr->sign<<31 | 0x7FC00000 | aPtr->v64>>41; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,53 +1,53 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into a 64-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast64_t softfloat_commonNaNToF64UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|  | ||||
|     return | ||||
|         (uint_fast64_t) aPtr->sign<<63 | UINT64_C( 0x7FF8000000000000 ) | ||||
|             | aPtr->v64>>12; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by `aPtr' into a 64-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast64_t softfloat_commonNaNToF64UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|  | ||||
|     return | ||||
|         (uint_fast64_t) aPtr->sign<<63 | UINT64_C( 0x7FF8000000000000 ) | ||||
|             | aPtr->v64>>12; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,62 +1,62 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the 80-bit extended floating-point value pointed to by `aSPtr' is | ||||
| | a NaN, converts this NaN to the common NaN form, and stores the resulting | ||||
| | common NaN at the location pointed to by `zPtr'.  If the NaN is a signaling | ||||
| | NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_extF80MToCommonNaN( | ||||
|      const struct extFloat80M *aSPtr, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( extF80M_isSignalingNaN( (const extFloat80_t *) aSPtr ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = signExtF80UI64( aSPtr->signExp ); | ||||
|     zPtr->v64 = aSPtr->signif<<1; | ||||
|     zPtr->v0  = 0; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the 80-bit extended floating-point value pointed to by `aSPtr' is | ||||
| | a NaN, converts this NaN to the common NaN form, and stores the resulting | ||||
| | common NaN at the location pointed to by `zPtr'.  If the NaN is a signaling | ||||
| | NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_extF80MToCommonNaN( | ||||
|      const struct extFloat80M *aSPtr, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( extF80M_isSignalingNaN( (const extFloat80_t *) aSPtr ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = signExtF80UI64( aSPtr->signExp ); | ||||
|     zPtr->v64 = aSPtr->signif<<1; | ||||
|     zPtr->v0  = 0; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,62 +1,62 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the unsigned integer formed from concatenating `uiA64' and `uiA0' | ||||
| | has the bit pattern of an 80-bit extended floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by `zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_extF80UIToCommonNaN( | ||||
|      uint_fast16_t uiA64, uint_fast64_t uiA0, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( softfloat_isSigNaNExtF80UI( uiA64, uiA0 ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = uiA64>>15; | ||||
|     zPtr->v64  = uiA0<<1; | ||||
|     zPtr->v0   = 0; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the unsigned integer formed from concatenating `uiA64' and `uiA0' | ||||
| | has the bit pattern of an 80-bit extended floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by `zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_extF80UIToCommonNaN( | ||||
|      uint_fast16_t uiA64, uint_fast64_t uiA0, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( softfloat_isSigNaNExtF80UI( uiA64, uiA0 ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = uiA64>>15; | ||||
|     zPtr->v64  = uiA0<<1; | ||||
|     zPtr->v0   = 0; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,62 +1,62 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the 128-bit floating-point value pointed to by `aWPtr' is a NaN, | ||||
| | converts this NaN to the common NaN form, and stores the resulting common | ||||
| | NaN at the location pointed to by `zPtr'.  If the NaN is a signaling NaN, | ||||
| | the invalid exception is raised.  Argument `aWPtr' points to an array of | ||||
| | four 32-bit elements that concatenate in the platform's normal endian order | ||||
| | to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_f128MToCommonNaN( const uint32_t *aWPtr, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( f128M_isSignalingNaN( (const float128_t *) aWPtr ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = aWPtr[indexWordHi( 4 )]>>31; | ||||
|     softfloat_shortShiftLeft128M( aWPtr, 16, (uint32_t *) &zPtr->v0 ); | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the 128-bit floating-point value pointed to by `aWPtr' is a NaN, | ||||
| | converts this NaN to the common NaN form, and stores the resulting common | ||||
| | NaN at the location pointed to by `zPtr'.  If the NaN is a signaling NaN, | ||||
| | the invalid exception is raised.  Argument `aWPtr' points to an array of | ||||
| | four 32-bit elements that concatenate in the platform's normal endian order | ||||
| | to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_f128MToCommonNaN( const uint32_t *aWPtr, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( f128M_isSignalingNaN( (const float128_t *) aWPtr ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = aWPtr[indexWordHi( 4 )]>>31; | ||||
|     softfloat_shortShiftLeft128M( aWPtr, 16, (uint32_t *) &zPtr->v0 ); | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,65 +1,65 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the unsigned integer formed from concatenating `uiA64' and `uiA0' | ||||
| | has the bit pattern of a 128-bit floating-point NaN, converts this NaN to | ||||
| | the common NaN form, and stores the resulting common NaN at the location | ||||
| | pointed to by `zPtr'.  If the NaN is a signaling NaN, the invalid exception | ||||
| | is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_f128UIToCommonNaN( | ||||
|      uint_fast64_t uiA64, uint_fast64_t uiA0, struct commonNaN *zPtr ) | ||||
| { | ||||
|     struct uint128 NaNSig; | ||||
|  | ||||
|     if ( softfloat_isSigNaNF128UI( uiA64, uiA0 ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     NaNSig = softfloat_shortShiftLeft128( uiA64, uiA0, 16 ); | ||||
|     zPtr->sign = uiA64>>63; | ||||
|     zPtr->v64  = NaNSig.v64; | ||||
|     zPtr->v0   = NaNSig.v0; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the unsigned integer formed from concatenating `uiA64' and `uiA0' | ||||
| | has the bit pattern of a 128-bit floating-point NaN, converts this NaN to | ||||
| | the common NaN form, and stores the resulting common NaN at the location | ||||
| | pointed to by `zPtr'.  If the NaN is a signaling NaN, the invalid exception | ||||
| | is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_f128UIToCommonNaN( | ||||
|      uint_fast64_t uiA64, uint_fast64_t uiA0, struct commonNaN *zPtr ) | ||||
| { | ||||
|     struct uint128 NaNSig; | ||||
|  | ||||
|     if ( softfloat_isSigNaNF128UI( uiA64, uiA0 ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     NaNSig = softfloat_shortShiftLeft128( uiA64, uiA0, 16 ); | ||||
|     zPtr->sign = uiA64>>63; | ||||
|     zPtr->v64  = NaNSig.v64; | ||||
|     zPtr->v0   = NaNSig.v0; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,59 +1,59 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming `uiA' has the bit pattern of a 16-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by `zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f16UIToCommonNaN( uint_fast16_t uiA, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( softfloat_isSigNaNF16UI( uiA ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = uiA>>15; | ||||
|     zPtr->v64  = (uint_fast64_t) uiA<<54; | ||||
|     zPtr->v0   = 0; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming `uiA' has the bit pattern of a 16-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by `zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f16UIToCommonNaN( uint_fast16_t uiA, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( softfloat_isSigNaNF16UI( uiA ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = uiA>>15; | ||||
|     zPtr->v64  = (uint_fast64_t) uiA<<54; | ||||
|     zPtr->v0   = 0; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,59 +1,59 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming `uiA' has the bit pattern of a 32-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by `zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f32UIToCommonNaN( uint_fast32_t uiA, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( softfloat_isSigNaNF32UI( uiA ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = uiA>>31; | ||||
|     zPtr->v64  = (uint_fast64_t) uiA<<41; | ||||
|     zPtr->v0   = 0; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming `uiA' has the bit pattern of a 32-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by `zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f32UIToCommonNaN( uint_fast32_t uiA, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( softfloat_isSigNaNF32UI( uiA ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = uiA>>31; | ||||
|     zPtr->v64  = (uint_fast64_t) uiA<<41; | ||||
|     zPtr->v0   = 0; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,59 +1,59 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming `uiA' has the bit pattern of a 64-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by `zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f64UIToCommonNaN( uint_fast64_t uiA, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( softfloat_isSigNaNF64UI( uiA ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = uiA>>63; | ||||
|     zPtr->v64  = uiA<<12; | ||||
|     zPtr->v0   = 0; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming `uiA' has the bit pattern of a 64-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by `zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f64UIToCommonNaN( uint_fast64_t uiA, struct commonNaN *zPtr ) | ||||
| { | ||||
|  | ||||
|     if ( softfloat_isSigNaNF64UI( uiA ) ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|     } | ||||
|     zPtr->sign = uiA>>63; | ||||
|     zPtr->v64  = uiA<<12; | ||||
|     zPtr->v0   = 0; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,107 +1,107 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming at least one of the two 80-bit extended floating-point values | ||||
| | pointed to by `aSPtr' and `bSPtr' is a NaN, stores the combined NaN result | ||||
| | at the location pointed to by `zSPtr'.  If either original floating-point | ||||
| | value is a signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_propagateNaNExtF80M( | ||||
|      const struct extFloat80M *aSPtr, | ||||
|      const struct extFloat80M *bSPtr, | ||||
|      struct extFloat80M *zSPtr | ||||
|  ) | ||||
| { | ||||
|     bool isSigNaNA; | ||||
|     const struct extFloat80M *sPtr; | ||||
|     bool isSigNaNB; | ||||
|     uint_fast16_t uiB64; | ||||
|     uint64_t uiB0; | ||||
|     uint_fast16_t uiA64; | ||||
|     uint64_t uiA0; | ||||
|     uint_fast16_t uiMagA64, uiMagB64; | ||||
|  | ||||
|     isSigNaNA = extF80M_isSignalingNaN( (const extFloat80_t *) aSPtr ); | ||||
|     sPtr = aSPtr; | ||||
|     if ( ! bSPtr ) { | ||||
|         if ( isSigNaNA ) softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         goto copy; | ||||
|     } | ||||
|     isSigNaNB = extF80M_isSignalingNaN( (const extFloat80_t *) bSPtr ); | ||||
|     if ( isSigNaNA | isSigNaNB ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) { | ||||
|             uiB64 = bSPtr->signExp; | ||||
|             if ( isSigNaNB ) goto returnLargerUIMag; | ||||
|             uiB0 = bSPtr->signif; | ||||
|             if ( isNaNExtF80UI( uiB64, uiB0 ) ) goto copyB; | ||||
|             goto copy; | ||||
|         } else { | ||||
|             uiA64 = aSPtr->signExp; | ||||
|             uiA0 = aSPtr->signif; | ||||
|             if ( isNaNExtF80UI( uiA64, uiA0 ) ) goto copy; | ||||
|             goto copyB; | ||||
|         } | ||||
|     } | ||||
|     uiB64 = bSPtr->signExp; | ||||
|  returnLargerUIMag: | ||||
|     uiA64 = aSPtr->signExp; | ||||
|     uiMagA64 = uiA64 & 0x7FFF; | ||||
|     uiMagB64 = uiB64 & 0x7FFF; | ||||
|     if ( uiMagA64 < uiMagB64 ) goto copyB; | ||||
|     if ( uiMagB64 < uiMagA64 ) goto copy; | ||||
|     uiA0 = aSPtr->signif; | ||||
|     uiB0 = bSPtr->signif; | ||||
|     if ( uiA0 < uiB0 ) goto copyB; | ||||
|     if ( uiB0 < uiA0 ) goto copy; | ||||
|     if ( uiA64 < uiB64 ) goto copy; | ||||
|  copyB: | ||||
|     sPtr = bSPtr; | ||||
|  copy: | ||||
|     zSPtr->signExp = sPtr->signExp; | ||||
|     zSPtr->signif = sPtr->signif | UINT64_C( 0xC000000000000000 ); | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming at least one of the two 80-bit extended floating-point values | ||||
| | pointed to by `aSPtr' and `bSPtr' is a NaN, stores the combined NaN result | ||||
| | at the location pointed to by `zSPtr'.  If either original floating-point | ||||
| | value is a signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_propagateNaNExtF80M( | ||||
|      const struct extFloat80M *aSPtr, | ||||
|      const struct extFloat80M *bSPtr, | ||||
|      struct extFloat80M *zSPtr | ||||
|  ) | ||||
| { | ||||
|     bool isSigNaNA; | ||||
|     const struct extFloat80M *sPtr; | ||||
|     bool isSigNaNB; | ||||
|     uint_fast16_t uiB64; | ||||
|     uint64_t uiB0; | ||||
|     uint_fast16_t uiA64; | ||||
|     uint64_t uiA0; | ||||
|     uint_fast16_t uiMagA64, uiMagB64; | ||||
|  | ||||
|     isSigNaNA = extF80M_isSignalingNaN( (const extFloat80_t *) aSPtr ); | ||||
|     sPtr = aSPtr; | ||||
|     if ( ! bSPtr ) { | ||||
|         if ( isSigNaNA ) softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         goto copy; | ||||
|     } | ||||
|     isSigNaNB = extF80M_isSignalingNaN( (const extFloat80_t *) bSPtr ); | ||||
|     if ( isSigNaNA | isSigNaNB ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) { | ||||
|             uiB64 = bSPtr->signExp; | ||||
|             if ( isSigNaNB ) goto returnLargerUIMag; | ||||
|             uiB0 = bSPtr->signif; | ||||
|             if ( isNaNExtF80UI( uiB64, uiB0 ) ) goto copyB; | ||||
|             goto copy; | ||||
|         } else { | ||||
|             uiA64 = aSPtr->signExp; | ||||
|             uiA0 = aSPtr->signif; | ||||
|             if ( isNaNExtF80UI( uiA64, uiA0 ) ) goto copy; | ||||
|             goto copyB; | ||||
|         } | ||||
|     } | ||||
|     uiB64 = bSPtr->signExp; | ||||
|  returnLargerUIMag: | ||||
|     uiA64 = aSPtr->signExp; | ||||
|     uiMagA64 = uiA64 & 0x7FFF; | ||||
|     uiMagB64 = uiB64 & 0x7FFF; | ||||
|     if ( uiMagA64 < uiMagB64 ) goto copyB; | ||||
|     if ( uiMagB64 < uiMagA64 ) goto copy; | ||||
|     uiA0 = aSPtr->signif; | ||||
|     uiB0 = bSPtr->signif; | ||||
|     if ( uiA0 < uiB0 ) goto copyB; | ||||
|     if ( uiB0 < uiA0 ) goto copy; | ||||
|     if ( uiA64 < uiB64 ) goto copy; | ||||
|  copyB: | ||||
|     sPtr = bSPtr; | ||||
|  copy: | ||||
|     zSPtr->signExp = sPtr->signExp; | ||||
|     zSPtr->signif = sPtr->signif | UINT64_C( 0xC000000000000000 ); | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,106 +1,106 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2018 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting the unsigned integer formed from concatenating 'uiA64' and | ||||
| | 'uiA0' as an 80-bit extended floating-point value, and likewise interpreting | ||||
| | the unsigned integer formed from concatenating 'uiB64' and 'uiB0' as another | ||||
| | 80-bit extended floating-point value, and assuming at least on of these | ||||
| | floating-point values is a NaN, returns the bit pattern of the combined NaN | ||||
| | result.  If either original floating-point value is a signaling NaN, the | ||||
| | invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 | ||||
|  softfloat_propagateNaNExtF80UI( | ||||
|      uint_fast16_t uiA64, | ||||
|      uint_fast64_t uiA0, | ||||
|      uint_fast16_t uiB64, | ||||
|      uint_fast64_t uiB0 | ||||
|  ) | ||||
| { | ||||
|     bool isSigNaNA, isSigNaNB; | ||||
|     uint_fast64_t uiNonsigA0, uiNonsigB0; | ||||
|     uint_fast16_t uiMagA64, uiMagB64; | ||||
|     struct uint128 uiZ; | ||||
|  | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     isSigNaNA = softfloat_isSigNaNExtF80UI( uiA64, uiA0 ); | ||||
|     isSigNaNB = softfloat_isSigNaNExtF80UI( uiB64, uiB0 ); | ||||
|     /*------------------------------------------------------------------------ | ||||
|     | Make NaNs non-signaling. | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     uiNonsigA0 = uiA0 | UINT64_C( 0xC000000000000000 ); | ||||
|     uiNonsigB0 = uiB0 | UINT64_C( 0xC000000000000000 ); | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     if ( isSigNaNA | isSigNaNB ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) { | ||||
|             if ( isSigNaNB ) goto returnLargerMag; | ||||
|             if ( isNaNExtF80UI( uiB64, uiB0 ) ) goto returnB; | ||||
|             goto returnA; | ||||
|         } else { | ||||
|             if ( isNaNExtF80UI( uiA64, uiA0 ) ) goto returnA; | ||||
|             goto returnB; | ||||
|         } | ||||
|     } | ||||
|  returnLargerMag: | ||||
|     uiMagA64 = uiA64 & 0x7FFF; | ||||
|     uiMagB64 = uiB64 & 0x7FFF; | ||||
|     if ( uiMagA64 < uiMagB64 ) goto returnB; | ||||
|     if ( uiMagB64 < uiMagA64 ) goto returnA; | ||||
|     if ( uiA0 < uiB0 ) goto returnB; | ||||
|     if ( uiB0 < uiA0 ) goto returnA; | ||||
|     if ( uiA64 < uiB64 ) goto returnA; | ||||
|  returnB: | ||||
|     uiZ.v64 = uiB64; | ||||
|     uiZ.v0  = uiNonsigB0; | ||||
|     return uiZ; | ||||
|  returnA: | ||||
|     uiZ.v64 = uiA64; | ||||
|     uiZ.v0  = uiNonsigA0; | ||||
|     return uiZ; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2018 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting the unsigned integer formed from concatenating 'uiA64' and | ||||
| | 'uiA0' as an 80-bit extended floating-point value, and likewise interpreting | ||||
| | the unsigned integer formed from concatenating 'uiB64' and 'uiB0' as another | ||||
| | 80-bit extended floating-point value, and assuming at least on of these | ||||
| | floating-point values is a NaN, returns the bit pattern of the combined NaN | ||||
| | result.  If either original floating-point value is a signaling NaN, the | ||||
| | invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 | ||||
|  softfloat_propagateNaNExtF80UI( | ||||
|      uint_fast16_t uiA64, | ||||
|      uint_fast64_t uiA0, | ||||
|      uint_fast16_t uiB64, | ||||
|      uint_fast64_t uiB0 | ||||
|  ) | ||||
| { | ||||
|     bool isSigNaNA, isSigNaNB; | ||||
|     uint_fast64_t uiNonsigA0, uiNonsigB0; | ||||
|     uint_fast16_t uiMagA64, uiMagB64; | ||||
|     struct uint128 uiZ; | ||||
|  | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     isSigNaNA = softfloat_isSigNaNExtF80UI( uiA64, uiA0 ); | ||||
|     isSigNaNB = softfloat_isSigNaNExtF80UI( uiB64, uiB0 ); | ||||
|     /*------------------------------------------------------------------------ | ||||
|     | Make NaNs non-signaling. | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     uiNonsigA0 = uiA0 | UINT64_C( 0xC000000000000000 ); | ||||
|     uiNonsigB0 = uiB0 | UINT64_C( 0xC000000000000000 ); | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     if ( isSigNaNA | isSigNaNB ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) { | ||||
|             if ( isSigNaNB ) goto returnLargerMag; | ||||
|             if ( isNaNExtF80UI( uiB64, uiB0 ) ) goto returnB; | ||||
|             goto returnA; | ||||
|         } else { | ||||
|             if ( isNaNExtF80UI( uiA64, uiA0 ) ) goto returnA; | ||||
|             goto returnB; | ||||
|         } | ||||
|     } | ||||
|  returnLargerMag: | ||||
|     uiMagA64 = uiA64 & 0x7FFF; | ||||
|     uiMagB64 = uiB64 & 0x7FFF; | ||||
|     if ( uiMagA64 < uiMagB64 ) goto returnB; | ||||
|     if ( uiMagB64 < uiMagA64 ) goto returnA; | ||||
|     if ( uiA0 < uiB0 ) goto returnB; | ||||
|     if ( uiB0 < uiA0 ) goto returnA; | ||||
|     if ( uiA64 < uiB64 ) goto returnA; | ||||
|  returnB: | ||||
|     uiZ.v64 = uiB64; | ||||
|     uiZ.v0  = uiNonsigB0; | ||||
|     return uiZ; | ||||
|  returnA: | ||||
|     uiZ.v64 = uiA64; | ||||
|     uiZ.v0  = uiNonsigA0; | ||||
|     return uiZ; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,108 +1,108 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming at least one of the two 128-bit floating-point values pointed to by | ||||
| | `aWPtr' and `bWPtr' is a NaN, stores the combined NaN result at the location | ||||
| | pointed to by `zWPtr'.  If either original floating-point value is a | ||||
| | signaling NaN, the invalid exception is raised.  Each of `aWPtr', `bWPtr', | ||||
| | and `zWPtr' points to an array of four 32-bit elements that concatenate in | ||||
| | the platform's normal endian order to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_propagateNaNF128M( | ||||
|      const uint32_t *aWPtr, const uint32_t *bWPtr, uint32_t *zWPtr ) | ||||
| { | ||||
|     bool isSigNaNA; | ||||
|     const uint32_t *ptr; | ||||
|     bool isSigNaNB; | ||||
|     uint32_t uiA96, uiB96, wordMagA, wordMagB; | ||||
|  | ||||
|     isSigNaNA = f128M_isSignalingNaN( (const float128_t *) aWPtr ); | ||||
|     ptr = aWPtr; | ||||
|     if ( ! bWPtr ) { | ||||
|         if ( isSigNaNA ) softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         goto copy; | ||||
|     } | ||||
|     isSigNaNB = f128M_isSignalingNaN( (const float128_t *) bWPtr ); | ||||
|     if ( isSigNaNA | isSigNaNB ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) { | ||||
|             if ( isSigNaNB ) goto returnLargerUIMag; | ||||
|             if ( softfloat_isNaNF128M( bWPtr ) ) goto copyB; | ||||
|             goto copy; | ||||
|         } else { | ||||
|             if ( softfloat_isNaNF128M( aWPtr ) ) goto copy; | ||||
|             goto copyB; | ||||
|         } | ||||
|     } | ||||
|  returnLargerUIMag: | ||||
|     uiA96 = aWPtr[indexWordHi( 4 )]; | ||||
|     uiB96 = bWPtr[indexWordHi( 4 )]; | ||||
|     wordMagA = uiA96 & 0x7FFFFFFF; | ||||
|     wordMagB = uiB96 & 0x7FFFFFFF; | ||||
|     if ( wordMagA < wordMagB ) goto copyB; | ||||
|     if ( wordMagB < wordMagA ) goto copy; | ||||
|     wordMagA = aWPtr[indexWord( 4, 2 )]; | ||||
|     wordMagB = bWPtr[indexWord( 4, 2 )]; | ||||
|     if ( wordMagA < wordMagB ) goto copyB; | ||||
|     if ( wordMagB < wordMagA ) goto copy; | ||||
|     wordMagA = aWPtr[indexWord( 4, 1 )]; | ||||
|     wordMagB = bWPtr[indexWord( 4, 1 )]; | ||||
|     if ( wordMagA < wordMagB ) goto copyB; | ||||
|     if ( wordMagB < wordMagA ) goto copy; | ||||
|     wordMagA = aWPtr[indexWord( 4, 0 )]; | ||||
|     wordMagB = bWPtr[indexWord( 4, 0 )]; | ||||
|     if ( wordMagA < wordMagB ) goto copyB; | ||||
|     if ( wordMagB < wordMagA ) goto copy; | ||||
|     if ( uiA96 < uiB96 ) goto copy; | ||||
|  copyB: | ||||
|     ptr = bWPtr; | ||||
|  copy: | ||||
|     zWPtr[indexWordHi( 4 )] = ptr[indexWordHi( 4 )] | 0x00008000; | ||||
|     zWPtr[indexWord( 4, 2 )] = ptr[indexWord( 4, 2 )]; | ||||
|     zWPtr[indexWord( 4, 1 )] = ptr[indexWord( 4, 1 )]; | ||||
|     zWPtr[indexWord( 4, 0 )] = ptr[indexWord( 4, 0 )]; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming at least one of the two 128-bit floating-point values pointed to by | ||||
| | `aWPtr' and `bWPtr' is a NaN, stores the combined NaN result at the location | ||||
| | pointed to by `zWPtr'.  If either original floating-point value is a | ||||
| | signaling NaN, the invalid exception is raised.  Each of `aWPtr', `bWPtr', | ||||
| | and `zWPtr' points to an array of four 32-bit elements that concatenate in | ||||
| | the platform's normal endian order to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_propagateNaNF128M( | ||||
|      const uint32_t *aWPtr, const uint32_t *bWPtr, uint32_t *zWPtr ) | ||||
| { | ||||
|     bool isSigNaNA; | ||||
|     const uint32_t *ptr; | ||||
|     bool isSigNaNB; | ||||
|     uint32_t uiA96, uiB96, wordMagA, wordMagB; | ||||
|  | ||||
|     isSigNaNA = f128M_isSignalingNaN( (const float128_t *) aWPtr ); | ||||
|     ptr = aWPtr; | ||||
|     if ( ! bWPtr ) { | ||||
|         if ( isSigNaNA ) softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         goto copy; | ||||
|     } | ||||
|     isSigNaNB = f128M_isSignalingNaN( (const float128_t *) bWPtr ); | ||||
|     if ( isSigNaNA | isSigNaNB ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) { | ||||
|             if ( isSigNaNB ) goto returnLargerUIMag; | ||||
|             if ( softfloat_isNaNF128M( bWPtr ) ) goto copyB; | ||||
|             goto copy; | ||||
|         } else { | ||||
|             if ( softfloat_isNaNF128M( aWPtr ) ) goto copy; | ||||
|             goto copyB; | ||||
|         } | ||||
|     } | ||||
|  returnLargerUIMag: | ||||
|     uiA96 = aWPtr[indexWordHi( 4 )]; | ||||
|     uiB96 = bWPtr[indexWordHi( 4 )]; | ||||
|     wordMagA = uiA96 & 0x7FFFFFFF; | ||||
|     wordMagB = uiB96 & 0x7FFFFFFF; | ||||
|     if ( wordMagA < wordMagB ) goto copyB; | ||||
|     if ( wordMagB < wordMagA ) goto copy; | ||||
|     wordMagA = aWPtr[indexWord( 4, 2 )]; | ||||
|     wordMagB = bWPtr[indexWord( 4, 2 )]; | ||||
|     if ( wordMagA < wordMagB ) goto copyB; | ||||
|     if ( wordMagB < wordMagA ) goto copy; | ||||
|     wordMagA = aWPtr[indexWord( 4, 1 )]; | ||||
|     wordMagB = bWPtr[indexWord( 4, 1 )]; | ||||
|     if ( wordMagA < wordMagB ) goto copyB; | ||||
|     if ( wordMagB < wordMagA ) goto copy; | ||||
|     wordMagA = aWPtr[indexWord( 4, 0 )]; | ||||
|     wordMagB = bWPtr[indexWord( 4, 0 )]; | ||||
|     if ( wordMagA < wordMagB ) goto copyB; | ||||
|     if ( wordMagB < wordMagA ) goto copy; | ||||
|     if ( uiA96 < uiB96 ) goto copy; | ||||
|  copyB: | ||||
|     ptr = bWPtr; | ||||
|  copy: | ||||
|     zWPtr[indexWordHi( 4 )] = ptr[indexWordHi( 4 )] | 0x00008000; | ||||
|     zWPtr[indexWord( 4, 2 )] = ptr[indexWord( 4, 2 )]; | ||||
|     zWPtr[indexWord( 4, 1 )] = ptr[indexWord( 4, 1 )]; | ||||
|     zWPtr[indexWord( 4, 0 )] = ptr[indexWord( 4, 0 )]; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,105 +1,105 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2018 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting the unsigned integer formed from concatenating 'uiA64' and | ||||
| | 'uiA0' as a 128-bit floating-point value, and likewise interpreting the | ||||
| | unsigned integer formed from concatenating 'uiB64' and 'uiB0' as another | ||||
| | 128-bit floating-point value, and assuming at least on of these floating- | ||||
| | point values is a NaN, returns the bit pattern of the combined NaN result. | ||||
| | If either original floating-point value is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 | ||||
|  softfloat_propagateNaNF128UI( | ||||
|      uint_fast64_t uiA64, | ||||
|      uint_fast64_t uiA0, | ||||
|      uint_fast64_t uiB64, | ||||
|      uint_fast64_t uiB0 | ||||
|  ) | ||||
| { | ||||
|     bool isSigNaNA, isSigNaNB; | ||||
|     uint_fast64_t uiNonsigA64, uiNonsigB64, uiMagA64, uiMagB64; | ||||
|     struct uint128 uiZ; | ||||
|  | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     isSigNaNA = softfloat_isSigNaNF128UI( uiA64, uiA0 ); | ||||
|     isSigNaNB = softfloat_isSigNaNF128UI( uiB64, uiB0 ); | ||||
|     /*------------------------------------------------------------------------ | ||||
|     | Make NaNs non-signaling. | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     uiNonsigA64 = uiA64 | UINT64_C( 0x0000800000000000 ); | ||||
|     uiNonsigB64 = uiB64 | UINT64_C( 0x0000800000000000 ); | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     if ( isSigNaNA | isSigNaNB ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) { | ||||
|             if ( isSigNaNB ) goto returnLargerMag; | ||||
|             if ( isNaNF128UI( uiB64, uiB0 ) ) goto returnB; | ||||
|             goto returnA; | ||||
|         } else { | ||||
|             if ( isNaNF128UI( uiA64, uiA0 ) ) goto returnA; | ||||
|             goto returnB; | ||||
|         } | ||||
|     } | ||||
|  returnLargerMag: | ||||
|     uiMagA64 = uiA64 & UINT64_C( 0x7FFFFFFFFFFFFFFF ); | ||||
|     uiMagB64 = uiB64 & UINT64_C( 0x7FFFFFFFFFFFFFFF ); | ||||
|     if ( uiMagA64 < uiMagB64 ) goto returnB; | ||||
|     if ( uiMagB64 < uiMagA64 ) goto returnA; | ||||
|     if ( uiA0 < uiB0 ) goto returnB; | ||||
|     if ( uiB0 < uiA0 ) goto returnA; | ||||
|     if ( uiNonsigA64 < uiNonsigB64 ) goto returnA; | ||||
|  returnB: | ||||
|     uiZ.v64 = uiNonsigB64; | ||||
|     uiZ.v0  = uiB0; | ||||
|     return uiZ; | ||||
|  returnA: | ||||
|     uiZ.v64 = uiNonsigA64; | ||||
|     uiZ.v0  = uiA0; | ||||
|     return uiZ; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2018 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting the unsigned integer formed from concatenating 'uiA64' and | ||||
| | 'uiA0' as a 128-bit floating-point value, and likewise interpreting the | ||||
| | unsigned integer formed from concatenating 'uiB64' and 'uiB0' as another | ||||
| | 128-bit floating-point value, and assuming at least on of these floating- | ||||
| | point values is a NaN, returns the bit pattern of the combined NaN result. | ||||
| | If either original floating-point value is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 | ||||
|  softfloat_propagateNaNF128UI( | ||||
|      uint_fast64_t uiA64, | ||||
|      uint_fast64_t uiA0, | ||||
|      uint_fast64_t uiB64, | ||||
|      uint_fast64_t uiB0 | ||||
|  ) | ||||
| { | ||||
|     bool isSigNaNA, isSigNaNB; | ||||
|     uint_fast64_t uiNonsigA64, uiNonsigB64, uiMagA64, uiMagB64; | ||||
|     struct uint128 uiZ; | ||||
|  | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     isSigNaNA = softfloat_isSigNaNF128UI( uiA64, uiA0 ); | ||||
|     isSigNaNB = softfloat_isSigNaNF128UI( uiB64, uiB0 ); | ||||
|     /*------------------------------------------------------------------------ | ||||
|     | Make NaNs non-signaling. | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     uiNonsigA64 = uiA64 | UINT64_C( 0x0000800000000000 ); | ||||
|     uiNonsigB64 = uiB64 | UINT64_C( 0x0000800000000000 ); | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     if ( isSigNaNA | isSigNaNB ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) { | ||||
|             if ( isSigNaNB ) goto returnLargerMag; | ||||
|             if ( isNaNF128UI( uiB64, uiB0 ) ) goto returnB; | ||||
|             goto returnA; | ||||
|         } else { | ||||
|             if ( isNaNF128UI( uiA64, uiA0 ) ) goto returnA; | ||||
|             goto returnB; | ||||
|         } | ||||
|     } | ||||
|  returnLargerMag: | ||||
|     uiMagA64 = uiA64 & UINT64_C( 0x7FFFFFFFFFFFFFFF ); | ||||
|     uiMagB64 = uiB64 & UINT64_C( 0x7FFFFFFFFFFFFFFF ); | ||||
|     if ( uiMagA64 < uiMagB64 ) goto returnB; | ||||
|     if ( uiMagB64 < uiMagA64 ) goto returnA; | ||||
|     if ( uiA0 < uiB0 ) goto returnB; | ||||
|     if ( uiB0 < uiA0 ) goto returnA; | ||||
|     if ( uiNonsigA64 < uiNonsigB64 ) goto returnA; | ||||
|  returnB: | ||||
|     uiZ.v64 = uiNonsigB64; | ||||
|     uiZ.v0  = uiB0; | ||||
|     return uiZ; | ||||
|  returnA: | ||||
|     uiZ.v64 = uiNonsigA64; | ||||
|     uiZ.v0  = uiA0; | ||||
|     return uiZ; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,84 +1,84 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2018 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting 'uiA' and 'uiB' as the bit patterns of two 16-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either 'uiA' or 'uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast16_t | ||||
|  softfloat_propagateNaNF16UI( uint_fast16_t uiA, uint_fast16_t uiB ) | ||||
| { | ||||
|     bool isSigNaNA, isSigNaNB; | ||||
|     uint_fast16_t uiNonsigA, uiNonsigB, uiMagA, uiMagB; | ||||
|  | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     isSigNaNA = softfloat_isSigNaNF16UI( uiA ); | ||||
|     isSigNaNB = softfloat_isSigNaNF16UI( uiB ); | ||||
|     /*------------------------------------------------------------------------ | ||||
|     | Make NaNs non-signaling. | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     uiNonsigA = uiA | 0x0200; | ||||
|     uiNonsigB = uiB | 0x0200; | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     if ( isSigNaNA | isSigNaNB ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) { | ||||
|             if ( isSigNaNB ) goto returnLargerMag; | ||||
|             return isNaNF16UI( uiB ) ? uiNonsigB : uiNonsigA; | ||||
|         } else { | ||||
|             return isNaNF16UI( uiA ) ? uiNonsigA : uiNonsigB; | ||||
|         } | ||||
|     } | ||||
|  returnLargerMag: | ||||
|     uiMagA = uiA & 0x7FFF; | ||||
|     uiMagB = uiB & 0x7FFF; | ||||
|     if ( uiMagA < uiMagB ) return uiNonsigB; | ||||
|     if ( uiMagB < uiMagA ) return uiNonsigA; | ||||
|     return (uiNonsigA < uiNonsigB) ? uiNonsigA : uiNonsigB; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2018 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting 'uiA' and 'uiB' as the bit patterns of two 16-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either 'uiA' or 'uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast16_t | ||||
|  softfloat_propagateNaNF16UI( uint_fast16_t uiA, uint_fast16_t uiB ) | ||||
| { | ||||
|     bool isSigNaNA, isSigNaNB; | ||||
|     uint_fast16_t uiNonsigA, uiNonsigB, uiMagA, uiMagB; | ||||
|  | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     isSigNaNA = softfloat_isSigNaNF16UI( uiA ); | ||||
|     isSigNaNB = softfloat_isSigNaNF16UI( uiB ); | ||||
|     /*------------------------------------------------------------------------ | ||||
|     | Make NaNs non-signaling. | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     uiNonsigA = uiA | 0x0200; | ||||
|     uiNonsigB = uiB | 0x0200; | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     if ( isSigNaNA | isSigNaNB ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) { | ||||
|             if ( isSigNaNB ) goto returnLargerMag; | ||||
|             return isNaNF16UI( uiB ) ? uiNonsigB : uiNonsigA; | ||||
|         } else { | ||||
|             return isNaNF16UI( uiA ) ? uiNonsigA : uiNonsigB; | ||||
|         } | ||||
|     } | ||||
|  returnLargerMag: | ||||
|     uiMagA = uiA & 0x7FFF; | ||||
|     uiMagB = uiB & 0x7FFF; | ||||
|     if ( uiMagA < uiMagB ) return uiNonsigB; | ||||
|     if ( uiMagB < uiMagA ) return uiNonsigA; | ||||
|     return (uiNonsigA < uiNonsigB) ? uiNonsigA : uiNonsigB; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,84 +1,84 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2018 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting 'uiA' and 'uiB' as the bit patterns of two 32-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either 'uiA' or 'uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast32_t | ||||
|  softfloat_propagateNaNF32UI( uint_fast32_t uiA, uint_fast32_t uiB ) | ||||
| { | ||||
|     bool isSigNaNA, isSigNaNB; | ||||
|     uint_fast32_t uiNonsigA, uiNonsigB, uiMagA, uiMagB; | ||||
|  | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     isSigNaNA = softfloat_isSigNaNF32UI( uiA ); | ||||
|     isSigNaNB = softfloat_isSigNaNF32UI( uiB ); | ||||
|     /*------------------------------------------------------------------------ | ||||
|     | Make NaNs non-signaling. | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     uiNonsigA = uiA | 0x00400000; | ||||
|     uiNonsigB = uiB | 0x00400000; | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     if ( isSigNaNA | isSigNaNB ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) { | ||||
|             if ( isSigNaNB ) goto returnLargerMag; | ||||
|             return isNaNF32UI( uiB ) ? uiNonsigB : uiNonsigA; | ||||
|         } else { | ||||
|             return isNaNF32UI( uiA ) ? uiNonsigA : uiNonsigB; | ||||
|         } | ||||
|     } | ||||
|  returnLargerMag: | ||||
|     uiMagA = uiA & 0x7FFFFFFF; | ||||
|     uiMagB = uiB & 0x7FFFFFFF; | ||||
|     if ( uiMagA < uiMagB ) return uiNonsigB; | ||||
|     if ( uiMagB < uiMagA ) return uiNonsigA; | ||||
|     return (uiNonsigA < uiNonsigB) ? uiNonsigA : uiNonsigB; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2018 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting 'uiA' and 'uiB' as the bit patterns of two 32-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either 'uiA' or 'uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast32_t | ||||
|  softfloat_propagateNaNF32UI( uint_fast32_t uiA, uint_fast32_t uiB ) | ||||
| { | ||||
|     bool isSigNaNA, isSigNaNB; | ||||
|     uint_fast32_t uiNonsigA, uiNonsigB, uiMagA, uiMagB; | ||||
|  | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     isSigNaNA = softfloat_isSigNaNF32UI( uiA ); | ||||
|     isSigNaNB = softfloat_isSigNaNF32UI( uiB ); | ||||
|     /*------------------------------------------------------------------------ | ||||
|     | Make NaNs non-signaling. | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     uiNonsigA = uiA | 0x00400000; | ||||
|     uiNonsigB = uiB | 0x00400000; | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     if ( isSigNaNA | isSigNaNB ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) { | ||||
|             if ( isSigNaNB ) goto returnLargerMag; | ||||
|             return isNaNF32UI( uiB ) ? uiNonsigB : uiNonsigA; | ||||
|         } else { | ||||
|             return isNaNF32UI( uiA ) ? uiNonsigA : uiNonsigB; | ||||
|         } | ||||
|     } | ||||
|  returnLargerMag: | ||||
|     uiMagA = uiA & 0x7FFFFFFF; | ||||
|     uiMagB = uiB & 0x7FFFFFFF; | ||||
|     if ( uiMagA < uiMagB ) return uiNonsigB; | ||||
|     if ( uiMagB < uiMagA ) return uiNonsigA; | ||||
|     return (uiNonsigA < uiNonsigB) ? uiNonsigA : uiNonsigB; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,84 +1,84 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2018 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting 'uiA' and 'uiB' as the bit patterns of two 64-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either 'uiA' or 'uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast64_t | ||||
|  softfloat_propagateNaNF64UI( uint_fast64_t uiA, uint_fast64_t uiB ) | ||||
| { | ||||
|     bool isSigNaNA, isSigNaNB; | ||||
|     uint_fast64_t uiNonsigA, uiNonsigB, uiMagA, uiMagB; | ||||
|  | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     isSigNaNA = softfloat_isSigNaNF64UI( uiA ); | ||||
|     isSigNaNB = softfloat_isSigNaNF64UI( uiB ); | ||||
|     /*------------------------------------------------------------------------ | ||||
|     | Make NaNs non-signaling. | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     uiNonsigA = uiA | UINT64_C( 0x0008000000000000 ); | ||||
|     uiNonsigB = uiB | UINT64_C( 0x0008000000000000 ); | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     if ( isSigNaNA | isSigNaNB ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) { | ||||
|             if ( isSigNaNB ) goto returnLargerMag; | ||||
|             return isNaNF64UI( uiB ) ? uiNonsigB : uiNonsigA; | ||||
|         } else { | ||||
|             return isNaNF64UI( uiA ) ? uiNonsigA : uiNonsigB; | ||||
|         } | ||||
|     } | ||||
|  returnLargerMag: | ||||
|     uiMagA = uiA & UINT64_C( 0x7FFFFFFFFFFFFFFF ); | ||||
|     uiMagB = uiB & UINT64_C( 0x7FFFFFFFFFFFFFFF ); | ||||
|     if ( uiMagA < uiMagB ) return uiNonsigB; | ||||
|     if ( uiMagB < uiMagA ) return uiNonsigA; | ||||
|     return (uiNonsigA < uiNonsigB) ? uiNonsigA : uiNonsigB; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2018 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "internals.h" | ||||
| #include "specialize.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting 'uiA' and 'uiB' as the bit patterns of two 64-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either 'uiA' or 'uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast64_t | ||||
|  softfloat_propagateNaNF64UI( uint_fast64_t uiA, uint_fast64_t uiB ) | ||||
| { | ||||
|     bool isSigNaNA, isSigNaNB; | ||||
|     uint_fast64_t uiNonsigA, uiNonsigB, uiMagA, uiMagB; | ||||
|  | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     isSigNaNA = softfloat_isSigNaNF64UI( uiA ); | ||||
|     isSigNaNB = softfloat_isSigNaNF64UI( uiB ); | ||||
|     /*------------------------------------------------------------------------ | ||||
|     | Make NaNs non-signaling. | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     uiNonsigA = uiA | UINT64_C( 0x0008000000000000 ); | ||||
|     uiNonsigB = uiB | UINT64_C( 0x0008000000000000 ); | ||||
|     /*------------------------------------------------------------------------ | ||||
|     *------------------------------------------------------------------------*/ | ||||
|     if ( isSigNaNA | isSigNaNB ) { | ||||
|         softfloat_raiseFlags( softfloat_flag_invalid ); | ||||
|         if ( isSigNaNA ) { | ||||
|             if ( isSigNaNB ) goto returnLargerMag; | ||||
|             return isNaNF64UI( uiB ) ? uiNonsigB : uiNonsigA; | ||||
|         } else { | ||||
|             return isNaNF64UI( uiA ) ? uiNonsigA : uiNonsigB; | ||||
|         } | ||||
|     } | ||||
|  returnLargerMag: | ||||
|     uiMagA = uiA & UINT64_C( 0x7FFFFFFFFFFFFFFF ); | ||||
|     uiMagB = uiB & UINT64_C( 0x7FFFFFFFFFFFFFFF ); | ||||
|     if ( uiMagA < uiMagB ) return uiNonsigB; | ||||
|     if ( uiMagB < uiMagA ) return uiNonsigA; | ||||
|     return (uiNonsigA < uiNonsigB) ? uiNonsigA : uiNonsigB; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,52 +1,52 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include "platform.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Raises the exceptions specified by `flags'.  Floating-point traps can be | ||||
| | defined here if desired.  It is currently not possible for such a trap | ||||
| | to substitute a result value.  If traps are not implemented, this routine | ||||
| | should be simply `softfloat_exceptionFlags |= flags;'. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_raiseFlags( uint_fast8_t flags ) | ||||
| { | ||||
|  | ||||
|     softfloat_exceptionFlags |= flags; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include "platform.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Raises the exceptions specified by `flags'.  Floating-point traps can be | ||||
| | defined here if desired.  It is currently not possible for such a trap | ||||
| | to substitute a result value.  If traps are not implemented, this routine | ||||
| | should be simply `softfloat_exceptionFlags |= flags;'. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_raiseFlags( uint_fast8_t flags ) | ||||
| { | ||||
|  | ||||
|     softfloat_exceptionFlags |= flags; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,346 +1,346 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2018 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #ifndef specialize_h | ||||
| #define specialize_h 1 | ||||
|  | ||||
| #include "primitiveTypes.h" | ||||
| #include "softfloat.h" | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Default value for 'softfloat_detectTininess'. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define init_detectTininess softfloat_tininess_afterRounding | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The values to return on conversions to 32-bit integer formats that raise an | ||||
| | invalid exception. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define ui32_fromPosOverflow 0xFFFFFFFF | ||||
| #define ui32_fromNegOverflow 0xFFFFFFFF | ||||
| #define ui32_fromNaN 0xFFFFFFFF | ||||
| #define i32_fromPosOverflow (-0x7FFFFFFF - 1) | ||||
| #define i32_fromNegOverflow (-0x7FFFFFFF - 1) | ||||
| #define i32_fromNaN (-0x7FFFFFFF - 1) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The values to return on conversions to 64-bit integer formats that raise an | ||||
| | invalid exception. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define ui64_fromPosOverflow UINT64_C(0xFFFFFFFFFFFFFFFF) | ||||
| #define ui64_fromNegOverflow UINT64_C(0xFFFFFFFFFFFFFFFF) | ||||
| #define ui64_fromNaN UINT64_C(0xFFFFFFFFFFFFFFFF) | ||||
| #define i64_fromPosOverflow (-INT64_C(0x7FFFFFFFFFFFFFFF) - 1) | ||||
| #define i64_fromNegOverflow (-INT64_C(0x7FFFFFFFFFFFFFFF) - 1) | ||||
| #define i64_fromNaN (-INT64_C(0x7FFFFFFFFFFFFFFF) - 1) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | "Common NaN" structure, used to transfer NaN representations from one format | ||||
| | to another. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct commonNaN { | ||||
|     bool sign; | ||||
| #ifdef LITTLEENDIAN | ||||
|     uint64_t v0, v64; | ||||
| #else | ||||
|     uint64_t v64, v0; | ||||
| #endif | ||||
| }; | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 16-bit floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNF16UI 0xFE00 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Returns true when 16-bit unsigned integer 'uiA' has the bit pattern of a | ||||
| | 16-bit floating-point signaling NaN. | ||||
| | Note:  This macro evaluates its argument more than once. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define softfloat_isSigNaNF16UI(uiA) ((((uiA)&0x7E00) == 0x7C00) && ((uiA)&0x01FF)) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming 'uiA' has the bit pattern of a 16-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by 'zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f16UIToCommonNaN(uint_fast16_t uiA, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 16-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast16_t softfloat_commonNaNToF16UI(const struct commonNaN* aPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting 'uiA' and 'uiB' as the bit patterns of two 16-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either 'uiA' or 'uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast16_t softfloat_propagateNaNF16UI(uint_fast16_t uiA, uint_fast16_t uiB); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 32-bit floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNF32UI 0xFFC00000 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Returns true when 32-bit unsigned integer 'uiA' has the bit pattern of a | ||||
| | 32-bit floating-point signaling NaN. | ||||
| | Note:  This macro evaluates its argument more than once. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define softfloat_isSigNaNF32UI(uiA) ((((uiA)&0x7FC00000) == 0x7F800000) && ((uiA)&0x003FFFFF)) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming 'uiA' has the bit pattern of a 32-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by 'zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f32UIToCommonNaN(uint_fast32_t uiA, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 32-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast32_t softfloat_commonNaNToF32UI(const struct commonNaN* aPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting 'uiA' and 'uiB' as the bit patterns of two 32-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either 'uiA' or 'uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast32_t softfloat_propagateNaNF32UI(uint_fast32_t uiA, uint_fast32_t uiB); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 64-bit floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNF64UI UINT64_C(0xFFF8000000000000) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Returns true when 64-bit unsigned integer 'uiA' has the bit pattern of a | ||||
| | 64-bit floating-point signaling NaN. | ||||
| | Note:  This macro evaluates its argument more than once. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define softfloat_isSigNaNF64UI(uiA)                                                                                                       \ | ||||
|     ((((uiA)&UINT64_C(0x7FF8000000000000)) == UINT64_C(0x7FF0000000000000)) && ((uiA)&UINT64_C(0x0007FFFFFFFFFFFF))) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming 'uiA' has the bit pattern of a 64-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by 'zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f64UIToCommonNaN(uint_fast64_t uiA, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 64-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast64_t softfloat_commonNaNToF64UI(const struct commonNaN* aPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting 'uiA' and 'uiB' as the bit patterns of two 64-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either 'uiA' or 'uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast64_t softfloat_propagateNaNF64UI(uint_fast64_t uiA, uint_fast64_t uiB); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 80-bit extended floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNExtF80UI64 0xFFFF | ||||
| #define defaultNaNExtF80UI0 UINT64_C(0xC000000000000000) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Returns true when the 80-bit unsigned integer formed from concatenating | ||||
| | 16-bit 'uiA64' and 64-bit 'uiA0' has the bit pattern of an 80-bit extended | ||||
| | floating-point signaling NaN. | ||||
| | Note:  This macro evaluates its arguments more than once. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define softfloat_isSigNaNExtF80UI(uiA64, uiA0)                                                                                            \ | ||||
|     ((((uiA64)&0x7FFF) == 0x7FFF) && !((uiA0)&UINT64_C(0x4000000000000000)) && ((uiA0)&UINT64_C(0x3FFFFFFFFFFFFFFF))) | ||||
|  | ||||
| #ifdef SOFTFLOAT_FAST_INT64 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The following functions are needed only when 'SOFTFLOAT_FAST_INT64' is | ||||
| | defined. | ||||
| *----------------------------------------------------------------------------*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the unsigned integer formed from concatenating 'uiA64' and 'uiA0' | ||||
| | has the bit pattern of an 80-bit extended floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by 'zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_extF80UIToCommonNaN(uint_fast16_t uiA64, uint_fast64_t uiA0, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into an 80-bit extended | ||||
| | floating-point NaN, and returns the bit pattern of this value as an unsigned | ||||
| | integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_commonNaNToExtF80UI(const struct commonNaN* aPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting the unsigned integer formed from concatenating 'uiA64' and | ||||
| | 'uiA0' as an 80-bit extended floating-point value, and likewise interpreting | ||||
| | the unsigned integer formed from concatenating 'uiB64' and 'uiB0' as another | ||||
| | 80-bit extended floating-point value, and assuming at least on of these | ||||
| | floating-point values is a NaN, returns the bit pattern of the combined NaN | ||||
| | result.  If either original floating-point value is a signaling NaN, the | ||||
| | invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_propagateNaNExtF80UI(uint_fast16_t uiA64, uint_fast64_t uiA0, uint_fast16_t uiB64, uint_fast64_t uiB0); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 128-bit floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNF128UI64 UINT64_C(0xFFFF800000000000) | ||||
| #define defaultNaNF128UI0 UINT64_C(0) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Returns true when the 128-bit unsigned integer formed from concatenating | ||||
| | 64-bit 'uiA64' and 64-bit 'uiA0' has the bit pattern of a 128-bit floating- | ||||
| | point signaling NaN. | ||||
| | Note:  This macro evaluates its arguments more than once. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define softfloat_isSigNaNF128UI(uiA64, uiA0)                                                                                              \ | ||||
|     ((((uiA64)&UINT64_C(0x7FFF800000000000)) == UINT64_C(0x7FFF000000000000)) && ((uiA0) || ((uiA64)&UINT64_C(0x00007FFFFFFFFFFF)))) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the unsigned integer formed from concatenating 'uiA64' and 'uiA0' | ||||
| | has the bit pattern of a 128-bit floating-point NaN, converts this NaN to | ||||
| | the common NaN form, and stores the resulting common NaN at the location | ||||
| | pointed to by 'zPtr'.  If the NaN is a signaling NaN, the invalid exception | ||||
| | is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f128UIToCommonNaN(uint_fast64_t uiA64, uint_fast64_t uiA0, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 128-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_commonNaNToF128UI(const struct commonNaN*); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting the unsigned integer formed from concatenating 'uiA64' and | ||||
| | 'uiA0' as a 128-bit floating-point value, and likewise interpreting the | ||||
| | unsigned integer formed from concatenating 'uiB64' and 'uiB0' as another | ||||
| | 128-bit floating-point value, and assuming at least on of these floating- | ||||
| | point values is a NaN, returns the bit pattern of the combined NaN result. | ||||
| | If either original floating-point value is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_propagateNaNF128UI(uint_fast64_t uiA64, uint_fast64_t uiA0, uint_fast64_t uiB64, uint_fast64_t uiB0); | ||||
|  | ||||
| #else | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The following functions are needed only when 'SOFTFLOAT_FAST_INT64' is not | ||||
| | defined. | ||||
| *----------------------------------------------------------------------------*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the 80-bit extended floating-point value pointed to by 'aSPtr' is | ||||
| | a NaN, converts this NaN to the common NaN form, and stores the resulting | ||||
| | common NaN at the location pointed to by 'zPtr'.  If the NaN is a signaling | ||||
| | NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_extF80MToCommonNaN(const struct extFloat80M* aSPtr, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into an 80-bit extended | ||||
| | floating-point NaN, and stores this NaN at the location pointed to by | ||||
| | 'zSPtr'. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_commonNaNToExtF80M(const struct commonNaN* aPtr, struct extFloat80M* zSPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming at least one of the two 80-bit extended floating-point values | ||||
| | pointed to by 'aSPtr' and 'bSPtr' is a NaN, stores the combined NaN result | ||||
| | at the location pointed to by 'zSPtr'.  If either original floating-point | ||||
| | value is a signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_propagateNaNExtF80M(const struct extFloat80M* aSPtr, const struct extFloat80M* bSPtr, struct extFloat80M* zSPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 128-bit floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNF128UI96 0xFFFF8000 | ||||
| #define defaultNaNF128UI64 0 | ||||
| #define defaultNaNF128UI32 0 | ||||
| #define defaultNaNF128UI0 0 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the 128-bit floating-point value pointed to by 'aWPtr' is a NaN, | ||||
| | converts this NaN to the common NaN form, and stores the resulting common | ||||
| | NaN at the location pointed to by 'zPtr'.  If the NaN is a signaling NaN, | ||||
| | the invalid exception is raised.  Argument 'aWPtr' points to an array of | ||||
| | four 32-bit elements that concatenate in the platform's normal endian order | ||||
| | to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f128MToCommonNaN(const uint32_t* aWPtr, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 128-bit floating-point | ||||
| | NaN, and stores this NaN at the location pointed to by 'zWPtr'.  Argument | ||||
| | 'zWPtr' points to an array of four 32-bit elements that concatenate in the | ||||
| | platform's normal endian order to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_commonNaNToF128M(const struct commonNaN* aPtr, uint32_t* zWPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming at least one of the two 128-bit floating-point values pointed to by | ||||
| | 'aWPtr' and 'bWPtr' is a NaN, stores the combined NaN result at the location | ||||
| | pointed to by 'zWPtr'.  If either original floating-point value is a | ||||
| | signaling NaN, the invalid exception is raised.  Each of 'aWPtr', 'bWPtr', | ||||
| | and 'zWPtr' points to an array of four 32-bit elements that concatenate in | ||||
| | the platform's normal endian order to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_propagateNaNF128M(const uint32_t* aWPtr, const uint32_t* bWPtr, uint32_t* zWPtr); | ||||
|  | ||||
| #endif | ||||
|  | ||||
| #endif | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C header file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2018 The Regents of the | ||||
| University of California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #ifndef specialize_h | ||||
| #define specialize_h 1 | ||||
|  | ||||
| #include "primitiveTypes.h" | ||||
| #include "softfloat.h" | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Default value for 'softfloat_detectTininess'. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define init_detectTininess softfloat_tininess_afterRounding | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The values to return on conversions to 32-bit integer formats that raise an | ||||
| | invalid exception. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define ui32_fromPosOverflow 0xFFFFFFFF | ||||
| #define ui32_fromNegOverflow 0xFFFFFFFF | ||||
| #define ui32_fromNaN 0xFFFFFFFF | ||||
| #define i32_fromPosOverflow (-0x7FFFFFFF - 1) | ||||
| #define i32_fromNegOverflow (-0x7FFFFFFF - 1) | ||||
| #define i32_fromNaN (-0x7FFFFFFF - 1) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The values to return on conversions to 64-bit integer formats that raise an | ||||
| | invalid exception. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define ui64_fromPosOverflow UINT64_C(0xFFFFFFFFFFFFFFFF) | ||||
| #define ui64_fromNegOverflow UINT64_C(0xFFFFFFFFFFFFFFFF) | ||||
| #define ui64_fromNaN UINT64_C(0xFFFFFFFFFFFFFFFF) | ||||
| #define i64_fromPosOverflow (-INT64_C(0x7FFFFFFFFFFFFFFF) - 1) | ||||
| #define i64_fromNegOverflow (-INT64_C(0x7FFFFFFFFFFFFFFF) - 1) | ||||
| #define i64_fromNaN (-INT64_C(0x7FFFFFFFFFFFFFFF) - 1) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | "Common NaN" structure, used to transfer NaN representations from one format | ||||
| | to another. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct commonNaN { | ||||
|     bool sign; | ||||
| #ifdef LITTLEENDIAN | ||||
|     uint64_t v0, v64; | ||||
| #else | ||||
|     uint64_t v64, v0; | ||||
| #endif | ||||
| }; | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 16-bit floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNF16UI 0xFE00 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Returns true when 16-bit unsigned integer 'uiA' has the bit pattern of a | ||||
| | 16-bit floating-point signaling NaN. | ||||
| | Note:  This macro evaluates its argument more than once. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define softfloat_isSigNaNF16UI(uiA) ((((uiA)&0x7E00) == 0x7C00) && ((uiA)&0x01FF)) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming 'uiA' has the bit pattern of a 16-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by 'zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f16UIToCommonNaN(uint_fast16_t uiA, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 16-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast16_t softfloat_commonNaNToF16UI(const struct commonNaN* aPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting 'uiA' and 'uiB' as the bit patterns of two 16-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either 'uiA' or 'uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast16_t softfloat_propagateNaNF16UI(uint_fast16_t uiA, uint_fast16_t uiB); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 32-bit floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNF32UI 0xFFC00000 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Returns true when 32-bit unsigned integer 'uiA' has the bit pattern of a | ||||
| | 32-bit floating-point signaling NaN. | ||||
| | Note:  This macro evaluates its argument more than once. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define softfloat_isSigNaNF32UI(uiA) ((((uiA)&0x7FC00000) == 0x7F800000) && ((uiA)&0x003FFFFF)) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming 'uiA' has the bit pattern of a 32-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by 'zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f32UIToCommonNaN(uint_fast32_t uiA, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 32-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast32_t softfloat_commonNaNToF32UI(const struct commonNaN* aPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting 'uiA' and 'uiB' as the bit patterns of two 32-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either 'uiA' or 'uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast32_t softfloat_propagateNaNF32UI(uint_fast32_t uiA, uint_fast32_t uiB); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 64-bit floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNF64UI UINT64_C(0xFFF8000000000000) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Returns true when 64-bit unsigned integer 'uiA' has the bit pattern of a | ||||
| | 64-bit floating-point signaling NaN. | ||||
| | Note:  This macro evaluates its argument more than once. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define softfloat_isSigNaNF64UI(uiA)                                                                                                       \ | ||||
|     ((((uiA)&UINT64_C(0x7FF8000000000000)) == UINT64_C(0x7FF0000000000000)) && ((uiA)&UINT64_C(0x0007FFFFFFFFFFFF))) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming 'uiA' has the bit pattern of a 64-bit floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by 'zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f64UIToCommonNaN(uint_fast64_t uiA, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 64-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast64_t softfloat_commonNaNToF64UI(const struct commonNaN* aPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting 'uiA' and 'uiB' as the bit patterns of two 64-bit floating- | ||||
| | point values, at least one of which is a NaN, returns the bit pattern of | ||||
| | the combined NaN result.  If either 'uiA' or 'uiB' has the pattern of a | ||||
| | signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| uint_fast64_t softfloat_propagateNaNF64UI(uint_fast64_t uiA, uint_fast64_t uiB); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 80-bit extended floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNExtF80UI64 0xFFFF | ||||
| #define defaultNaNExtF80UI0 UINT64_C(0xC000000000000000) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Returns true when the 80-bit unsigned integer formed from concatenating | ||||
| | 16-bit 'uiA64' and 64-bit 'uiA0' has the bit pattern of an 80-bit extended | ||||
| | floating-point signaling NaN. | ||||
| | Note:  This macro evaluates its arguments more than once. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define softfloat_isSigNaNExtF80UI(uiA64, uiA0)                                                                                            \ | ||||
|     ((((uiA64)&0x7FFF) == 0x7FFF) && !((uiA0)&UINT64_C(0x4000000000000000)) && ((uiA0)&UINT64_C(0x3FFFFFFFFFFFFFFF))) | ||||
|  | ||||
| #ifdef SOFTFLOAT_FAST_INT64 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The following functions are needed only when 'SOFTFLOAT_FAST_INT64' is | ||||
| | defined. | ||||
| *----------------------------------------------------------------------------*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the unsigned integer formed from concatenating 'uiA64' and 'uiA0' | ||||
| | has the bit pattern of an 80-bit extended floating-point NaN, converts | ||||
| | this NaN to the common NaN form, and stores the resulting common NaN at the | ||||
| | location pointed to by 'zPtr'.  If the NaN is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_extF80UIToCommonNaN(uint_fast16_t uiA64, uint_fast64_t uiA0, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into an 80-bit extended | ||||
| | floating-point NaN, and returns the bit pattern of this value as an unsigned | ||||
| | integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_commonNaNToExtF80UI(const struct commonNaN* aPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting the unsigned integer formed from concatenating 'uiA64' and | ||||
| | 'uiA0' as an 80-bit extended floating-point value, and likewise interpreting | ||||
| | the unsigned integer formed from concatenating 'uiB64' and 'uiB0' as another | ||||
| | 80-bit extended floating-point value, and assuming at least on of these | ||||
| | floating-point values is a NaN, returns the bit pattern of the combined NaN | ||||
| | result.  If either original floating-point value is a signaling NaN, the | ||||
| | invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_propagateNaNExtF80UI(uint_fast16_t uiA64, uint_fast64_t uiA0, uint_fast16_t uiB64, uint_fast64_t uiB0); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 128-bit floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNF128UI64 UINT64_C(0xFFFF800000000000) | ||||
| #define defaultNaNF128UI0 UINT64_C(0) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Returns true when the 128-bit unsigned integer formed from concatenating | ||||
| | 64-bit 'uiA64' and 64-bit 'uiA0' has the bit pattern of a 128-bit floating- | ||||
| | point signaling NaN. | ||||
| | Note:  This macro evaluates its arguments more than once. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define softfloat_isSigNaNF128UI(uiA64, uiA0)                                                                                              \ | ||||
|     ((((uiA64)&UINT64_C(0x7FFF800000000000)) == UINT64_C(0x7FFF000000000000)) && ((uiA0) || ((uiA64)&UINT64_C(0x00007FFFFFFFFFFF)))) | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the unsigned integer formed from concatenating 'uiA64' and 'uiA0' | ||||
| | has the bit pattern of a 128-bit floating-point NaN, converts this NaN to | ||||
| | the common NaN form, and stores the resulting common NaN at the location | ||||
| | pointed to by 'zPtr'.  If the NaN is a signaling NaN, the invalid exception | ||||
| | is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f128UIToCommonNaN(uint_fast64_t uiA64, uint_fast64_t uiA0, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 128-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_commonNaNToF128UI(const struct commonNaN*); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Interpreting the unsigned integer formed from concatenating 'uiA64' and | ||||
| | 'uiA0' as a 128-bit floating-point value, and likewise interpreting the | ||||
| | unsigned integer formed from concatenating 'uiB64' and 'uiB0' as another | ||||
| | 128-bit floating-point value, and assuming at least on of these floating- | ||||
| | point values is a NaN, returns the bit pattern of the combined NaN result. | ||||
| | If either original floating-point value is a signaling NaN, the invalid | ||||
| | exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_propagateNaNF128UI(uint_fast64_t uiA64, uint_fast64_t uiA0, uint_fast64_t uiB64, uint_fast64_t uiB0); | ||||
|  | ||||
| #else | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The following functions are needed only when 'SOFTFLOAT_FAST_INT64' is not | ||||
| | defined. | ||||
| *----------------------------------------------------------------------------*/ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the 80-bit extended floating-point value pointed to by 'aSPtr' is | ||||
| | a NaN, converts this NaN to the common NaN form, and stores the resulting | ||||
| | common NaN at the location pointed to by 'zPtr'.  If the NaN is a signaling | ||||
| | NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_extF80MToCommonNaN(const struct extFloat80M* aSPtr, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into an 80-bit extended | ||||
| | floating-point NaN, and stores this NaN at the location pointed to by | ||||
| | 'zSPtr'. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_commonNaNToExtF80M(const struct commonNaN* aPtr, struct extFloat80M* zSPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming at least one of the two 80-bit extended floating-point values | ||||
| | pointed to by 'aSPtr' and 'bSPtr' is a NaN, stores the combined NaN result | ||||
| | at the location pointed to by 'zSPtr'.  If either original floating-point | ||||
| | value is a signaling NaN, the invalid exception is raised. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_propagateNaNExtF80M(const struct extFloat80M* aSPtr, const struct extFloat80M* bSPtr, struct extFloat80M* zSPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | The bit pattern for a default generated 128-bit floating-point NaN. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| #define defaultNaNF128UI96 0xFFFF8000 | ||||
| #define defaultNaNF128UI64 0 | ||||
| #define defaultNaNF128UI32 0 | ||||
| #define defaultNaNF128UI0 0 | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming the 128-bit floating-point value pointed to by 'aWPtr' is a NaN, | ||||
| | converts this NaN to the common NaN form, and stores the resulting common | ||||
| | NaN at the location pointed to by 'zPtr'.  If the NaN is a signaling NaN, | ||||
| | the invalid exception is raised.  Argument 'aWPtr' points to an array of | ||||
| | four 32-bit elements that concatenate in the platform's normal endian order | ||||
| | to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_f128MToCommonNaN(const uint32_t* aWPtr, struct commonNaN* zPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 128-bit floating-point | ||||
| | NaN, and stores this NaN at the location pointed to by 'zWPtr'.  Argument | ||||
| | 'zWPtr' points to an array of four 32-bit elements that concatenate in the | ||||
| | platform's normal endian order to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_commonNaNToF128M(const struct commonNaN* aPtr, uint32_t* zWPtr); | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Assuming at least one of the two 128-bit floating-point values pointed to by | ||||
| | 'aWPtr' and 'bWPtr' is a NaN, stores the combined NaN result at the location | ||||
| | pointed to by 'zWPtr'.  If either original floating-point value is a | ||||
| | signaling NaN, the invalid exception is raised.  Each of 'aWPtr', 'bWPtr', | ||||
| | and 'zWPtr' points to an array of four 32-bit elements that concatenate in | ||||
| | the platform's normal endian order to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void softfloat_propagateNaNF128M(const uint32_t* aWPtr, const uint32_t* bWPtr, uint32_t* zWPtr); | ||||
|  | ||||
| #endif | ||||
|  | ||||
| #endif | ||||
|   | ||||
| @@ -1,57 +1,57 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| bool extF80M_isSignalingNaN( const extFloat80_t *aPtr ) | ||||
| { | ||||
|     const struct extFloat80M *aSPtr; | ||||
|     uint64_t uiA0; | ||||
|  | ||||
|     aSPtr = (const struct extFloat80M *) aPtr; | ||||
|     if ( (aSPtr->signExp & 0x7FFF) != 0x7FFF ) return false; | ||||
|     uiA0 = aSPtr->signif; | ||||
|     return | ||||
|         ! (uiA0 & UINT64_C( 0x4000000000000000 )) | ||||
|             && (uiA0 & UINT64_C( 0x3FFFFFFFFFFFFFFF)); | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| bool extF80M_isSignalingNaN( const extFloat80_t *aPtr ) | ||||
| { | ||||
|     const struct extFloat80M *aSPtr; | ||||
|     uint64_t uiA0; | ||||
|  | ||||
|     aSPtr = (const struct extFloat80M *) aPtr; | ||||
|     if ( (aSPtr->signExp & 0x7FFF) != 0x7FFF ) return false; | ||||
|     uiA0 = aSPtr->signif; | ||||
|     return | ||||
|         ! (uiA0 & UINT64_C( 0x4000000000000000 )) | ||||
|             && (uiA0 & UINT64_C( 0x3FFFFFFFFFFFFFFF)); | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,60 +1,60 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| bool f128M_isSignalingNaN( const float128_t *aPtr ) | ||||
| { | ||||
|     const uint32_t *aWPtr; | ||||
|     uint32_t uiA96; | ||||
|  | ||||
|     aWPtr = (const uint32_t *) aPtr; | ||||
|     uiA96 = aWPtr[indexWordHi( 4 )]; | ||||
|     if ( (uiA96 & 0x7FFF8000) != 0x7FFF0000 ) return false; | ||||
|     return | ||||
|         ((uiA96 & 0x00007FFF) != 0) | ||||
|             || ((aWPtr[indexWord( 4, 2 )] | aWPtr[indexWord( 4, 1 )] | ||||
|                      | aWPtr[indexWord( 4, 0 )]) | ||||
|                     != 0); | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014 The Regents of the University of California. | ||||
| All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitives.h" | ||||
| #include "softfloat.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| *----------------------------------------------------------------------------*/ | ||||
| bool f128M_isSignalingNaN( const float128_t *aPtr ) | ||||
| { | ||||
|     const uint32_t *aWPtr; | ||||
|     uint32_t uiA96; | ||||
|  | ||||
|     aWPtr = (const uint32_t *) aPtr; | ||||
|     uiA96 = aWPtr[indexWordHi( 4 )]; | ||||
|     if ( (uiA96 & 0x7FFF8000) != 0x7FFF0000 ) return false; | ||||
|     return | ||||
|         ((uiA96 & 0x00007FFF) != 0) | ||||
|             || ((aWPtr[indexWord( 4, 2 )] | aWPtr[indexWord( 4, 1 )] | ||||
|                      | aWPtr[indexWord( 4, 0 )]) | ||||
|                     != 0); | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,57 +1,57 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2017 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include "platform.h" | ||||
| #include "softfloat_types.h" | ||||
|  | ||||
| #define softfloat_commonNaNToExtF80M softfloat_commonNaNToExtF80M | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into an 80-bit extended | ||||
| | floating-point NaN, and stores this NaN at the location pointed to by | ||||
| | 'zSPtr'. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_commonNaNToExtF80M( | ||||
|      const struct commonNaN *aPtr, struct extFloat80M *zSPtr ) | ||||
| { | ||||
|  | ||||
|     zSPtr->signExp = defaultNaNExtF80UI64; | ||||
|     zSPtr->signif  = defaultNaNExtF80UI0; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2017 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include "platform.h" | ||||
| #include "softfloat_types.h" | ||||
|  | ||||
| #define softfloat_commonNaNToExtF80M softfloat_commonNaNToExtF80M | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into an 80-bit extended | ||||
| | floating-point NaN, and stores this NaN at the location pointed to by | ||||
| | 'zSPtr'. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_commonNaNToExtF80M( | ||||
|      const struct commonNaN *aPtr, struct extFloat80M *zSPtr ) | ||||
| { | ||||
|  | ||||
|     zSPtr->signExp = defaultNaNExtF80UI64; | ||||
|     zSPtr->signif  = defaultNaNExtF80UI0; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,57 +1,57 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2017 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include "platform.h" | ||||
| #include "primitiveTypes.h" | ||||
|  | ||||
| #define softfloat_commonNaNToExtF80UI softfloat_commonNaNToExtF80UI | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into an 80-bit extended | ||||
| | floating-point NaN, and returns the bit pattern of this value as an unsigned | ||||
| | integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_commonNaNToExtF80UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|     struct uint128 uiZ; | ||||
|  | ||||
|     uiZ.v64 = defaultNaNExtF80UI64; | ||||
|     uiZ.v0  = defaultNaNExtF80UI0; | ||||
|     return uiZ; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2017 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include "platform.h" | ||||
| #include "primitiveTypes.h" | ||||
|  | ||||
| #define softfloat_commonNaNToExtF80UI softfloat_commonNaNToExtF80UI | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into an 80-bit extended | ||||
| | floating-point NaN, and returns the bit pattern of this value as an unsigned | ||||
| | integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_commonNaNToExtF80UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|     struct uint128 uiZ; | ||||
|  | ||||
|     uiZ.v64 = defaultNaNExtF80UI64; | ||||
|     uiZ.v0  = defaultNaNExtF80UI0; | ||||
|     return uiZ; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,60 +1,60 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2017 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitiveTypes.h" | ||||
|  | ||||
| #define softfloat_commonNaNToF128M softfloat_commonNaNToF128M | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 128-bit floating-point | ||||
| | NaN, and stores this NaN at the location pointed to by 'zWPtr'.  Argument | ||||
| | 'zWPtr' points to an array of four 32-bit elements that concatenate in the | ||||
| | platform's normal endian order to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_commonNaNToF128M( const struct commonNaN *aPtr, uint32_t *zWPtr ) | ||||
| { | ||||
|  | ||||
|     zWPtr[indexWord( 4, 3 )] = defaultNaNF128UI96; | ||||
|     zWPtr[indexWord( 4, 2 )] = defaultNaNF128UI64; | ||||
|     zWPtr[indexWord( 4, 1 )] = defaultNaNF128UI32; | ||||
|     zWPtr[indexWord( 4, 0 )] = defaultNaNF128UI0; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2017 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include "platform.h" | ||||
| #include "primitiveTypes.h" | ||||
|  | ||||
| #define softfloat_commonNaNToF128M softfloat_commonNaNToF128M | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 128-bit floating-point | ||||
| | NaN, and stores this NaN at the location pointed to by 'zWPtr'.  Argument | ||||
| | 'zWPtr' points to an array of four 32-bit elements that concatenate in the | ||||
| | platform's normal endian order to form a 128-bit floating-point value. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| void | ||||
|  softfloat_commonNaNToF128M( const struct commonNaN *aPtr, uint32_t *zWPtr ) | ||||
| { | ||||
|  | ||||
|     zWPtr[indexWord( 4, 3 )] = defaultNaNF128UI96; | ||||
|     zWPtr[indexWord( 4, 2 )] = defaultNaNF128UI64; | ||||
|     zWPtr[indexWord( 4, 1 )] = defaultNaNF128UI32; | ||||
|     zWPtr[indexWord( 4, 0 )] = defaultNaNF128UI0; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,56 +1,56 @@ | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2017 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include "platform.h" | ||||
| #include "primitiveTypes.h" | ||||
|  | ||||
| #define softfloat_commonNaNToF128UI softfloat_commonNaNToF128UI | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 128-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_commonNaNToF128UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|     struct uint128 uiZ; | ||||
|  | ||||
|     uiZ.v64 = defaultNaNF128UI64; | ||||
|     uiZ.v0  = defaultNaNF128UI0; | ||||
|     return uiZ; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*============================================================================ | ||||
|  | ||||
| This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic | ||||
| Package, Release 3e, by John R. Hauser. | ||||
|  | ||||
| Copyright 2011, 2012, 2013, 2014, 2015, 2017 The Regents of the University of | ||||
| California.  All rights reserved. | ||||
|  | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are met: | ||||
|  | ||||
|  1. Redistributions of source code must retain the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer. | ||||
|  | ||||
|  2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|     this list of conditions, and the following disclaimer in the documentation | ||||
|     and/or other materials provided with the distribution. | ||||
|  | ||||
|  3. Neither the name of the University nor the names of its contributors may | ||||
|     be used to endorse or promote products derived from this software without | ||||
|     specific prior written permission. | ||||
|  | ||||
| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY | ||||
| EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE | ||||
| DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY | ||||
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
| (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
| LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
| ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
| SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | ||||
| =============================================================================*/ | ||||
|  | ||||
| #include "platform.h" | ||||
| #include "primitiveTypes.h" | ||||
|  | ||||
| #define softfloat_commonNaNToF128UI softfloat_commonNaNToF128UI | ||||
| #include "specialize.h" | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | Converts the common NaN pointed to by 'aPtr' into a 128-bit floating-point | ||||
| | NaN, and returns the bit pattern of this value as an unsigned integer. | ||||
| *----------------------------------------------------------------------------*/ | ||||
| struct uint128 softfloat_commonNaNToF128UI( const struct commonNaN *aPtr ) | ||||
| { | ||||
|     struct uint128 uiZ; | ||||
|  | ||||
|     uiZ.v64 = defaultNaNF128UI64; | ||||
|     uiZ.v0  = defaultNaNF128UI0; | ||||
|     return uiZ; | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | This file intentionally contains no code. | ||||
| *----------------------------------------------------------------------------*/ | ||||
|  | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | This file intentionally contains no code. | ||||
| *----------------------------------------------------------------------------*/ | ||||
|  | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | This file intentionally contains no code. | ||||
| *----------------------------------------------------------------------------*/ | ||||
|  | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | This file intentionally contains no code. | ||||
| *----------------------------------------------------------------------------*/ | ||||
|  | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | This file intentionally contains no code. | ||||
| *----------------------------------------------------------------------------*/ | ||||
|  | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | This file intentionally contains no code. | ||||
| *----------------------------------------------------------------------------*/ | ||||
|  | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | This file intentionally contains no code. | ||||
| *----------------------------------------------------------------------------*/ | ||||
|  | ||||
|  | ||||
| /*---------------------------------------------------------------------------- | ||||
| | This file intentionally contains no code. | ||||
| *----------------------------------------------------------------------------*/ | ||||
|  | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user