Merge "cc_fuzz: add "data" field" am: 3606b00176 am: e6f58d4a61
				
					
				
			Change-Id: I20f7373e4a6f90b96ad5072032bfb32ff2889a42
This commit is contained in:
		| @@ -317,6 +317,11 @@ func (fuzz *fuzzBinary) AndroidMk(ctx AndroidMkContext, ret *android.AndroidMkDa | |||||||
| 			filepath.Dir(fuzz.corpusIntermediateDir.String())+":corpus/"+d.Base()) | 			filepath.Dir(fuzz.corpusIntermediateDir.String())+":corpus/"+d.Base()) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	for _, d := range fuzz.data { | ||||||
|  | 		fuzzFiles = append(fuzzFiles, | ||||||
|  | 			filepath.Dir(fuzz.dataIntermediateDir.String())+":data/"+d.Rel()) | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	if fuzz.dictionary != nil { | 	if fuzz.dictionary != nil { | ||||||
| 		fuzzFiles = append(fuzzFiles, | 		fuzzFiles = append(fuzzFiles, | ||||||
| 			filepath.Dir(fuzz.dictionary.String())+":"+fuzz.dictionary.Base()) | 			filepath.Dir(fuzz.dictionary.String())+":"+fuzz.dictionary.Base()) | ||||||
|   | |||||||
							
								
								
									
										29
									
								
								cc/fuzz.go
									
									
									
									
									
								
							
							
						
						
									
										29
									
								
								cc/fuzz.go
									
									
									
									
									
								
							| @@ -49,6 +49,9 @@ type FuzzProperties struct { | |||||||
| 	// Optional list of seed files to be installed to the fuzz target's output | 	// Optional list of seed files to be installed to the fuzz target's output | ||||||
| 	// directory. | 	// directory. | ||||||
| 	Corpus []string `android:"path"` | 	Corpus []string `android:"path"` | ||||||
|  | 	// Optional list of data files to be installed to the fuzz target's output | ||||||
|  | 	// directory. Directory structure relative to the module is preserved. | ||||||
|  | 	Data []string `android:"path"` | ||||||
| 	// Optional dictionary to be installed to the fuzz target's output directory. | 	// Optional dictionary to be installed to the fuzz target's output directory. | ||||||
| 	Dictionary *string `android:"path"` | 	Dictionary *string `android:"path"` | ||||||
| 	// Config for running the target on fuzzing infrastructure. | 	// Config for running the target on fuzzing infrastructure. | ||||||
| @@ -81,6 +84,8 @@ type fuzzBinary struct { | |||||||
| 	corpus                android.Paths | 	corpus                android.Paths | ||||||
| 	corpusIntermediateDir android.Path | 	corpusIntermediateDir android.Path | ||||||
| 	config                android.Path | 	config                android.Path | ||||||
|  | 	data                  android.Paths | ||||||
|  | 	dataIntermediateDir   android.Path | ||||||
| 	installedSharedDeps   []string | 	installedSharedDeps   []string | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -210,6 +215,17 @@ func (fuzz *fuzzBinary) install(ctx ModuleContext, file android.Path) { | |||||||
| 	builder.Build(pctx, ctx, "copy_corpus", "copy corpus") | 	builder.Build(pctx, ctx, "copy_corpus", "copy corpus") | ||||||
| 	fuzz.corpusIntermediateDir = intermediateDir | 	fuzz.corpusIntermediateDir = intermediateDir | ||||||
|  |  | ||||||
|  | 	fuzz.data = android.PathsForModuleSrc(ctx, fuzz.Properties.Data) | ||||||
|  | 	builder = android.NewRuleBuilder() | ||||||
|  | 	intermediateDir = android.PathForModuleOut(ctx, "data") | ||||||
|  | 	for _, entry := range fuzz.data { | ||||||
|  | 		builder.Command().Text("cp"). | ||||||
|  | 			Input(entry). | ||||||
|  | 			Output(intermediateDir.Join(ctx, entry.Rel())) | ||||||
|  | 	} | ||||||
|  | 	builder.Build(pctx, ctx, "copy_data", "copy data") | ||||||
|  | 	fuzz.dataIntermediateDir = intermediateDir | ||||||
|  |  | ||||||
| 	if fuzz.Properties.Dictionary != nil { | 	if fuzz.Properties.Dictionary != nil { | ||||||
| 		fuzz.dictionary = android.PathForModuleSrc(ctx, *fuzz.Properties.Dictionary) | 		fuzz.dictionary = android.PathForModuleSrc(ctx, *fuzz.Properties.Dictionary) | ||||||
| 		if fuzz.dictionary.Ext() != ".dict" { | 		if fuzz.dictionary.Ext() != ".dict" { | ||||||
| @@ -377,6 +393,19 @@ func (s *fuzzPackager) GenerateBuildActions(ctx android.SingletonContext) { | |||||||
| 			files = append(files, fileToZip{corpusZip, ""}) | 			files = append(files, fileToZip{corpusZip, ""}) | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|  | 		// Package the data into a zipfile. | ||||||
|  | 		if fuzzModule.data != nil { | ||||||
|  | 			dataZip := archDir.Join(ctx, module.Name()+"_data.zip") | ||||||
|  | 			command := builder.Command().BuiltTool(ctx, "soong_zip"). | ||||||
|  | 				FlagWithOutput("-o ", dataZip) | ||||||
|  | 			for _, f := range fuzzModule.data { | ||||||
|  | 				intermediateDir := strings.TrimSuffix(f.String(), f.Rel()) | ||||||
|  | 				command.FlagWithArg("-C ", intermediateDir) | ||||||
|  | 				command.FlagWithInput("-f ", f) | ||||||
|  | 			} | ||||||
|  | 			files = append(files, fileToZip{dataZip, ""}) | ||||||
|  | 		} | ||||||
|  |  | ||||||
| 		// Find and mark all the transiently-dependent shared libraries for | 		// Find and mark all the transiently-dependent shared libraries for | ||||||
| 		// packaging. | 		// packaging. | ||||||
| 		for _, library := range sharedLibraries { | 		for _, library := range sharedLibraries { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user