xref: /aosp_15_r20/system/libvintf/assemble_vintf_main.cpp (revision 70a7ec852fcefd15a4fb57f8f183a8b1c3aacb08)
1*70a7ec85SAndroid Build Coastguard Worker /*
2*70a7ec85SAndroid Build Coastguard Worker  * Copyright (C) 2017 The Android Open Source Project
3*70a7ec85SAndroid Build Coastguard Worker  *
4*70a7ec85SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*70a7ec85SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*70a7ec85SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*70a7ec85SAndroid Build Coastguard Worker  *
8*70a7ec85SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*70a7ec85SAndroid Build Coastguard Worker  *
10*70a7ec85SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*70a7ec85SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*70a7ec85SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*70a7ec85SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*70a7ec85SAndroid Build Coastguard Worker  * limitations under the License.
15*70a7ec85SAndroid Build Coastguard Worker  */
16*70a7ec85SAndroid Build Coastguard Worker 
17*70a7ec85SAndroid Build Coastguard Worker #include <getopt.h>
18*70a7ec85SAndroid Build Coastguard Worker 
19*70a7ec85SAndroid Build Coastguard Worker #include <iostream>
20*70a7ec85SAndroid Build Coastguard Worker 
21*70a7ec85SAndroid Build Coastguard Worker #include <android-base/strings.h>
22*70a7ec85SAndroid Build Coastguard Worker #include <vintf/AssembleVintf.h>
23*70a7ec85SAndroid Build Coastguard Worker #include "utils.h"
24*70a7ec85SAndroid Build Coastguard Worker 
help()25*70a7ec85SAndroid Build Coastguard Worker void help() {
26*70a7ec85SAndroid Build Coastguard Worker     std::cerr << "assemble_vintf: Checks if a given manifest / matrix file is valid and \n"
27*70a7ec85SAndroid Build Coastguard Worker                  "    fill in build-time flags into the given file.\n"
28*70a7ec85SAndroid Build Coastguard Worker                  "assemble_vintf -h\n"
29*70a7ec85SAndroid Build Coastguard Worker                  "               Display this help text.\n"
30*70a7ec85SAndroid Build Coastguard Worker                  "assemble_vintf -i <input file>[:<input file>[...]] [-o <output file>] [-m]\n"
31*70a7ec85SAndroid Build Coastguard Worker                  "               [-c [<check file>]]\n"
32*70a7ec85SAndroid Build Coastguard Worker                  "               Fill in build-time flags into the given file.\n"
33*70a7ec85SAndroid Build Coastguard Worker                  "    -i <input file>[:<input file>[...]]\n"
34*70a7ec85SAndroid Build Coastguard Worker                  "               A list of input files. Format is automatically detected for the\n"
35*70a7ec85SAndroid Build Coastguard Worker                  "               first file, and the remaining files must have the same format.\n"
36*70a7ec85SAndroid Build Coastguard Worker                  "               Files other than the first file should only have <hal> defined;\n"
37*70a7ec85SAndroid Build Coastguard Worker                  "               other entries are ignored. Argument may also be specified\n"
38*70a7ec85SAndroid Build Coastguard Worker                  "               multiple times.\n"
39*70a7ec85SAndroid Build Coastguard Worker                  "    -o <output file>\n"
40*70a7ec85SAndroid Build Coastguard Worker                  "               Optional output file. If not specified, write to stdout.\n"
41*70a7ec85SAndroid Build Coastguard Worker                  "    -m\n"
42*70a7ec85SAndroid Build Coastguard Worker                  "               a compatible compatibility matrix is\n"
43*70a7ec85SAndroid Build Coastguard Worker                  "               generated instead; for example, given a device manifest,\n"
44*70a7ec85SAndroid Build Coastguard Worker                  "               a framework compatibility matrix is generated. This flag\n"
45*70a7ec85SAndroid Build Coastguard Worker                  "               is ignored when input is a compatibility matrix.\n"
46*70a7ec85SAndroid Build Coastguard Worker                  "    -c [<check file>]\n"
47*70a7ec85SAndroid Build Coastguard Worker                  "               The path of the \"check file\"; for example, this is the path\n"
48*70a7ec85SAndroid Build Coastguard Worker                  "               of the device manifest for framework compatibility matrix.\n"
49*70a7ec85SAndroid Build Coastguard Worker                  "               After writing the output file, the program checks against\n"
50*70a7ec85SAndroid Build Coastguard Worker                  "               the \"check file\", depending on environment variables.\n"
51*70a7ec85SAndroid Build Coastguard Worker                  "               - PRODUCT_ENFORCE_VINTF_MANIFEST=true: check compatibility\n"
52*70a7ec85SAndroid Build Coastguard Worker                  "               If any check fails, an error message is written to stderr.\n"
53*70a7ec85SAndroid Build Coastguard Worker                  "               Return 1.\n"
54*70a7ec85SAndroid Build Coastguard Worker                  "    --kernel=<version>:<android-base.config>[:<android-base-arch.config>[...]]\n"
55*70a7ec85SAndroid Build Coastguard Worker                  "               Add a kernel entry to framework compatibility matrix or device\n"
56*70a7ec85SAndroid Build Coastguard Worker                  "               manifest. Ignored for other input format.\n"
57*70a7ec85SAndroid Build Coastguard Worker                  "               There can be any number of --kernel for framework compatibility\n"
58*70a7ec85SAndroid Build Coastguard Worker                  "               matrix, but at most one --kernel and at most one config file for\n"
59*70a7ec85SAndroid Build Coastguard Worker                  "               device manifest.\n"
60*70a7ec85SAndroid Build Coastguard Worker                  "               <version> has format: 3.18.0\n"
61*70a7ec85SAndroid Build Coastguard Worker                  "               <android-base.config> is the location of android-base.config\n"
62*70a7ec85SAndroid Build Coastguard Worker                  "               <android-base-arch.config> is the location of an optional\n"
63*70a7ec85SAndroid Build Coastguard Worker                  "               arch-specific config fragment, more than one may be specified\n"
64*70a7ec85SAndroid Build Coastguard Worker                  "    -l, --hals-only\n"
65*70a7ec85SAndroid Build Coastguard Worker                  "               Output has only <hal> entries. Cannot be used with -n.\n"
66*70a7ec85SAndroid Build Coastguard Worker                  "    -n, --no-hals\n"
67*70a7ec85SAndroid Build Coastguard Worker                  "               Output has no <hal> entries (but all other entries).\n"
68*70a7ec85SAndroid Build Coastguard Worker                  "               Cannot be used with -l.\n"
69*70a7ec85SAndroid Build Coastguard Worker                  "    --no-kernel-requirements\n"
70*70a7ec85SAndroid Build Coastguard Worker                  "               Output has no <config> entries in <kernel>, and kernel minor\n"
71*70a7ec85SAndroid Build Coastguard Worker                  "               version is set to zero. (For example, 3.18.0).\n";
72*70a7ec85SAndroid Build Coastguard Worker }
73*70a7ec85SAndroid Build Coastguard Worker 
main(int argc,char ** argv)74*70a7ec85SAndroid Build Coastguard Worker int main(int argc, char** argv) {
75*70a7ec85SAndroid Build Coastguard Worker     using namespace ::android::vintf;
76*70a7ec85SAndroid Build Coastguard Worker     const struct option longopts[] = {{"kernel", required_argument, NULL, 'k'},
77*70a7ec85SAndroid Build Coastguard Worker                                       {"hals-only", no_argument, NULL, 'l'},
78*70a7ec85SAndroid Build Coastguard Worker                                       {"no-hals", no_argument, NULL, 'n'},
79*70a7ec85SAndroid Build Coastguard Worker                                       {"no-kernel-requirements", no_argument, NULL, 'K'},
80*70a7ec85SAndroid Build Coastguard Worker                                       {0, 0, 0, 0}};
81*70a7ec85SAndroid Build Coastguard Worker 
82*70a7ec85SAndroid Build Coastguard Worker     std::string outFilePath;
83*70a7ec85SAndroid Build Coastguard Worker     auto assembleVintf = AssembleVintf::newInstance();
84*70a7ec85SAndroid Build Coastguard Worker     int res;
85*70a7ec85SAndroid Build Coastguard Worker     while ((res = getopt_long(argc, argv, "hi:o:mc:nl", longopts, nullptr)) >= 0) {
86*70a7ec85SAndroid Build Coastguard Worker         switch (res) {
87*70a7ec85SAndroid Build Coastguard Worker             case 'i': {
88*70a7ec85SAndroid Build Coastguard Worker                 for (const auto& inFilePath : ::android::base::Split(optarg, ":")) {
89*70a7ec85SAndroid Build Coastguard Worker                     if (!assembleVintf->openInFile(inFilePath.c_str())) {
90*70a7ec85SAndroid Build Coastguard Worker                         std::cerr << "Failed to open " << inFilePath << std::endl;
91*70a7ec85SAndroid Build Coastguard Worker                         return 1;
92*70a7ec85SAndroid Build Coastguard Worker                     }
93*70a7ec85SAndroid Build Coastguard Worker                 }
94*70a7ec85SAndroid Build Coastguard Worker             } break;
95*70a7ec85SAndroid Build Coastguard Worker 
96*70a7ec85SAndroid Build Coastguard Worker             case 'o': {
97*70a7ec85SAndroid Build Coastguard Worker                 outFilePath = optarg;
98*70a7ec85SAndroid Build Coastguard Worker                 if (!assembleVintf->openOutFile(optarg)) {
99*70a7ec85SAndroid Build Coastguard Worker                     std::cerr << "Failed to open " << optarg << std::endl;
100*70a7ec85SAndroid Build Coastguard Worker                     return 1;
101*70a7ec85SAndroid Build Coastguard Worker                 }
102*70a7ec85SAndroid Build Coastguard Worker             } break;
103*70a7ec85SAndroid Build Coastguard Worker 
104*70a7ec85SAndroid Build Coastguard Worker             case 'm': {
105*70a7ec85SAndroid Build Coastguard Worker                 assembleVintf->setOutputMatrix();
106*70a7ec85SAndroid Build Coastguard Worker             } break;
107*70a7ec85SAndroid Build Coastguard Worker 
108*70a7ec85SAndroid Build Coastguard Worker             case 'c': {
109*70a7ec85SAndroid Build Coastguard Worker                 if (!assembleVintf->openCheckFile(optarg)) {
110*70a7ec85SAndroid Build Coastguard Worker                     std::cerr << "Failed to open " << optarg << std::endl;
111*70a7ec85SAndroid Build Coastguard Worker                     return 1;
112*70a7ec85SAndroid Build Coastguard Worker                 }
113*70a7ec85SAndroid Build Coastguard Worker             } break;
114*70a7ec85SAndroid Build Coastguard Worker 
115*70a7ec85SAndroid Build Coastguard Worker             case 'k': {
116*70a7ec85SAndroid Build Coastguard Worker                 if (!assembleVintf->addKernel(optarg)) {
117*70a7ec85SAndroid Build Coastguard Worker                     std::cerr << "ERROR: Unrecognized --kernel argument." << std::endl;
118*70a7ec85SAndroid Build Coastguard Worker                     return 1;
119*70a7ec85SAndroid Build Coastguard Worker                 }
120*70a7ec85SAndroid Build Coastguard Worker             } break;
121*70a7ec85SAndroid Build Coastguard Worker 
122*70a7ec85SAndroid Build Coastguard Worker             case 'l': {
123*70a7ec85SAndroid Build Coastguard Worker                 if (!assembleVintf->setHalsOnly()) {
124*70a7ec85SAndroid Build Coastguard Worker                     return 1;
125*70a7ec85SAndroid Build Coastguard Worker                 }
126*70a7ec85SAndroid Build Coastguard Worker             } break;
127*70a7ec85SAndroid Build Coastguard Worker 
128*70a7ec85SAndroid Build Coastguard Worker             case 'n': {
129*70a7ec85SAndroid Build Coastguard Worker                 if (!assembleVintf->setNoHals()) {
130*70a7ec85SAndroid Build Coastguard Worker                     return 1;
131*70a7ec85SAndroid Build Coastguard Worker                 }
132*70a7ec85SAndroid Build Coastguard Worker             } break;
133*70a7ec85SAndroid Build Coastguard Worker 
134*70a7ec85SAndroid Build Coastguard Worker             case 'K': {
135*70a7ec85SAndroid Build Coastguard Worker                 if (!assembleVintf->setNoKernelRequirements()) {
136*70a7ec85SAndroid Build Coastguard Worker                     return 1;
137*70a7ec85SAndroid Build Coastguard Worker                 }
138*70a7ec85SAndroid Build Coastguard Worker             } break;
139*70a7ec85SAndroid Build Coastguard Worker 
140*70a7ec85SAndroid Build Coastguard Worker             case 'h':
141*70a7ec85SAndroid Build Coastguard Worker             default: {
142*70a7ec85SAndroid Build Coastguard Worker                 help();
143*70a7ec85SAndroid Build Coastguard Worker                 return 1;
144*70a7ec85SAndroid Build Coastguard Worker             } break;
145*70a7ec85SAndroid Build Coastguard Worker         }
146*70a7ec85SAndroid Build Coastguard Worker     }
147*70a7ec85SAndroid Build Coastguard Worker 
148*70a7ec85SAndroid Build Coastguard Worker     bool success = assembleVintf->assemble();
149*70a7ec85SAndroid Build Coastguard Worker 
150*70a7ec85SAndroid Build Coastguard Worker     return success ? 0 : 1;
151*70a7ec85SAndroid Build Coastguard Worker }
152