Merge "[NETD-BPF#34] Add a tag for bpf to specify the install folder" am: a9a5d36884 am: 9624d183f4 am: 7b49b608f6 am: 1a1604f9c6
				
					
				
			Original change: https://android-review.googlesource.com/c/platform/build/soong/+/1888356 Change-Id: Ic82782a7a0f56a34881961cdee2b4c82bff893e5
This commit is contained in:
		| @@ -1612,8 +1612,8 @@ func apexFileForRuntimeResourceOverlay(ctx android.BaseModuleContext, rro java.R | ||||
| 	return af | ||||
| } | ||||
|  | ||||
| func apexFileForBpfProgram(ctx android.BaseModuleContext, builtFile android.Path, bpfProgram bpf.BpfModule) apexFile { | ||||
| 	dirInApex := filepath.Join("etc", "bpf") | ||||
| func apexFileForBpfProgram(ctx android.BaseModuleContext, builtFile android.Path, apex_sub_dir string, bpfProgram bpf.BpfModule) apexFile { | ||||
| 	dirInApex := filepath.Join("etc", "bpf", apex_sub_dir) | ||||
| 	return newApexFile(ctx, builtFile, builtFile.Base(), dirInApex, etc, bpfProgram) | ||||
| } | ||||
|  | ||||
| @@ -1831,8 +1831,9 @@ func (a *apexBundle) GenerateAndroidBuildActions(ctx android.ModuleContext) { | ||||
| 			case bpfTag: | ||||
| 				if bpfProgram, ok := child.(bpf.BpfModule); ok { | ||||
| 					filesToCopy, _ := bpfProgram.OutputFiles("") | ||||
| 					apex_sub_dir := bpfProgram.SubDir() | ||||
| 					for _, bpfFile := range filesToCopy { | ||||
| 						filesInfo = append(filesInfo, apexFileForBpfProgram(ctx, bpfFile, bpfProgram)) | ||||
| 						filesInfo = append(filesInfo, apexFileForBpfProgram(ctx, bpfFile, apex_sub_dir, bpfProgram)) | ||||
| 					} | ||||
| 				} else { | ||||
| 					ctx.PropertyErrorf("bpfs", "%q is not a bpf module", depName) | ||||
|   | ||||
| @@ -623,7 +623,7 @@ func TestDefaults(t *testing.T) { | ||||
| 			java_libs: ["myjar"], | ||||
| 			apps: ["AppFoo"], | ||||
| 			rros: ["rro"], | ||||
| 			bpfs: ["bpf"], | ||||
| 			bpfs: ["bpf", "netd_test"], | ||||
| 			updatable: false, | ||||
| 		} | ||||
|  | ||||
| @@ -676,6 +676,12 @@ func TestDefaults(t *testing.T) { | ||||
| 			srcs: ["bpf.c", "bpf2.c"], | ||||
| 		} | ||||
|  | ||||
| 		bpf { | ||||
| 			name: "netd_test", | ||||
| 			srcs: ["netd_test.c"], | ||||
| 			sub_dir: "netd", | ||||
| 		} | ||||
|  | ||||
| 	`) | ||||
| 	ensureExactContents(t, ctx, "myapex", "android_common_myapex_image", []string{ | ||||
| 		"etc/myetc", | ||||
| @@ -685,6 +691,7 @@ func TestDefaults(t *testing.T) { | ||||
| 		"overlay/blue/rro.apk", | ||||
| 		"etc/bpf/bpf.o", | ||||
| 		"etc/bpf/bpf2.o", | ||||
| 		"etc/bpf/netd/netd_test.o", | ||||
| 	}) | ||||
| } | ||||
|  | ||||
|   | ||||
							
								
								
									
										14
									
								
								bpf/bpf.go
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								bpf/bpf.go
									
									
									
									
									
								
							| @@ -54,12 +54,16 @@ type BpfModule interface { | ||||
| 	android.Module | ||||
|  | ||||
| 	OutputFiles(tag string) (android.Paths, error) | ||||
|  | ||||
| 	// Returns the sub install directory if the bpf module is included by apex. | ||||
| 	SubDir() string | ||||
| } | ||||
|  | ||||
| type BpfProperties struct { | ||||
| 	Srcs         []string `android:"path"` | ||||
| 	Cflags       []string | ||||
| 	Include_dirs []string | ||||
| 	Sub_dir      string | ||||
| } | ||||
|  | ||||
| type bpf struct { | ||||
| @@ -121,6 +125,10 @@ func (bpf *bpf) AndroidMk() android.AndroidMkData { | ||||
| 			fmt.Fprintln(w) | ||||
| 			fmt.Fprintln(w, "LOCAL_PATH :=", moduleDir) | ||||
| 			fmt.Fprintln(w) | ||||
| 			localModulePath := "LOCAL_MODULE_PATH := $(TARGET_OUT_ETC)/bpf" | ||||
| 			if len(bpf.properties.Sub_dir) > 0 { | ||||
| 				localModulePath += "/" + bpf.properties.Sub_dir | ||||
| 			} | ||||
| 			for _, obj := range bpf.objs { | ||||
| 				objName := name + "_" + obj.Base() | ||||
| 				names = append(names, objName) | ||||
| @@ -130,7 +138,7 @@ func (bpf *bpf) AndroidMk() android.AndroidMkData { | ||||
| 				fmt.Fprintln(w, "LOCAL_PREBUILT_MODULE_FILE :=", obj.String()) | ||||
| 				fmt.Fprintln(w, "LOCAL_MODULE_STEM :=", obj.Base()) | ||||
| 				fmt.Fprintln(w, "LOCAL_MODULE_CLASS := ETC") | ||||
| 				fmt.Fprintln(w, "LOCAL_MODULE_PATH := $(TARGET_OUT_ETC)/bpf") | ||||
| 				fmt.Fprintln(w, localModulePath) | ||||
| 				fmt.Fprintln(w, "include $(BUILD_PREBUILT)") | ||||
| 				fmt.Fprintln(w) | ||||
| 			} | ||||
| @@ -154,6 +162,10 @@ func (bpf *bpf) OutputFiles(tag string) (android.Paths, error) { | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func (bpf *bpf) SubDir() string { | ||||
| 	return bpf.properties.Sub_dir | ||||
| } | ||||
|  | ||||
| var _ android.OutputFileProducer = (*bpf)(nil) | ||||
|  | ||||
| func BpfFactory() android.Module { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user