From b425400e9af523f1ff99eb1d723cb907f4689429 Mon Sep 17 00:00:00 2001 From: trav90 Date: Fri, 19 Oct 2018 05:28:36 -0500 Subject: Update generate_sources_mozbuild.sh This changes generate_sources_mozbuild.sh to call generate_sources_mozbuild.py to generate sources.mozbuild and config files and removes the parts of the script that are no longer necessary. --- media/libaom/generate_sources_mozbuild.sh | 190 ++---------------------------- 1 file changed, 13 insertions(+), 177 deletions(-) (limited to 'media') diff --git a/media/libaom/generate_sources_mozbuild.sh b/media/libaom/generate_sources_mozbuild.sh index 1e0224083..6aea5f613 100755 --- a/media/libaom/generate_sources_mozbuild.sh +++ b/media/libaom/generate_sources_mozbuild.sh @@ -21,100 +21,16 @@ LIBAOM_CONFIG_DIR="config" # Print license header. # $1 - Output base name function write_license { - echo "# This file is automatically generated. Do not edit." >> $1 + echo "# This file is generated. Do not edit." >> $1 echo "" >> $1 } -# Search for source files with the same basename. -# The build does not support duplicate file names. -function find_duplicates { - local readonly duplicate_file_names=$(find \ - $BASE_DIR/$LIBAOM_SRC_DIR/aom \ - $BASE_DIR/$LIBAOM_SRC_DIR/aom_dsp \ - $BASE_DIR/$LIBAOM_SRC_DIR/av1 \ - -type f -name \*.c -o -name \*.asm | \ - xargs -I {} basename -s .c {} | \ - xargs -I {} basename -s .asm {} | \ - sort | uniq -d \ - ) - - if [ -n "${duplicate_file_names}" ]; then - echo "ERROR: DUPLICATE FILES FOUND" - for file in ${duplicate_file_names}; do - find \ - $BASE_DIR/$LIBAOM_SRC_DIR/aom \ - $BASE_DIR/$LIBAOM_SRC_DIR/aom_dsp \ - $BASE_DIR/$LIBAOM_SRC_DIR/av1 \ - -name $file\.* - done - exit 1 - fi -} - -# Generate sources.mozbuild with a list of source files. -# $1 - Array name for file list. This is processed with 'declare' below to -# regenerate the array locally. -# $2 - Variable name. -# $3 - Output file. -function write_sources { - # Convert the first argument back in to an array. - declare -a file_list=("${!1}") - - echo " '$2': [" >> "$3" - for f in $file_list - do - echo " '$LIBAOM_SRC_DIR/$f'," >> "$3" - done - echo "]," >> "$3" -} - -# Convert a list of source files into sources.mozbuild. -# $1 - Input file. -# $2 - Output prefix. -function convert_srcs_to_project_files { - # Do the following here: - # 1. Filter .c, .h, .s, .S and .asm files. - # 3. Convert .asm.s to .asm because moz.build will do the conversion. - - local source_list=$(grep -E '(\.c|\.h|\.S|\.s|\.asm)$' $1) - - # Remove aom_config.c. - source_list=$(echo "$source_list" | grep -v 'aom_config\.c') - - # The actual ARM files end in .asm. We have rules to translate them to .S - source_list=$(echo "$source_list" | sed s/\.asm\.s$/.asm/) - - # Exports - everything in aom, aom_mem, aom_ports, aom_scale - local exports_list=$(echo "$source_list" | \ - egrep '^(aom|aom_mem|aom_ports|aom_scale)/.*h$') - # but not anything in one level down, like 'internal' - exports_list=$(echo "$exports_list" | egrep -v '/(internal|src)/') - # or any of the other internal-ish header files. - exports_list=$(echo "$exports_list" | egrep -v '/(emmintrin_compat.h|mem_.*|msvc.h|aom_once.h)$') - - # Remove these files from the main list. - source_list=$(comm -23 <(echo "$source_list") <(echo "$exports_list")) - - # Write a single file that includes all source files for all archs. - local c_sources=$(echo "$source_list" | egrep '.(asm|c)$') - local exports_sources=$(echo "$exports_list" | egrep '.h$') - - write_sources exports_sources ${2}_EXPORTS "$BASE_DIR/sources.mozbuild" - write_sources c_sources ${2}_SOURCES "$BASE_DIR/sources.mozbuild" -} - -# Clean files from previous make. -function make_clean { - make clean > /dev/null - rm -f libaom_srcs.txt -} - # Print the configuration. # $1 - Header file directory. function print_config { $BASE_DIR/lint_config.sh -p \ - -h $BASE_DIR/$LIBAOM_CONFIG_DIR/$1/aom_config.h \ - -a $BASE_DIR/$LIBAOM_CONFIG_DIR/$1/aom_config.asm + -h $BASE_DIR/$LIBAOM_CONFIG_DIR/$1/config/aom_config.h \ + -a $BASE_DIR/$LIBAOM_CONFIG_DIR/$1/config/aom_config.asm } # Generate *_rtcd.h files. @@ -126,8 +42,8 @@ function gen_rtcd_header { rm -rf $TEMP_DIR/libaom.config $BASE_DIR/lint_config.sh -p \ - -h $BASE_DIR/$LIBAOM_CONFIG_DIR/$1/aom_config.h \ - -a $BASE_DIR/$LIBAOM_CONFIG_DIR/$1/aom_config.asm \ + -h $BASE_DIR/$LIBAOM_CONFIG_DIR/$1/config/aom_config.h \ + -a $BASE_DIR/$LIBAOM_CONFIG_DIR/$1/config/aom_config.asm \ -o $TEMP_DIR/libaom.config $BASE_DIR/$LIBAOM_SRC_DIR/build/make/rtcd.pl \ @@ -135,76 +51,33 @@ function gen_rtcd_header { --sym=aom_rtcd $3 \ --config=$TEMP_DIR/libaom.config \ $BASE_DIR/$LIBAOM_SRC_DIR/av1/common/av1_rtcd_defs.pl \ - > $BASE_DIR/$LIBAOM_CONFIG_DIR/$1/av1_rtcd.h + > $BASE_DIR/$LIBAOM_CONFIG_DIR/$1/config/av1_rtcd.h $BASE_DIR/$LIBAOM_SRC_DIR/build/make/rtcd.pl \ --arch=$2 \ --sym=aom_scale_rtcd $3 \ --config=$TEMP_DIR/libaom.config \ $BASE_DIR/$LIBAOM_SRC_DIR/aom_scale/aom_scale_rtcd.pl \ - > $BASE_DIR/$LIBAOM_CONFIG_DIR/$1/aom_scale_rtcd.h + > $BASE_DIR/$LIBAOM_CONFIG_DIR/$1/config/aom_scale_rtcd.h $BASE_DIR/$LIBAOM_SRC_DIR/build/make/rtcd.pl \ --arch=$2 \ --sym=aom_dsp_rtcd $3 \ --config=$TEMP_DIR/libaom.config \ $BASE_DIR/$LIBAOM_SRC_DIR/aom_dsp/aom_dsp_rtcd_defs.pl \ - > $BASE_DIR/$LIBAOM_CONFIG_DIR/$1/aom_dsp_rtcd.h + > $BASE_DIR/$LIBAOM_CONFIG_DIR/$1/config/aom_dsp_rtcd.h rm -rf $TEMP_DIR/libaom.config } -# Generate Config files. "--enable-external-build" must be set to skip -# detection of capabilities on specific targets. -# $1 - Header file directory. -# $2 - Config command line. -function gen_config_files { - ./configure $2 #> /dev/null - - # Disable HAVE_UNISTD_H. - ( echo '/HAVE_UNISTD_H'; echo 'd' ; echo 'w' ; echo 'q' ) | ed -s aom_config.h - - local ASM_CONV=ads2gas.pl - - # Generate aom_config.asm. - if [[ "$1" == *x64* ]] || [[ "$1" == *ia32* ]] || [[ "$1" == *mingw* ]]; then - egrep "#define [A-Z0-9_]+ [01]" aom_config.h | awk '{print $2 " equ " $3}' > aom_config.asm - else - egrep "#define [A-Z0-9_]+ [01]" aom_config.h | awk '{print $2 " EQU " $3}' | perl $BASE_DIR/$LIBAOM_SRC_DIR/build/make/$ASM_CONV > aom_config.asm - fi - - mkdir -p $BASE_DIR/$LIBAOM_CONFIG_DIR/$1 - cp aom_config.* $BASE_DIR/$LIBAOM_CONFIG_DIR/$1 - make_clean - rm -rf aom_config.* -} - -find_duplicates - -echo "Creating temporary directory." -TEMP_DIR="$BASE_DIR/.temp" -rm -rf $TEMP_DIR -cp -R $LIBAOM_SRC_DIR $TEMP_DIR -cd $TEMP_DIR - echo "Generating config files." -all_platforms="--enable-external-build --disable-examples --disable-docs --disable-unit-tests" -all_platforms="${all_platforms} --size-limit=8192x4608 --enable-pic" -x86_platforms="--enable-postproc --as=yasm" -arm_platforms="--enable-runtime-cpu-detect --enable-realtime-only" -gen_config_files linux/x64 "--target=x86_64-linux-gcc ${all_platforms} ${x86_platforms}" -gen_config_files linux/ia32 "--target=x86-linux-gcc ${all_platforms} ${x86_platforms}" -gen_config_files mac/x64 "--target=x86_64-darwin9-gcc ${all_platforms} ${x86_platforms}" -gen_config_files win/x64 "--target=x86_64-win64-vs12 ${all_platforms} ${x86_platforms}" -gen_config_files win/ia32 "--target=x86-win32-gcc ${all_platforms} ${x86_platforms}" -gen_config_files win/mingw32 "--target=x86-win32-gcc ${all_platforms} ${x86_platforms}" - -gen_config_files linux/arm "--target=armv7-linux-gcc ${all_platforms} ${arm_platforms}" +cd $BASE_DIR +python generate_sources_mozbuild.py -gen_config_files generic "--target=generic-gnu ${all_platforms}" +# Copy aom_version.h once. The file is the same for all platforms. +cp aom_version.h $BASE_DIR/$LIBAOM_CONFIG_DIR echo "Remove temporary directory." -cd $BASE_DIR rm -rf $TEMP_DIR echo "Create temporary directory." @@ -219,49 +92,12 @@ gen_rtcd_header mac/x64 x86_64 gen_rtcd_header win/x64 x86_64 gen_rtcd_header win/ia32 x86 gen_rtcd_header win/mingw32 x86 +gen_rtcd_header win/mingw64 x86_64 gen_rtcd_header linux/arm armv7 gen_rtcd_header generic generic -echo "Prepare Makefile." -./configure --target=generic-gnu > /dev/null -make_clean - -# Remove existing source files. -rm -rf $BASE_DIR/sources.mozbuild -write_license $BASE_DIR/sources.mozbuild -echo "files = {" >> $BASE_DIR/sources.mozbuild - -echo "Generate X86_64 source list." -config=$(print_config linux/x64) -make_clean -make libaom_srcs.txt target=libs $config > /dev/null -convert_srcs_to_project_files libaom_srcs.txt X64 - -# Copy aom_version.h once. The file is the same for all platforms. -cp aom_version.h $BASE_DIR/$LIBAOM_CONFIG_DIR - -echo "Generate IA32 source list." -config=$(print_config linux/ia32) -make_clean -make libaom_srcs.txt target=libs $config > /dev/null -convert_srcs_to_project_files libaom_srcs.txt IA32 - -echo "Generate ARM source list." -config=$(print_config linux/arm) -make_clean -make libaom_srcs.txt target=libs $config > /dev/null -convert_srcs_to_project_files libaom_srcs.txt ARM - -echo "Generate generic source list." -config=$(print_config generic) -make_clean -make libaom_srcs.txt target=libs $config > /dev/null -convert_srcs_to_project_files libaom_srcs.txt GENERIC - -echo "}" >> $BASE_DIR/sources.mozbuild - echo "Remove temporary directory." cd $BASE_DIR rm -rf $TEMP_DIR -- cgit v1.2.3