all: use compiler-rt from LLVM
Этот коммит содержится в:
		
							родитель
							
								
									09a3c6a16b
								
							
						
					
					
						коммит
						83227e68df
					
				
					 12 изменённых файлов: 42 добавлений и 22 удалений
				
			
		|  | @ -22,15 +22,16 @@ commands: | ||||||
|     steps: |     steps: | ||||||
|       - restore_cache: |       - restore_cache: | ||||||
|           keys: |           keys: | ||||||
|             - llvm-source-13-v1 |             - llvm-source-13-v3 | ||||||
|       - run: |       - run: | ||||||
|           name: "Fetch LLVM source" |           name: "Fetch LLVM source" | ||||||
|           command: make llvm-source |           command: make llvm-source | ||||||
|       - save_cache: |       - save_cache: | ||||||
|           key: llvm-source-13-v1 |           key: llvm-source-13-v3 | ||||||
|           paths: |           paths: | ||||||
|             - llvm-project/clang/lib/Headers |             - llvm-project/clang/lib/Headers | ||||||
|             - llvm-project/clang/include |             - llvm-project/clang/include | ||||||
|  |             - llvm-project/compiler-rt | ||||||
|             - llvm-project/lld/include |             - llvm-project/lld/include | ||||||
|             - llvm-project/llvm/include |             - llvm-project/llvm/include | ||||||
|   hack-ninja-jobs: |   hack-ninja-jobs: | ||||||
|  |  | ||||||
							
								
								
									
										3
									
								
								.github/workflows/build-macos.yml
									
										
									
									
										предоставленный
									
									
								
							
							
						
						
									
										3
									
								
								.github/workflows/build-macos.yml
									
										
									
									
										предоставленный
									
									
								
							|  | @ -35,10 +35,11 @@ jobs: | ||||||
|         uses: actions/cache@v2 |         uses: actions/cache@v2 | ||||||
|         id: cache-llvm-source |         id: cache-llvm-source | ||||||
|         with: |         with: | ||||||
|           key: llvm-source-13-macos-v1 |           key: llvm-source-13-macos-v2 | ||||||
|           path: | |           path: | | ||||||
|             llvm-project/clang/lib/Headers |             llvm-project/clang/lib/Headers | ||||||
|             llvm-project/clang/include |             llvm-project/clang/include | ||||||
|  |             llvm-project/compiler-rt | ||||||
|             llvm-project/lld/include |             llvm-project/lld/include | ||||||
|             llvm-project/llvm/include |             llvm-project/llvm/include | ||||||
|       - name: Download LLVM source |       - name: Download LLVM source | ||||||
|  |  | ||||||
							
								
								
									
										6
									
								
								.github/workflows/linux.yml
									
										
									
									
										предоставленный
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/linux.yml
									
										
									
									
										предоставленный
									
									
								
							|  | @ -38,10 +38,11 @@ jobs: | ||||||
|         uses: actions/cache@v2 |         uses: actions/cache@v2 | ||||||
|         id: cache-llvm-source |         id: cache-llvm-source | ||||||
|         with: |         with: | ||||||
|           key: llvm-source-13-linux-v1 |           key: llvm-source-13-linux-v2 | ||||||
|           path: | |           path: | | ||||||
|             llvm-project/clang/lib/Headers |             llvm-project/clang/lib/Headers | ||||||
|             llvm-project/clang/include |             llvm-project/clang/include | ||||||
|  |             llvm-project/compiler-rt | ||||||
|             llvm-project/lld/include |             llvm-project/lld/include | ||||||
|             llvm-project/llvm/include |             llvm-project/llvm/include | ||||||
|       - name: Download LLVM source |       - name: Download LLVM source | ||||||
|  | @ -179,10 +180,11 @@ jobs: | ||||||
|         uses: actions/cache@v2 |         uses: actions/cache@v2 | ||||||
|         id: cache-llvm-source |         id: cache-llvm-source | ||||||
|         with: |         with: | ||||||
|           key: llvm-source-13-linux-asserts-v1 |           key: llvm-source-13-linux-asserts-v2 | ||||||
|           path: | |           path: | | ||||||
|             llvm-project/clang/lib/Headers |             llvm-project/clang/lib/Headers | ||||||
|             llvm-project/clang/include |             llvm-project/clang/include | ||||||
|  |             llvm-project/compiler-rt | ||||||
|             llvm-project/lld/include |             llvm-project/lld/include | ||||||
|             llvm-project/llvm/include |             llvm-project/llvm/include | ||||||
|       - name: Download LLVM source |       - name: Download LLVM source | ||||||
|  |  | ||||||
							
								
								
									
										3
									
								
								.github/workflows/windows.yml
									
										
									
									
										предоставленный
									
									
								
							
							
						
						
									
										3
									
								
								.github/workflows/windows.yml
									
										
									
									
										предоставленный
									
									
								
							|  | @ -35,10 +35,11 @@ jobs: | ||||||
