mirror of
				https://github.com/openhwgroup/cvw
				synced 2025-02-11 06:05:49 +00:00 
			
		
		
		
	Modify Makefile + software example for SP/DP/QP
This commit is contained in:
		
							parent
							
								
									1852304a2a
								
							
						
					
					
						commit
						2d6b5d3000
					
				| @ -2,14 +2,13 @@ | |||||||
| 
 | 
 | ||||||
| CC     = gcc | CC     = gcc | ||||||
| CFLAGS = -O3 | CFLAGS = -O3 | ||||||
| LIBS   = -lm |  | ||||||
| LFLAGS = -L.  | LFLAGS = -L.  | ||||||
| # Link against the riscv-isa-sim version of SoftFloat rather than 
 | # Link against the riscv-isa-sim version of SoftFloat rather than 
 | ||||||
| # the regular version to get RISC-V NaN behavior
 | # the regular version to get RISC-V NaN behavior
 | ||||||
| IFLAGS   = -I$(RISCV)/riscv-isa-sim/softfloat | #IFLAGS   = -I$(RISCV)/riscv-isa-sim/softfloat
 | ||||||
| LIBS   = $(RISCV)/riscv-isa-sim/build/libsoftfloat.a | #LIBS   = $(RISCV)/riscv-isa-sim/build/libsoftfloat.a
 | ||||||
| #IFLAGS = -I../../../addins/SoftFloat-3e/source/include/
 | IFLAGS = -I../../../addins/SoftFloat-3e/source/include/ | ||||||
| #LIBS   = ../../../addins/SoftFloat-3e/build/Linux-x86_64-GCC/softfloat.a
 | LIBS   = ../../../addins/SoftFloat-3e/build/Linux-x86_64-GCC/softfloat.a -lm -lquadmath | ||||||
| SRCS   = $(wildcard *.c) | SRCS   = $(wildcard *.c) | ||||||
| 
 | 
 | ||||||
| PROGS = $(patsubst %.c,%,$(SRCS)) | PROGS = $(patsubst %.c,%,$(SRCS)) | ||||||
| @ -17,7 +16,7 @@ PROGS = $(patsubst %.c,%,$(SRCS)) | |||||||
| all:	$(PROGS) | all:	$(PROGS) | ||||||
| 
 | 
 | ||||||
| %: %.c | %: %.c | ||||||
| 	$(CC) $(CFLAGS) $(IFLAGS) $(LFLAGS) -o $@ $< $(LIBS) | 	$(CC) $(CFLAGS) -DSOFTFLOAT_FAST_INT64 $(IFLAGS) $(LFLAGS) -o $@ $< $(LIBS) | ||||||
| 
 | 
 | ||||||
| clean:  | clean:  | ||||||
| 	rm -f $(PROGS) | 	rm -f $(PROGS) | ||||||
|  | |||||||
| @ -1,77 +0,0 @@ | |||||||
| //
 |  | ||||||
| // softfloat_div.c
 |  | ||||||
| // james.stine@okstate.edu 12 April 2023
 |  | ||||||
| // 
 |  | ||||||
| // Demonstrate using SoftFloat to compute 754 fp divide, then print results
 |  | ||||||
| // (adapted from original C built by David Harris)
 |  | ||||||
| //
 |  | ||||||
| 
 |  | ||||||
| #include <stdio.h> |  | ||||||
| #include <stdint.h> |  | ||||||
| #include "softfloat.h" |  | ||||||
| #include "softfloat_types.h" |  | ||||||
| typedef union sp { |  | ||||||
|   uint32_t v; |  | ||||||
|   unsigned short x[2]; |  | ||||||
|   float f; |  | ||||||
| } sp; |  | ||||||
| 
 |  | ||||||
