diff options
author | Mark Salyzyn <salyzyn@google.com> | 2015-04-16 00:15:47 +0000 |
---|---|---|
committer | Android Git Automerger <android-git-automerger@android.com> | 2015-04-16 00:15:47 +0000 |
commit | d756e7367ab60d5e4138d7561aaabf4256e3d247 (patch) | |
tree | ca9b8578e4a8fac90cd27442baf2e47d57a4f61f | |
parent | 54c1d36eaee59c62a652b071bdec9e71c40002ae (diff) | |
parent | c9402076b65025c994c28bac0350d5b600d1d6fe (diff) | |
download | build-d756e7367ab60d5e4138d7561aaabf4256e3d247.zip build-d756e7367ab60d5e4138d7561aaabf4256e3d247.tar.gz build-d756e7367ab60d5e4138d7561aaabf4256e3d247.tar.bz2 |
am c9402076: am 7a1d4d5e: Merge "fs_config: Add fs_config_generate"
* commit 'c9402076b65025c994c28bac0350d5b600d1d6fe':
fs_config: Add fs_config_generate
-rw-r--r-- | tools/fs_config/Android.mk | 61 | ||||
-rw-r--r-- | tools/fs_config/default/android_filesystem_config.h | 44 | ||||
-rw-r--r-- | tools/fs_config/fs_config_generate.c | 128 |
3 files changed, 233 insertions, 0 deletions
diff --git a/tools/fs_config/Android.mk b/tools/fs_config/Android.mk index 3e16962..34a3522 100644 --- a/tools/fs_config/Android.mk +++ b/tools/fs_config/Android.mk @@ -22,3 +22,64 @@ LOCAL_SHARED_LIBRARIES := libcutils libselinux LOCAL_CFLAGS := -Werror include $(BUILD_HOST_EXECUTABLE) + +# To Build the custom target binary for the host to generate the fs_config +# override files. The executable is hard coded to include the +# $(TARGET_ANDROID_FILESYSTEM_CONFIG_H) file if it exists. +# Expectations: +# device/<vendor>/<device>/android_filesystem_config.h +# fills in struct fs_path_config android_device_dirs[] and +# struct fs_path_config android_device_files[] +# device/<vendor>/<device>/device.mk +# PRODUCT_PACKAGES += fs_config_dirs fs_config_files + +# If not specified, check if default one to be found +ANDROID_FS_CONFIG_H := android_filesystem_config.h + +ifneq ($(TARGET_ANDROID_FILESYSTEM_CONFIG_H),) +ifeq ($(filter %/$(ANDROID_FS_CONFIG_H),$(TARGET_ANDROID_FILESYSTEM_CONFIG_H)),) +$(error TARGET_ANDROID_FILESYSTEM_CONFIG_H file name must be $(ANDROID_FS_CONFIG_H), \ + see "$(notdir $(TARGET_ANDROID_FILESYSTEM_CONFIG_H))".) +endif + +my_fs_config_h := $(TARGET_ANDROID_FILESYSTEM_CONFIG_H) +else ifneq ($(wildcard $(TARGET_DEVICE_DIR)/$(ANDROID_FS_CONFIG_H)),) +my_fs_config_h := $(TARGET_DEVICE_DIR)/$(ANDROID_FS_CONFIG_H) +else +my_fs_config_h := $(LOCAL_PATH)/default/$(ANDROID_FS_CONFIG_H) +endif + +include $(CLEAR_VARS) +LOCAL_SRC_FILES := fs_config_generate.c +LOCAL_MODULE := fs_config_generate_$(TARGET_DEVICE) +LOCAL_SHARED_LIBRARIES := libcutils +LOCAL_CFLAGS := -Werror -Wno-error=\#warnings +LOCAL_C_INCLUDES := $(dir $(my_fs_config_h)) +include $(BUILD_HOST_EXECUTABLE) +fs_config_generate_bin := $(LOCAL_INSTALLED_MODULE) + +# Generate the system/etc/fs_config_dirs binary file for the target +# Add fs_config_dirs to PRODUCT_PACKAGES in the device make file to enable +include $(CLEAR_VARS) + +LOCAL_MODULE := fs_config_dirs +LOCAL_MODULE_CLASS := ETC +include $(BUILD_SYSTEM)/base_rules.mk +$(LOCAL_BUILT_MODULE): $(fs_config_generate_bin) + @mkdir -p $(dir $@) + $< -D -o $@ + +# Generate the system/etc/fs_config_files binary file for the target +# Add fs_config_files to PRODUCT_PACKAGES in the device make file to enable +include $(CLEAR_VARS) + +LOCAL_MODULE := fs_config_files +LOCAL_MODULE_CLASS := ETC +include $(BUILD_SYSTEM)/base_rules.mk +$(LOCAL_BUILT_MODULE): $(fs_config_generate_bin) + @mkdir -p $(dir $@) + $< -F -o $@ + +ANDROID_FS_CONFIG_H := +my_fs_config_h := +fs_config_generate_bin := diff --git a/tools/fs_config/default/android_filesystem_config.h b/tools/fs_config/default/android_filesystem_config.h new file mode 100644 index 0000000..820b04a --- /dev/null +++ b/tools/fs_config/default/android_filesystem_config.h @@ -0,0 +1,44 @@ +/* + * Copyright (C) 2015 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* This file is used to enhance the properties of the filesystem +** images generated by build tools (mkbootfs and mkyaffs2image) and +** by the device side of adb. +*/ + +/* +** Resorting to the default file means someone requested fs_config_dirs or +** fs_config_files in their device configuration without providing an +** associated header. +*/ +#warning No device-supplied android_filesystem_config.h, using empty default. + +/* Rules for directories. +** These rules are applied based on "first match", so they +** should start with the most specific path and work their +** way up to the root. +*/ + +#define NO_ANDROID_FILESYSTEM_CONFIG_DEVICE_DIRS 1 /* opt out of specifying */ + +/* Rules for files. +** These rules are applied based on "first match", so they +** should start with the most specific path and work their +** way up to the root. Prefixes ending in * denotes wildcard +** and will allow partial matches. +*/ + +#define NO_ANDROID_FILESYSTEM_CONFIG_DEVICE_FILES 1 /* opt out of specifying */ diff --git a/tools/fs_config/fs_config_generate.c b/tools/fs_config/fs_config_generate.c new file mode 100644 index 0000000..87769c7 --- /dev/null +++ b/tools/fs_config/fs_config_generate.c @@ -0,0 +1,128 @@ +/* + * Copyright (C) 2015 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include <stdbool.h> +#include <stdio.h> +#include <stdlib.h> +#include <unistd.h> + +#include <private/android_filesystem_config.h> + +/* + * This program expects android_device_dirs and android_device_files + * to be defined in the supplied android_filesystem_config.h file in + * the device/<vendor>/<product> $(TARGET_DEVICE_DIR). Then generates + * the binary format used in the /system/etc/fs_config_dirs and + * the /system/etc/fs_config_files to be used by the runtimes. + */ +#include "android_filesystem_config.h" + +#ifdef NO_ANDROID_FILESYSTEM_CONFIG_DEVICE_DIRS + static const struct fs_path_config android_device_dirs[] = { +}; +#endif + +#ifdef NO_ANDROID_FILESYSTEM_CONFIG_DEVICE_FILES +static const struct fs_path_config android_device_files[] = { +#ifdef NO_ANDROID_FILESYSTEM_CONFIG_DEVICE_DIRS + { 0, AID_ROOT, AID_ROOT, 0, "system/etc/fs_config_dirs" }, +#endif + { 0, AID_ROOT, AID_ROOT, 0, "system/etc/fs_config_files" }, +}; +#endif + +static void usage() { + fprintf(stderr, + "Generate binary content for fs_config_dirs (-D) and fs_config_files (-F)\n" + "from device-specific android_filesystem_config.h override\n\n" + "Usage: fs_config_generate -D|-F [-o output-file]\n"); +} + +int main(int argc, char** argv) { + const struct fs_path_config *pc; + const struct fs_path_config *end; + bool dir = false, file = false; + FILE *fp = stdout; + int opt; + + while((opt = getopt(argc, argv, "DFho:")) != -1) { + switch(opt) { + case 'D': + if (file) { + fprintf(stderr, "Must specify only -D or -F\n"); + usage(); + exit(EXIT_FAILURE); + } + dir = true; + break; + case 'F': + if (dir) { + fprintf(stderr, "Must specify only -F or -D\n"); + usage(); + exit(EXIT_FAILURE); + } + file = true; + break; + case 'o': + if (fp != stdout) { + fprintf(stderr, "Specify only one output file\n"); + usage(); + exit(EXIT_FAILURE); + } + fp = fopen(optarg, "w"); + if (fp == NULL) { + fprintf(stderr, "Can not open \"%s\"\n", optarg); + exit(EXIT_FAILURE); + } + break; + case 'h': + usage(); + exit(EXIT_SUCCESS); + default: + usage(); + exit(EXIT_FAILURE); + } + } + + if (!file && !dir) { + fprintf(stderr, "Must specify either -F or -D\n"); + usage(); + exit(EXIT_FAILURE); + } + + if (dir) { + pc = android_device_dirs; + end = &android_device_dirs[sizeof(android_device_dirs) / sizeof(android_device_dirs[0])]; + } else { + pc = android_device_files; + end = &android_device_files[sizeof(android_device_files) / sizeof(android_device_files[0])]; + } + for(; (pc < end) && pc->prefix; pc++) { + char buffer[512]; + ssize_t len = fs_config_generate(buffer, sizeof(buffer), pc); + if (len < 0) { + fprintf(stderr, "Entry too large\n"); + exit(EXIT_FAILURE); + } + if (fwrite(buffer, 1, len, fp) != (size_t)len) { + fprintf(stderr, "Write failure\n"); + exit(EXIT_FAILURE); + } + } + fclose(fp); + + return 0; +} |