Merge changes Idea4f04c,I3b85ef66
* changes: Add $$ORIGIN/lib to rpath for fuzz targets. Prebuilt shared libraries should be collected for fuzz targets.
This commit is contained in:
		
							
								
								
									
										24
									
								
								cc/fuzz.go
									
									
									
									
									
								
							
							
						
						
									
										24
									
								
								cc/fuzz.go
									
									
									
									
									
								
							| @@ -103,8 +103,11 @@ func (fuzz *fuzzBinary) linkerDeps(ctx DepsContext, deps Deps) Deps { | |||||||
|  |  | ||||||
| func (fuzz *fuzzBinary) linkerFlags(ctx ModuleContext, flags Flags) Flags { | func (fuzz *fuzzBinary) linkerFlags(ctx ModuleContext, flags Flags) Flags { | ||||||
| 	flags = fuzz.binaryDecorator.linkerFlags(ctx, flags) | 	flags = fuzz.binaryDecorator.linkerFlags(ctx, flags) | ||||||
| 	// RunPaths on devices isn't instantiated by the base linker. | 	// RunPaths on devices isn't instantiated by the base linker. `../lib` for | ||||||
|  | 	// installed fuzz targets (both host and device), and `./lib` for fuzz | ||||||
|  | 	// target packages. | ||||||
| 	flags.Local.LdFlags = append(flags.Local.LdFlags, `-Wl,-rpath,\$$ORIGIN/../lib`) | 	flags.Local.LdFlags = append(flags.Local.LdFlags, `-Wl,-rpath,\$$ORIGIN/../lib`) | ||||||
|  | 	flags.Local.LdFlags = append(flags.Local.LdFlags, `-Wl,-rpath,\$$ORIGIN/lib`) | ||||||
| 	return flags | 	return flags | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -123,19 +126,23 @@ func collectAllSharedDependencies( | |||||||
| 	// Enumerate the first level of dependencies, as we discard all non-library | 	// Enumerate the first level of dependencies, as we discard all non-library | ||||||
| 	// modules in the BFS loop below. | 	// modules in the BFS loop below. | ||||||
| 	ctx.VisitDirectDeps(module, func(dep android.Module) { | 	ctx.VisitDirectDeps(module, func(dep android.Module) { | ||||||
|  | 		if isValidSharedDependency(dep, sharedDeps) { | ||||||
| 			fringe = append(fringe, dep) | 			fringe = append(fringe, dep) | ||||||
|  | 		} | ||||||
| 	}) | 	}) | ||||||
|  |  | ||||||
| 	for i := 0; i < len(fringe); i++ { | 	for i := 0; i < len(fringe); i++ { | ||||||
| 		module := fringe[i] | 		module := fringe[i] | ||||||
| 		if !isValidSharedDependency(module, sharedDeps) { | 		if _, exists := sharedDeps[module.Name()]; exists { | ||||||
| 			continue | 			continue | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		ccModule := module.(*Module) | 		ccModule := module.(*Module) | ||||||
| 		sharedDeps[ccModule.Name()] = ccModule.UnstrippedOutputFile() | 		sharedDeps[ccModule.Name()] = ccModule.UnstrippedOutputFile() | ||||||
| 		ctx.VisitDirectDeps(module, func(dep android.Module) { | 		ctx.VisitDirectDeps(module, func(dep android.Module) { | ||||||
|  | 			if isValidSharedDependency(dep, sharedDeps) { | ||||||
| 				fringe = append(fringe, dep) | 				fringe = append(fringe, dep) | ||||||
|  | 			} | ||||||
| 		}) | 		}) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| @@ -155,10 +162,21 @@ func isValidSharedDependency( | |||||||
| 	if linkable, ok := dependency.(LinkableInterface); !ok || // Discard non-linkables. | 	if linkable, ok := dependency.(LinkableInterface); !ok || // Discard non-linkables. | ||||||
| 		!linkable.CcLibraryInterface() || !linkable.Shared() || // Discard static libs. | 		!linkable.CcLibraryInterface() || !linkable.Shared() || // Discard static libs. | ||||||
| 		linkable.UseVndk() || // Discard vendor linked libraries. | 		linkable.UseVndk() || // Discard vendor linked libraries. | ||||||
| 		!linkable.CcLibrary() || linkable.BuildStubs() { // Discard stubs libs (only CCLibrary variants). | 		// Discard stubs libs (only CCLibrary variants). Prebuilt libraries should not | ||||||
|  | 		// be excluded on the basis of they're not CCLibrary()'s. | ||||||
|  | 		(linkable.CcLibrary() && linkable.BuildStubs()) { | ||||||
| 		return false | 		return false | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	// We discarded module stubs libraries above, but the LLNDK prebuilts stubs | ||||||
|  | 	// libraries must be handled differently - by looking for the stubDecorator. | ||||||
|  | 	// Discard LLNDK prebuilts stubs as well. | ||||||
|  | 	if ccLibrary, isCcLibrary := dependency.(*Module); isCcLibrary { | ||||||
|  | 		if _, isLLndkStubLibrary := ccLibrary.linker.(*stubDecorator); isLLndkStubLibrary { | ||||||
|  | 			return false | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	// If this library has already been traversed, we don't need to do any more work. | 	// If this library has already been traversed, we don't need to do any more work. | ||||||
| 	if _, exists := sharedDeps[dependency.Name()]; exists { | 	if _, exists := sharedDeps[dependency.Name()]; exists { | ||||||
| 		return false | 		return false | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user