| void printF32 (char *msg, float32_t f) { |  | ||||||
|   sp conv; |  | ||||||
|   int i, j; |  | ||||||
|   conv.v = f.v; // use union to convert between hexadecimal and floating-point views
 |  | ||||||
|   printf("%s: ", msg);  // print out nicely
 |  | ||||||
|   printf("0x%04x_%04x = %1.15g\n", (conv.v >> 16),(conv.v & 0xFFFF), conv.f); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void printFlags(void) { |  | ||||||
|   int NX = softfloat_exceptionFlags % 2; |  | ||||||
|   int UF = (softfloat_exceptionFlags >> 1) % 2; |  | ||||||
|   int OF = (softfloat_exceptionFlags >> 2) % 2; |  | ||||||
|   int DZ = (softfloat_exceptionFlags >> 3) % 2; |  | ||||||
|   int NV = (softfloat_exceptionFlags >> 4) % 2; |  | ||||||
|   printf ("Flags: Inexact %d Underflow %d Overflow %d DivideZero %d Invalid %d\n",  |  | ||||||
|           NX, UF, OF, DZ, NV); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void softfloatInit(void) { |  | ||||||
|     // RNE: softfloat_round_near_even
 |  | ||||||
|     // RZ:  softfloat_round_minMag
 |  | ||||||
|     // RU:  softfloat_round_max
 |  | ||||||
|     // RD:  softfloat_round_min
 |  | ||||||
|     // RM: softfloat_round_near_maxMag   
 |  | ||||||
|     softfloat_roundingMode = softfloat_round_near_even;  |  | ||||||
|     softfloat_exceptionFlags = 0; // clear exceptions
 |  | ||||||
|     softfloat_detectTininess = softfloat_tininess_afterRounding; // RISC-V behavior for tininess
 |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| int main() { |  | ||||||
| 
 |  | ||||||
|   // float32_t is typedef in SoftFloat
 |  | ||||||
|   float32_t x, y, r1, r2; |  | ||||||
|   sp convx, convy; |  | ||||||
| 
 |  | ||||||
|   // Choose two random values
 |  | ||||||
|   convx.f = 1.30308703073; |  | ||||||
|   convy.f = 1.903038030370; |  | ||||||
|   // Convert to SoftFloat format
 |  | ||||||
|   x.v = (convx.x[1] << 16) + convx.x[0]; |  | ||||||
|   y.v = (convy.x[1] << 16) + convy.x[0];   |  | ||||||
| 
 |  | ||||||
|   printf("Example using SoftFloat\n"); |  | ||||||
|    |  | ||||||
|   softfloatInit(); |  | ||||||
|   r1 = f32_div(x, y); |  | ||||||
|   printf("-------\n"); |  | ||||||
|   printF32("X", x); |  | ||||||
|   printF32("Y", y);  |  | ||||||
|   printF32("result = X/Y", r1); |  | ||||||
|   printFlags(); |  | ||||||
| 
 |  | ||||||
|   r2 = f32_sqrt(x); |  | ||||||
|   printf("-------\n");     |  | ||||||
|   printF32("X", x); |  | ||||||
|   printF32("result = sqrt(X)", r2); |  | ||||||
|   printFlags();   |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
							
								
								
									
										88
									
								
								examples/fp/softfloat_demo/softfloat_demoDP.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										88
									
								
								examples/fp/softfloat_demo/softfloat_demoDP.c
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,88 @@ | |||||||
|  | // softfloat_demo3.c
 | ||||||
|  | // james.stine@okstate.edu 15 August 2023
 | ||||||
|  | // 
 | ||||||
|  | // Demonstrate using SoftFloat do compute a floating-point for quad, then print results
 | ||||||
|  | 
 | ||||||
|  | #include <stdio.h> | ||||||
|  | #include <stdint.h> | ||||||
|  | #include <inttypes.h> | ||||||
|  | #include <quadmath.h> // GCC Quad-Math Library | ||||||
|  | #include "softfloat.h" | ||||||
|  | #include "softfloat_types.h" | ||||||
|  | typedef union sp { | ||||||
|  |   uint32_t v; | ||||||
|  |   float f; | ||||||
|  | } sp; | ||||||
|  | 
 | ||||||
|  | typedef union dp { | ||||||
|  |   uint64_t v; | ||||||
|  |   double d; | ||||||
|  | } dp; | ||||||
|  | 
 | ||||||
|  | typedef union qp { | ||||||
|  |   uint64_t v[2]; | ||||||
|  |   __float128 q; | ||||||
|  | } qp; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | void printF32 (char *msg, float32_t f) { | ||||||
|  |   sp conv; | ||||||
|  |   int i, j; | ||||||
|  |   conv.v = f.v; // use union to convert between hexadecimal and floating-point views
 | ||||||
|  |   printf("%s: ", msg);  // print out nicely
 | ||||||
|  |   printf("0x%04x_%04x = %g\n", (conv.v >> 16),(conv.v & 0xFFFF), conv.f); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void printF64 (char *msg, float64_t d) { | ||||||
|  |   dp conv; | ||||||
|  |   int i, j; | ||||||
|  |   conv.v = d.v; // use union to convert between hexadecimal and floating-point views
 | ||||||
|  |   printf("%s: ", msg);  // print out nicely
 | ||||||
|  |   printf("0x%08x_%08x = %g\n", (conv.v >> 32),(conv.v & 0xFFFFFFFF), conv.d); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void printF128 (char *msg, float128_t q) { | ||||||
|  |   qp conv; | ||||||
|  |   int i, j; | ||||||
|  |   conv.v[0] = q.v[0]; // use union to convert between hexadecimal and floating-point views
 | ||||||
|  |   conv.v[1] = q.v[1]; // use union to convert between hexadecimal and floating-point views  
 | ||||||
|  |   printf("%s: ", msg);  // print out nicely
 | ||||||
|  |   printf("0x%016" PRIx64 "_%016" PRIx64 " = %1.15Qe\n", q.v[1], q.v[0], conv.q); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void printFlags(void) { | ||||||
|  |   int NX = softfloat_exceptionFlags % 2; | ||||||
|  |   int UF = (softfloat_exceptionFlags >> 1) % 2; | ||||||
|  |   int OF = (softfloat_exceptionFlags >> 2) % 2; | ||||||
|  |   int DZ = (softfloat_exceptionFlags >> 3) % 2; | ||||||
|  |   int NV = (softfloat_exceptionFlags >> 4) % 2; | ||||||
|  |   printf ("Flags: Inexact %d Underflow %d Overflow %d DivideZero %d Invalid %d\n",  | ||||||
|  |           NX, UF, OF, DZ, NV); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void softfloatInit(void) { | ||||||
|  |     // rounding modes: RNE: softfloat_round_near_even
 | ||||||
|  |     //                 RZ:  softfloat_round_minMag
 | ||||||
|  |     //                 RP:  softfloat_round_max
 | ||||||
|  |     //                 RM:  softfloat_round_min
 | ||||||
|  |     softfloat_roundingMode = softfloat_round_near_even;  | ||||||
|  |     softfloat_exceptionFlags = 0; // clear exceptions
 | ||||||
|  |     softfloat_detectTininess = softfloat_tininess_afterRounding; // RISC-V behavior for tininess
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | int main() { | ||||||
|  |    | ||||||
|  |   float64_t x, y, z; | ||||||
|  |   float64_t r; | ||||||
|  | 
 | ||||||
|  |   x.v = 0xBFFF988ECE97DFEB; | ||||||
|  |   y.v = 0x3F8EFFFFFFFFFFFF; | ||||||
|  |   z.v = 0x4001000000000000; | ||||||
|  | 
 | ||||||
|  |   softfloatInit(); | ||||||
|  |   printF64("X", x); printF64("Y", y); printF64("Z", z); | ||||||
|  |   r = f64_mulAdd(x, y, z); | ||||||
|  |   printf("\n"); | ||||||
|  |   printF64("r", r); | ||||||
|  |    | ||||||
|  | } | ||||||
							
								
								
									
										91
									
								
								examples/fp/softfloat_demo/softfloat_demoQP.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								examples/fp/softfloat_demo/softfloat_demoQP.c
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,91 @@ | |||||||
|  | // softfloat_demo3.c
 | ||||||
|  | // james.stine@okstate.edu 15 August 2023
 | ||||||
|  | // 
 | ||||||
|  | // Demonstrate using SoftFloat do compute a floating-point for quad, then print results
 | ||||||
|  | 
 | ||||||
|  | #include <stdio.h> | ||||||
|  | #include <stdint.h> | ||||||
|  | #include <inttypes.h> | ||||||
|  | #include <quadmath.h> // GCC Quad-Math Library | ||||||
|  | #include "softfloat.h" | ||||||
|  | #include "softfloat_types.h" | ||||||
|  | typedef union sp { | ||||||
|  |   uint32_t v; | ||||||
|  |   float f; | ||||||
|  | } sp; | ||||||
|  | 
 | ||||||
|  | typedef union dp { | ||||||
|  |   uint64_t v; | ||||||
|  |   double d; | ||||||
|  | } dp; | ||||||
|  | 
 | ||||||
|  | typedef union qp { | ||||||
|  |   uint64_t v[2]; | ||||||
|  |   __float128 q; | ||||||
|  | } qp; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | void printF32 (char *msg, float32_t f) { | ||||||
|  |   sp conv; | ||||||
|  |   int i, j; | ||||||
|  |   conv.v = f.v; // use union to convert between hexadecimal and floating-point views
 | ||||||
|  |   printf("%s: ", msg);  // print out nicely
 | ||||||
|  |   printf("0x%04x_%04x = %g\n", (conv.v >> 16),(conv.v & 0xFFFF), conv.f); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void printF64 (char *msg, float64_t d) { | ||||||
|  |   dp conv; | ||||||
|  |   int i, j; | ||||||
|  |   conv.v = d.v; // use union to convert between hexadecimal and floating-point views
 | ||||||
|  |   printf("%s: ", msg);  // print out nicely
 | ||||||
|  |   printf("0x%08x_%08x = %g\n", (conv.v >> 32),(conv.v & 0xFFFFFFFF), conv.d); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void printF128 (char *msg, float128_t q) { | ||||||
|  |   qp conv; | ||||||
|  |   int i, j; | ||||||
|  |   conv.v[0] = q.v[0]; // use union to convert between hexadecimal and floating-point views
 | ||||||
|  |   conv.v[1] = q.v[1]; // use union to convert between hexadecimal and floating-point views  
 | ||||||
|  |   printf("%s: ", msg);  // print out nicely
 | ||||||
|  |   printf("0x%016" PRIx64 "_%016" PRIx64 " = %1.15Qe\n", q.v[1], q.v[0], conv.q); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void printFlags(void) { | ||||||
|  |   int NX = softfloat_exceptionFlags % 2; | ||||||
|  |   int UF = (softfloat_exceptionFlags >> 1) % 2; | ||||||
|  |   int OF = (softfloat_exceptionFlags >> 2) % 2; | ||||||
|  |   int DZ = (softfloat_exceptionFlags >> 3) % 2; | ||||||
|  |   int NV = (softfloat_exceptionFlags >> 4) % 2; | ||||||
|  |   printf ("Flags: Inexact %d Underflow %d Overflow %d DivideZero %d Invalid %d\n",  | ||||||
|  |           NX, UF, OF, DZ, NV); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void softfloatInit(void) { | ||||||
|  |     // rounding modes: RNE: softfloat_round_near_even
 | ||||||
|  |     //                 RZ:  softfloat_round_minMag
 | ||||||
|  |     //                 RP:  softfloat_round_max
 | ||||||
|  |     //                 RM:  softfloat_round_min
 | ||||||
|  |     softfloat_roundingMode = softfloat_round_near_even;  | ||||||
|  |     softfloat_exceptionFlags = 0; // clear exceptions
 | ||||||
|  |     softfloat_detectTininess = softfloat_tininess_afterRounding; // RISC-V behavior for tininess
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | int main() { | ||||||
|  |    | ||||||
|  |   float128_t x, y, z; | ||||||
|  |   float128_t r; | ||||||
|  | 
 | ||||||
|  |   x.v[1] = 0xBFFF988ECE97DFEB; | ||||||
|  |   x.v[0] = 0xC3BBA082445B4836; | ||||||
|  |   y.v[1] = 0x3F8EFFFFFFFFFFFF; | ||||||
|  |   y.v[0] = 0xFFFFFFFFFFFFFFFF; | ||||||
|  |   z.v[1] = 0x4001000000000000; | ||||||
|  |   z.v[0] = 0x0000000000000000; | ||||||
|  | 
 | ||||||
|  |   softfloatInit(); | ||||||
|  |   printF128("X", x); printF128("Y", y); printF128("Z", z); | ||||||
|  |   r = f128_mulAdd(x, y, z); | ||||||
|  |   printf("\n"); | ||||||
|  |   printF128("r", r); | ||||||
|  |    | ||||||
|  | } | ||||||
							
								
								
									
										88
									
								
								examples/fp/softfloat_demo/softfloat_demoSP.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										88
									
								
								examples/fp/softfloat_demo/softfloat_demoSP.c
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,88 @@ | |||||||
|  | // softfloat_demo3.c
 | ||||||
|  | // james.stine@okstate.edu 15 August 2023
 | ||||||
|  | // 
 | ||||||
|  | // Demonstrate using SoftFloat do compute a floating-point for quad, then print results
 | ||||||
|  | 
 | ||||||
|  | #include <stdio.h> | ||||||
|  | #include <stdint.h> | ||||||
|  | #include <inttypes.h> | ||||||
|  | #include <quadmath.h> // GCC Quad-Math Library | ||||||
|  | #include "softfloat.h" | ||||||
|  | #include "softfloat_types.h" | ||||||
|  | typedef union sp { | ||||||
|  |   uint32_t v; | ||||||
|  |   float f; | ||||||
|  | } sp; | ||||||
|  | 
 | ||||||
|  | typedef union dp { | ||||||
|  |   uint64_t v; | ||||||
|  |   double d; | ||||||
|  | } dp; | ||||||
|  | 
 | ||||||
|  | typedef union qp { | ||||||
|  |   uint64_t v[2]; | ||||||
|  |   __float128 q; | ||||||
|  | } qp; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | void printF32 (char *msg, float32_t f) { | ||||||
|  |   sp conv; | ||||||
|  |   int i, j; | ||||||
|  |   conv.v = f.v; // use union to convert between hexadecimal and floating-point views
 | ||||||
|  |   printf("%s: ", msg);  // print out nicely
 | ||||||
|  |   printf("0x%04x_%04x = %g\n", (conv.v >> 16),(conv.v & 0xFFFF), conv.f); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void printF64 (char *msg, float64_t d) { | ||||||
|  |   dp conv; | ||||||
|  |   int i, j; | ||||||
|  |   conv.v = d.v; // use union to convert between hexadecimal and floating-point views
 | ||||||
|  |   printf("%s: ", msg);  // print out nicely
 | ||||||
|  |   printf("0x%08x_%08x = %g\n", (conv.v >> 32),(conv.v & 0xFFFFFFFF), conv.d); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void printF128 (char *msg, float128_t q) { | ||||||
|  |   qp conv; | ||||||
|  |   int i, j; | ||||||
|  |   conv.v[0] = q.v[0]; // use union to convert between hexadecimal and floating-point views
 | ||||||
|  |   conv.v[1] = q.v[1]; // use union to convert between hexadecimal and floating-point views  
 | ||||||
|  |   printf("%s: ", msg);  // print out nicely
 | ||||||
|  |   printf("0x%016" PRIx64 "_%016" PRIx64 " = %1.15Qe\n", q.v[1], q.v[0], conv.q); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void printFlags(void) { | ||||||
|  |   int NX = softfloat_exceptionFlags % 2; | ||||||
|  |   int UF = (softfloat_exceptionFlags >> 1) % 2; | ||||||
|  |   int OF = (softfloat_exceptionFlags >> 2) % 2; | ||||||
|  |   int DZ = (softfloat_exceptionFlags >> 3) % 2; | ||||||
|  |   int NV = (softfloat_exceptionFlags >> 4) % 2; | ||||||
|  |   printf ("Flags: Inexact %d Underflow %d Overflow %d DivideZero %d Invalid %d\n",  | ||||||
|  |           NX, UF, OF, DZ, NV); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void softfloatInit(void) { | ||||||
|  |     // rounding modes: RNE: softfloat_round_near_even
 | ||||||
|  |     //                 RZ:  softfloat_round_minMag
 | ||||||
|  |     //                 RP:  softfloat_round_max
 | ||||||
|  |     //                 RM:  softfloat_round_min
 | ||||||
|  |     softfloat_roundingMode = softfloat_round_near_even;  | ||||||
|  |     softfloat_exceptionFlags = 0; // clear exceptions
 | ||||||
|  |     softfloat_detectTininess = softfloat_tininess_afterRounding; // RISC-V behavior for tininess
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | int main() { | ||||||
|  |    | ||||||
|  |   float32_t x, y, z; | ||||||
|  |   float32_t r; | ||||||
|  | 
 | ||||||
|  |   x.v = 0xBFFF988E; | ||||||
|  |   y.v = 0x3F8EFFFF; | ||||||
|  |   z.v = 0x40010000; | ||||||
|  | 
 | ||||||
|  |   softfloatInit(); | ||||||
|  |   printF32("X", x); printF32("Y", y); printF32("Z", z); | ||||||
|  |   r = f32_mulAdd(x, y, z); | ||||||
|  |   printf("\n"); | ||||||
|  |   printF32("r", r); | ||||||
|  |    | ||||||
|  | } | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user