android13/packages/services/Car/tools/emulator/vhal_const_generate.py

128 lines
5.7 KiB
Python
Executable File

#!/usr/bin/env python3
#
# Copyright (C) 2017 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 script generates vhal_consts_x_y.py files for use in vhal_emulator
# They are generated from corresponding data in Vehicle HAL types.hal files
# To run, invoke at a shell by saying:
# $ packages/services/Car/tools/emulator/vhal_const_generate.py
# The script will automatically locate itself and the required HAL files and will write next
# to itself vhal_consts_x.y.py for any version of Vehicle HAL that it knows about
# Those files can then be used with vhal_emulator.py as per that script's documentation
from __future__ import print_function
import datetime
def printHeader(dest):
year = datetime.datetime.now().year
print("# Copyright (C) %s The Android Open Source Project" % year, file=dest)
print("#", file=dest)
print("# Licensed under the Apache License, Version 2.0 (the \"License\");", file=dest)
print("# you may not use this file except in compliance with the License.", file=dest)
print("# You may obtain a copy of the License at", file=dest)
print("#", file=dest)
print("# http://www.apache.org/licenses/LICENSE-2.0", file=dest)
print("#", file=dest)
print("# Unless required by applicable law or agreed to in writing, software", file=dest)
print("# distributed under the License is distributed on an \"AS IS\" BASIS,", file=dest)
print("# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.", file=dest)
print("# See the License for the specific language governing permissions and", file=dest)
print("# limitations under the License.", file=dest)
print("#", file=dest)
print("# DO NOT EDIT MANUALLY", file=dest)
print("# This file was autogenerated by vhal_const_generate.py", file=dest)
def printEnum(doc, name, dest, postprocess=lambda x: x):
# Construct a value name prefix from the group name
valueNamePrefix = name.upper() + '_'
enum_object = doc['enums'][name]
print("\n# %s" % name, file=dest)
for case in enum_object.cases:
print('%s%s = %s' % (valueNamePrefix, case.name,
postprocess(case.value.resolve(enum_object, doc))),
file=dest)
import os, os.path
import sys
script_directory = os.path.join(os.path.dirname(os.path.abspath(__file__)))
parent_location = os.path.abspath(os.path.join(script_directory, '..'))
sys.path.append(parent_location)
# hidl_parser depends on a custom Python package that requires installation
# give user guidance should the import fail
try:
from hidl_parser import parser
except ImportError as e:
isPly = False
pipTool = "pip%s" % ("3" if sys.version_info > (3,0) else "")
if hasattr(e, 'name'):
if e.name == 'ply': isPly = True
elif hasattr(e, 'message'):
if e.message.endswith('ply'): isPly = True
if isPly:
print('could not import ply.')
print('ply is available as part of an Android checkout in external/ply')
print('or it can be installed via "sudo %s install ply"' % pipTool)
sys.exit(1)
else:
raise e
android_build_top = os.environ.get("ANDROID_BUILD_TOP", None)
if android_build_top is not None:
vhal_location = os.path.join(android_build_top, 'hardware','interfaces','automotive','vehicle')
else:
vhal_location = os.path.abspath(os.path.join(os.path.dirname(os.path.abspath(__file__)),
'..','..','..','..','..','hardware','interfaces','automotive','vehicle'
))
if not(os.path.exists(vhal_location) and os.path.isdir(vhal_location)):
print("Vehicle HAL was not found at %s. lunch may provide a correct environment, or files moved" % vhal_location)
sys.exit(1)
def generateHal20():
vhal_20_file = os.path.join(vhal_location, '2.0', 'types.hal')
if not(os.path.exists(vhal_20_file)):
print("Vehicle HAL was not found at %s. lunch may provide a correct environment, or files moved" % vhal_location)
sys.exit(1)
print("Generating constants from Vehicle HAL 2.0 (%s)" % (vhal_20_file))
vhal_20_doc = parser.parse(vhal_20_file)
vhal_20_file = open(os.path.join(script_directory, 'vhal_consts_2_0.py'), 'w')
printHeader(vhal_20_file)
for group in vhal_20_doc['enums']:
print(group)
printEnum(vhal_20_doc, group, vhal_20_file, lambda x : hex(x))
print("\n# Create a container of value_type constants to be used by vhal_emulator", file=vhal_20_file)
print("class vhal_types_2_0:", file=vhal_20_file)
print(" TYPE_STRING = [VEHICLEPROPERTYTYPE_STRING]", file=vhal_20_file)
print(" TYPE_BYTES = [VEHICLEPROPERTYTYPE_BYTES]", file=vhal_20_file)
print(" TYPE_INT32 = [VEHICLEPROPERTYTYPE_BOOLEAN,", file=vhal_20_file)
print(" VEHICLEPROPERTYTYPE_INT32]", file=vhal_20_file)
print(" TYPE_INT64 = [VEHICLEPROPERTYTYPE_INT64]", file=vhal_20_file)
print(" TYPE_FLOAT = [VEHICLEPROPERTYTYPE_FLOAT]", file=vhal_20_file)
print(" TYPE_INT32S = [VEHICLEPROPERTYTYPE_INT32_VEC]", file=vhal_20_file)
print(" TYPE_INT64S = [VEHICLEPROPERTYTYPE_INT64_VEC]", file=vhal_20_file)
print(" TYPE_FLOATS = [VEHICLEPROPERTYTYPE_FLOAT_VEC]", file=vhal_20_file)
print(" TYPE_MIXED = [VEHICLEPROPERTYTYPE_MIXED]", file=vhal_20_file)
generateHal20()