/* * Copyright 2016 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 <map> #include <android-base/logging.h> #include <getopt.h> #include <android-base/logging.h> #include "TcpServerForRunner.h" static constexpr const char* kDefaultSpecDirPath = "/data/local/tmp/spec/"; static constexpr const char* kDefaultHalDriverPath32 = "./vts_hal_driver32"; static constexpr const char* kDefaultHalDriverPath64 = "./vts_hal_driver64"; static constexpr const char* kDefaultShellDriverPath32 = "./vts_shell_driver32"; static constexpr const char* kDefaultShellDriverPath64 = "./vts_shell_driver64"; using namespace std; void ShowUsage() { printf( "Usage: vts_hal_agent [options]\n" "--hal_driver_path_32: Set 32 bit hal driver binary path.\n" "--hal_driver_path_32: Set 64 bit hal driver binary path.\n" "--spec_dir: Set vts spec directory. \n" "--shell_driver_path_32: Set 32 bit shell driver binary path\n" "--shell_driver_path_64: Set 64 bit shell driver binary path\n" "--log_severity: Set log severity\n" "--help: Show help\n"); exit(1); } int main(int argc, char** argv) { string hal_driver_path32 = kDefaultHalDriverPath32; string hal_driver_path64 = kDefaultHalDriverPath64; string shell_driver_path32 = kDefaultShellDriverPath32; string shell_driver_path64 = kDefaultShellDriverPath64; string spec_dir_path = kDefaultSpecDirPath; string log_severity = "INFO"; enum { HAL_DRIVER_PATH32 = 1000, HAL_DRIVER_PATH64, SHELL_DRIVER_PATH32, SHELL_DRIVER_PATH64, SPEC_DIR }; const char* const short_opts = "hl:"; const option long_opts[] = { {"help", no_argument, nullptr, 'h'}, {"hal_driver_path_32", required_argument, nullptr, HAL_DRIVER_PATH32}, {"hal_driver_path_64", required_argument, nullptr, HAL_DRIVER_PATH64}, {"shell_driver_path_32", required_argument, nullptr, SHELL_DRIVER_PATH32}, {"shell_driver_path_64", required_argument, nullptr, SHELL_DRIVER_PATH64}, {"spec_dir", required_argument, nullptr, SPEC_DIR}, {"log_severity", required_argument, nullptr, 'l'}, {nullptr, 0, nullptr, 0}, }; while (true) { int opt = getopt_long(argc, argv, short_opts, long_opts, nullptr); if (opt == -1) { break; } switch (opt) { case 'h': case '?': ShowUsage(); return 0; case 'l': { log_severity = string(optarg); break; } case HAL_DRIVER_PATH32: { hal_driver_path32 = string(optarg); break; } case HAL_DRIVER_PATH64: { hal_driver_path64 = string(optarg); break; } case SHELL_DRIVER_PATH32: { shell_driver_path32 = string(optarg); break; } case SHELL_DRIVER_PATH64: { shell_driver_path64 = string(optarg); break; } case SPEC_DIR: { spec_dir_path = string(optarg); break; } default: printf("getopt_long returned unexpected value: %d\n", opt); return 2; } } map<string, string> log_map = { {"ERROR", "*:e"}, {"WARNING", "*:w"}, {"INFO", "*:i"}, {"DEBUG", "*:d"}, }; if (log_map.find(log_severity) != log_map.end()) { setenv("ANDROID_LOG_TAGS", log_map[log_severity].c_str(), 1); } android::base::InitLogging(argv, android::base::StderrLogger); LOG(INFO) << "|| VTS AGENT ||"; char* dir_path; dir_path = (char*)malloc(strlen(argv[0]) + 1); strcpy(dir_path, argv[0]); for (int index = strlen(argv[0]) - 2; index >= 0; index--) { if (dir_path[index] == '/') { dir_path[index] = '\0'; break; } } chdir(dir_path); android::vts::StartTcpServerForRunner( spec_dir_path.c_str(), hal_driver_path32.c_str(), hal_driver_path64.c_str(), shell_driver_path32.c_str(), shell_driver_path64.c_str()); return 0; }