// Copyright (C) 2020 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.
//

// The original Work has been changed by NXP.
//
// 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.
//
// Copyright 2022-2023 NXP
//

package {
    default_applicable_licenses: [
        "//hardware/nxp/keymint:hardware_nxp_keymint_license",
    ],
}

cc_library {
    name: "libjc_keymint3.nxp",
    defaults: [
        "keymaster_defaults",
    ],
    srcs: [
        "CborConverter.cpp",
        "JavacardKeyMintDevice.cpp",
        "JavacardKeyMintOperation.cpp",
        "JavacardRemotelyProvisionedComponentDevice.cpp",
        "JavacardSecureElement.cpp",
        "JavacardSharedSecret.cpp",
        "keymint_utils.cpp",
    ],
    cflags: [
        "-O0",
        "-DNXP_EXTNS",
    ],
    shared_libs: [
        "android.hardware.security.rkp-V3-ndk",
        "android.hardware.security.secureclock-V1-ndk",
        "android.hardware.security.sharedsecret-V1-ndk",
        "lib_android_keymaster_keymint_utils",
        "libbase",
        "libbinder",
        "libcppbor",
        "libkeymaster_portable",
        "libkeymaster_messages",
        "libsoft_attestation_cert",
        "liblog",
        "libcrypto",
        "libcutils",
        "libjc_keymint_transport.nxp",
        "libbinder_ndk",
        "libmemunreachable",
        "android.hardware.security.keymint-V3-ndk",
    ],
    export_include_dirs: [
        ".",
    ],
    product_variables: {
        debuggable: {
            cflags: ["-DDCHECK_ALWAYS_ON"],
        },
    },
    vendor_available: true,
}

cc_binary {
    name: "android.hardware.security.keymint3-service.strongbox.nxp",
    relative_install_path: "hw",
    init_rc: ["android.hardware.security.keymint3-service.strongbox.nxp.rc"],
    vintf_fragments: [
        "android.hardware.security.keymint3-service.strongbox.nxp.xml",
        "android.hardware.security.sharedsecret3-service.strongbox.nxp.xml",
    ],
    vendor: true,
    cflags: [
        "-Wall",
        "-Wextra",
        "-DOMAPI_TRANSPORT",
        "-DNXP_EXTNS",
    ],
    shared_libs: [
        "android.hardware.security.rkp-V3-ndk",
        "android.hardware.security.sharedsecret-V1-ndk",
        "lib_android_keymaster_keymint_utils",
        "android.se.omapi-V1-ndk",
        "libbase",
        "libbinder_ndk",
        "libcppbor",
        "libcrypto",
        "libkeymaster_portable",
        "libjc_keymint3.nxp",
        "libjc_keymint_transport.nxp",
        "liblog",
        "libutils",
        "libhidlbase",
        "android.hardware.security.keymint-V3-ndk",
    ],
    srcs: [
        "service.cpp",
    ],
    required: [
        "android.hardware.hardware_keystore.jc-strongbox-keymint3.nxp.xml",
    ],
}

prebuilt_etc {
    name: "android.hardware.hardware_keystore.jc-strongbox-keymint3.nxp.xml",
    sub_dir: "permissions",
    vendor: true,
    src: "android.hardware.hardware_keystore.jc-strongbox-keymint3.nxp.xml",
}