|         uses: actions/cache@v2 |         uses: actions/cache@v2 | ||||||
|         id: cache-llvm-source |         id: cache-llvm-source | ||||||
|         with: |         with: | ||||||
|           key: llvm-source-13-windows-v1 |           key: llvm-source-13-windows-v2 | ||||||
|           path: | |           path: | | ||||||
|             llvm-project/clang/lib/Headers |             llvm-project/clang/lib/Headers | ||||||
|             llvm-project/clang/include |             llvm-project/clang/include | ||||||
|  |             llvm-project/compiler-rt | ||||||
|             llvm-project/lld/include |             llvm-project/lld/include | ||||||
|             llvm-project/llvm/include |             llvm-project/llvm/include | ||||||
|       - name: Download LLVM source |       - name: Download LLVM source | ||||||
|  |  | ||||||
							
								
								
									
										4
									
								
								.gitmodules
									
										
									
									
										предоставленный
									
									
								
							
							
						
						
									
										4
									
								
								.gitmodules
									
										
									
									
										предоставленный
									
									
								
							|  | @ -10,10 +10,6 @@ | ||||||
| [submodule "lib/cmsis-svd"] | [submodule "lib/cmsis-svd"] | ||||||
| 	path = lib/cmsis-svd | 	path = lib/cmsis-svd | ||||||
| 	url = https://github.com/tinygo-org/cmsis-svd | 	url = https://github.com/tinygo-org/cmsis-svd | ||||||
| [submodule "lib/compiler-rt"] |  | ||||||
| 	path = lib/compiler-rt |  | ||||||
| 	url = https://github.com/llvm-mirror/compiler-rt.git |  | ||||||
| 	branch = release_80 |  | ||||||
| [submodule "lib/wasi-libc"] | [submodule "lib/wasi-libc"] | ||||||
| 	path = lib/wasi-libc | 	path = lib/wasi-libc | ||||||
| 	url = https://github.com/CraneStation/wasi-libc | 	url = https://github.com/CraneStation/wasi-libc | ||||||
|  |  | ||||||
							
								
								
									
										6
									
								
								Makefile
									
										
									
									
									
								
							
							
						
						
									
										6
									
								
								Makefile
									
										
									
									
									
								
							|  | @ -619,7 +619,6 @@ build/release: tinygo gen-device wasi-libc $(if $(filter 1,$(USE_SYSTEM_BINARYEN | ||||||
| 	@mkdir -p build/release/tinygo/bin | 	@mkdir -p build/release/tinygo/bin | ||||||
| 	@mkdir -p build/release/tinygo/lib/clang/include | 	@mkdir -p build/release/tinygo/lib/clang/include | ||||||
| 	@mkdir -p build/release/tinygo/lib/CMSIS/CMSIS | 	@mkdir -p build/release/tinygo/lib/CMSIS/CMSIS | ||||||
| 	@mkdir -p build/release/tinygo/lib/compiler-rt/lib |  | ||||||
| 	@mkdir -p build/release/tinygo/lib/macos-minimal-sdk | 	@mkdir -p build/release/tinygo/lib/macos-minimal-sdk | ||||||
| 	@mkdir -p build/release/tinygo/lib/mingw-w64/mingw-w64-crt/lib-common | 	@mkdir -p build/release/tinygo/lib/mingw-w64/mingw-w64-crt/lib-common | ||||||
| 	@mkdir -p build/release/tinygo/lib/mingw-w64/mingw-w64-headers/defaults | 	@mkdir -p build/release/tinygo/lib/mingw-w64/mingw-w64-headers/defaults | ||||||
|  | @ -641,9 +640,6 @@ endif | ||||||
| 	@cp -p $(abspath $(CLANG_SRC))/lib/Headers/*.h build/release/tinygo/lib/clang/include | 	@cp -p $(abspath $(CLANG_SRC))/lib/Headers/*.h build/release/tinygo/lib/clang/include | ||||||
| 	@cp -rp lib/CMSIS/CMSIS/Include      build/release/tinygo/lib/CMSIS/CMSIS | 	@cp -rp lib/CMSIS/CMSIS/Include      build/release/tinygo/lib/CMSIS/CMSIS | ||||||
| 	@cp -rp lib/CMSIS/README.md          build/release/tinygo/lib/CMSIS | 	@cp -rp lib/CMSIS/README.md          build/release/tinygo/lib/CMSIS | ||||||
| 	@cp -rp lib/compiler-rt/lib/builtins build/release/tinygo/lib/compiler-rt/lib |  | ||||||
| 	@cp -rp lib/compiler-rt/LICENSE.TXT  build/release/tinygo/lib/compiler-rt |  | ||||||
| 	@cp -rp lib/compiler-rt/README.txt   build/release/tinygo/lib/compiler-rt |  | ||||||
| 	@cp -rp lib/macos-minimal-sdk/*      build/release/tinygo/lib/macos-minimal-sdk | 	@cp -rp lib/macos-minimal-sdk/*      build/release/tinygo/lib/macos-minimal-sdk | ||||||
| 	@cp -rp lib/musl/arch/aarch64        build/release/tinygo/lib/musl/arch | 	@cp -rp lib/musl/arch/aarch64        build/release/tinygo/lib/musl/arch | ||||||
| 	@cp -rp lib/musl/arch/arm            build/release/tinygo/lib/musl/arch | 	@cp -rp lib/musl/arch/arm            build/release/tinygo/lib/musl/arch | ||||||
|  | @ -680,6 +676,8 @@ endif | ||||||
| 	@cp -rp lib/picolibc/newlib/libm/common      build/release/tinygo/lib/picolibc/newlib/libm | 	@cp -rp lib/picolibc/newlib/libm/common      build/release/tinygo/lib/picolibc/newlib/libm | ||||||
| 	@cp -rp lib/picolibc-stdio.c         build/release/tinygo/lib | 	@cp -rp lib/picolibc-stdio.c         build/release/tinygo/lib | ||||||
| 	@cp -rp lib/wasi-libc/sysroot        build/release/tinygo/lib/wasi-libc/sysroot | 	@cp -rp lib/wasi-libc/sysroot        build/release/tinygo/lib/wasi-libc/sysroot | ||||||
|  | 	@cp -rp llvm-project/compiler-rt/lib/builtins build/release/tinygo/lib/compiler-rt-builtins | ||||||
|  | 	@cp -rp llvm-project/compiler-rt/LICENSE.TXT  build/release/tinygo/lib/compiler-rt-builtins | ||||||
| 	@cp -rp src                          build/release/tinygo/src | 	@cp -rp src                          build/release/tinygo/src | ||||||
| 	@cp -rp targets                      build/release/tinygo/targets | 	@cp -rp targets                      build/release/tinygo/targets | ||||||
| 	./build/tinygo build-library -target=cortex-m0     -o build/release/tinygo/pkg/thumbv6m-unknown-unknown-eabi-cortex-m0/compiler-rt     compiler-rt | 	./build/tinygo build-library -target=cortex-m0     -o build/release/tinygo/pkg/thumbv6m-unknown-unknown-eabi-cortex-m0/compiler-rt     compiler-rt | ||||||
|  |  | ||||||
|  | @ -1,7 +1,11 @@ | ||||||
| package builder | package builder | ||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
|  | 	"os" | ||||||
|  | 	"path/filepath" | ||||||
| 	"strings" | 	"strings" | ||||||
|  | 
 | ||||||
|  | 	"github.com/tinygo-org/tinygo/goenv" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| // These are the GENERIC_SOURCES according to CMakeList.txt. | // These are the GENERIC_SOURCES according to CMakeList.txt. | ||||||
|  | @ -72,6 +76,7 @@ var genericBuiltins = []string{ | ||||||
| 	"floatunsisf.c", | 	"floatunsisf.c", | ||||||
| 	"floatuntidf.c", | 	"floatuntidf.c", | ||||||
| 	"floatuntisf.c", | 	"floatuntisf.c", | ||||||
|  | 	"fp_mode.c", | ||||||
| 	//"int_util.c", | 	//"int_util.c", | ||||||
| 	"lshrdi3.c", | 	"lshrdi3.c", | ||||||
| 	"lshrti3.c", | 	"lshrti3.c", | ||||||
|  | @ -161,7 +166,15 @@ var CompilerRT = Library{ | ||||||
| 	cflags: func(target, headerPath string) []string { | 	cflags: func(target, headerPath string) []string { | ||||||
| 		return []string{"-Werror", "-Wall", "-std=c11", "-nostdlibinc"} | 		return []string{"-Werror", "-Wall", "-std=c11", "-nostdlibinc"} | ||||||
| 	}, | 	}, | ||||||
| 	sourceDir: "lib/compiler-rt/lib/builtins", | 	sourceDir: func() string { | ||||||
|  | 		llvmDir := filepath.Join(goenv.Get("TINYGOROOT"), "llvm-project/compiler-rt/lib/builtins") | ||||||
|  | 		if _, err := os.Stat(llvmDir); err == nil { | ||||||
|  | 			// Release build. | ||||||
|  | 			return llvmDir | ||||||
|  | 		} | ||||||
|  | 		// Development build. | ||||||
|  | 		return filepath.Join(goenv.Get("TINYGOROOT"), "lib/compiler-rt-builtins") | ||||||
|  | 	}, | ||||||
| 	librarySources: func(target string) []string { | 	librarySources: func(target string) []string { | ||||||
| 		builtins := append([]string{}, genericBuiltins...) // copy genericBuiltins | 		builtins := append([]string{}, genericBuiltins...) // copy genericBuiltins | ||||||
| 		if strings.HasPrefix(target, "arm") || strings.HasPrefix(target, "thumb") { | 		if strings.HasPrefix(target, "arm") || strings.HasPrefix(target, "thumb") { | ||||||
|  |  | ||||||
|  | @ -24,8 +24,8 @@ type Library struct { | ||||||
| 	// cflags returns the C flags specific to this library | 	// cflags returns the C flags specific to this library | ||||||
| 	cflags func(target, headerPath string) []string | 	cflags func(target, headerPath string) []string | ||||||
| 
 | 
 | ||||||
| 	// The source directory, relative to TINYGOROOT. | 	// The source directory. | ||||||
| 	sourceDir string | 	sourceDir func() string | ||||||
| 
 | 
 | ||||||
| 	// The source files, relative to sourceDir. | 	// The source files, relative to sourceDir. | ||||||
| 	librarySources func(target string) []string | 	librarySources func(target string) []string | ||||||
|  | @ -161,6 +161,12 @@ func (l *Library) load(config *compileopts.Config, tmpdir string) (job *compileJ | ||||||
| 	if strings.HasPrefix(target, "riscv64-") { | 	if strings.HasPrefix(target, "riscv64-") { | ||||||
| 		args = append(args, "-march=rv64gc", "-mabi=lp64") | 		args = append(args, "-march=rv64gc", "-mabi=lp64") | ||||||
| 	} | 	} | ||||||
|  | 	if strings.HasPrefix(target, "xtensa") { | ||||||
|  | 		// Hack to work around an issue in the Xtensa port: | ||||||
|  | 		// https://github.com/espressif/llvm-project/issues/52 | ||||||
|  | 		// Hopefully this will be fixed soon (LLVM 14). | ||||||
|  | 		args = append(args, "-D__ELF__") | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	var once sync.Once | 	var once sync.Once | ||||||
| 
 | 
 | ||||||
|  | @ -195,6 +201,8 @@ func (l *Library) load(config *compileopts.Config, tmpdir string) (job *compileJ | ||||||
| 		}, | 		}, | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	sourceDir := l.sourceDir() | ||||||
|  | 
 | ||||||
| 	// Create jobs to compile all sources. These jobs are depended upon by the | 	// Create jobs to compile all sources. These jobs are depended upon by the | ||||||
| 	// archive job above, so must be run first. | 	// archive job above, so must be run first. | ||||||
| 	for _, path := range l.librarySources(target) { | 	for _, path := range l.librarySources(target) { | ||||||
|  | @ -203,7 +211,7 @@ func (l *Library) load(config *compileopts.Config, tmpdir string) (job *compileJ | ||||||
| 		for strings.HasPrefix(cleanpath, "../") { | 		for strings.HasPrefix(cleanpath, "../") { | ||||||
| 			cleanpath = cleanpath[3:] | 			cleanpath = cleanpath[3:] | ||||||
| 		} | 		} | ||||||
| 		srcpath := filepath.Join(goenv.Get("TINYGOROOT"), l.sourceDir, path) | 		srcpath := filepath.Join(sourceDir, path) | ||||||
| 		objpath := filepath.Join(dir, cleanpath+".o") | 		objpath := filepath.Join(dir, cleanpath+".o") | ||||||
| 		os.MkdirAll(filepath.Dir(objpath), 0o777) | 		os.MkdirAll(filepath.Dir(objpath), 0o777) | ||||||
| 		objs = append(objs, objpath) | 		objs = append(objs, objpath) | ||||||
|  | @ -227,7 +235,7 @@ func (l *Library) load(config *compileopts.Config, tmpdir string) (job *compileJ | ||||||
| 	// (It could be done in parallel with creating the ar file, but it probably | 	// (It could be done in parallel with creating the ar file, but it probably | ||||||
| 	// won't make much of a difference in speed). | 	// won't make much of a difference in speed). | ||||||
| 	if l.crt1Source != "" { | 	if l.crt1Source != "" { | ||||||
| 		srcpath := filepath.Join(goenv.Get("TINYGOROOT"), l.sourceDir, l.crt1Source) | 		srcpath := filepath.Join(sourceDir, l.crt1Source) | ||||||
| 		job.dependencies = append(job.dependencies, &compileJob{ | 		job.dependencies = append(job.dependencies, &compileJob{ | ||||||
| 			description: "compile " + srcpath, | 			description: "compile " + srcpath, | ||||||
| 			run: func(*compileJob) error { | 			run: func(*compileJob) error { | ||||||
|  |  | ||||||
|  | @ -26,6 +26,7 @@ var MinGW = Library{ | ||||||
| 		_, err = io.Copy(outf, inf) | 		_, err = io.Copy(outf, inf) | ||||||
| 		return err | 		return err | ||||||
| 	}, | 	}, | ||||||
|  | 	sourceDir: func() string { return "" }, // unused | ||||||
| 	cflags: func(target, headerPath string) []string { | 	cflags: func(target, headerPath string) []string { | ||||||
| 		// No flags necessary because there are no files to compile. | 		// No flags necessary because there are no files to compile. | ||||||
| 		return nil | 		return nil | ||||||
|  |  | ||||||
|  | @ -104,7 +104,7 @@ var Musl = Library{ | ||||||
| 			"-fno-stack-protector", | 			"-fno-stack-protector", | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	sourceDir: "lib/musl/src", | 	sourceDir: func() string { return filepath.Join(goenv.Get("TINYGOROOT"), "lib/musl/src") }, | ||||||
| 	librarySources: func(target string) []string { | 	librarySources: func(target string) []string { | ||||||
| 		arch := compileopts.MuslArchitecture(target) | 		arch := compileopts.MuslArchitecture(target) | ||||||
| 		globs := []string{ | 		globs := []string{ | ||||||
|  |  | ||||||
|  | @ -33,7 +33,7 @@ var Picolibc = Library{ | ||||||
| 			"-I" + headerPath, | 			"-I" + headerPath, | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	sourceDir: "lib/picolibc/newlib/libc", | 	sourceDir: func() string { return filepath.Join(goenv.Get("TINYGOROOT"), "lib/picolibc/newlib/libc") }, | ||||||
| 	librarySources: func(target string) []string { | 	librarySources: func(target string) []string { | ||||||
| 		return picolibcSources | 		return picolibcSources | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
|  | @ -1 +0,0 @@ | ||||||
| Subproject commit 5bc79797e1f9184f39e1bd30fac75d995b72cea3 |  | ||||||
		Загрузка…
	
	Создание таблицы
		
		Сослаться в новой задаче
	
	 Ayke van Laethem
						Ayke van Laethem