Skip to content

Commit

Permalink
Update USB HAL to V1.3 implementation
Browse files Browse the repository at this point in the history
Supports to enable/disable USB data signaling

Bug: 161414036
Test: Pass USB V1.3 HIDL tests
Signed-off-by: Albert Wang <[email protected]>
Change-Id: I370e69264bec6c2c7ac61094db49f5e3a4b317b6
  • Loading branch information
Albert Wang committed Mar 24, 2021
1 parent c991432 commit 89dfe03
Show file tree
Hide file tree
Showing 9 changed files with 127 additions and 50 deletions.
8 changes: 8 additions & 0 deletions CleanSpec.mk
Original file line number Diff line number Diff line change
Expand Up @@ -120,3 +120,11 @@ $(call add-clean-step, rm -rf $(PRODUCT_OUT)/vendor/etc/init/android.hardware.po
# Remove generic atrace HAL
$(call add-clean-step, rm -rf $(PRODUCT_OUT)/vendor/etc/init/[email protected])
$(call add-clean-step, rm -rf $(PRODUCT_OUT)/vendor/etc/vintf/manifest/[email protected])

# Update to USB HAL 1.3
$(call add-clean-step, rm -rf $(PRODUCT_OUT)/vendor/bin/hw/[email protected])
$(call add-clean-step, rm -rf $(PRODUCT_OUT)/vendor/etc/init/[email protected])
$(call add-clean-step, rm -rf $(PRODUCT_OUT)/vendor/etc/vintf/manifest/[email protected])
$(call add-clean-step, rm -rf $(PRODUCT_OUT)/vendor/bin/hw/[email protected])
$(call add-clean-step, rm -rf $(PRODUCT_OUT)/vendor/etc/init/[email protected])
$(call add-clean-step, rm -rf $(PRODUCT_OUT)/vendor/etc/vintf/manifest/[email protected])
2 changes: 1 addition & 1 deletion device.mk
Original file line number Diff line number Diff line change
Expand Up @@ -451,7 +451,7 @@ PRODUCT_COPY_FILES += \
device/google/sunfish/nfc/libnfc-nci.conf:$(TARGET_COPY_OUT_PRODUCT)/etc/libnfc-nci.conf

PRODUCT_PACKAGES += \
android.hardware.usb@1.2-service.sunfish
android.hardware.usb@1.3-service.sunfish

PRODUCT_PACKAGES += \
[email protected] \
Expand Down
9 changes: 5 additions & 4 deletions usb/Android.bp
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
//
// Copyright (C) 2018 The Android Open Source Project
// Copyright (C) 2021 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.
Expand All @@ -18,18 +18,19 @@ package {
}

cc_binary {
name: "android.hardware.usb@1.2-service.sunfish",
name: "android.hardware.usb@1.3-service.sunfish",
relative_install_path: "hw",
init_rc: ["android.hardware.usb@1.2-service.sunfish.rc"],
init_rc: ["android.hardware.usb@1.3-service.sunfish.rc"],
vintf_fragments: [
"android.hardware.usb@1.2-service.sunfish.xml",
"android.hardware.usb@1.3-service.sunfish.xml",
"[email protected]",
],
srcs: ["service.cpp", "Usb.cpp", "UsbGadget.cpp"],
shared_libs: [
"[email protected]",
"[email protected]",
"[email protected]",
"[email protected]",
"[email protected]",
"[email protected]",
"[email protected]",
Expand Down
70 changes: 54 additions & 16 deletions usb/Usb.cpp
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2017 The Android Open Source Project
* Copyright (C) 2021 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.
Expand All @@ -14,7 +14,7 @@
* limitations under the License.
*/

#define LOG_TAG "android.hardware.usb@1.2-service.sunfish"
#define LOG_TAG "android.hardware.usb@1.3-service.sunfish"

#include <android-base/logging.h>
#include <android-base/properties.h>
Expand All @@ -41,9 +41,49 @@ using android::base::GetProperty;
namespace android {
namespace hardware {
namespace usb {
namespace V1_2 {
namespace V1_3 {
namespace implementation {

Return<bool> Usb::enableUsbDataSignal(bool enable) {
bool result = true;

ALOGI("Userspace turn %s USB data signaling", enable ? "on" : "off");

if (enable) {
if (!WriteStringToFile("1", USB_DATA_PATH)) {
ALOGE("Not able to turn on usb connection notification");
result = false;
}

if (!WriteStringToFile(kGadgetName, PULLUP_PATH)) {
ALOGE("Gadget cannot be pulled up");
result = false;
}
} else {
if (!WriteStringToFile("1", ID_PATH)) {
ALOGE("Not able to turn off host mode");
result = false;
}

if (!WriteStringToFile("0", VBUS_PATH)) {
ALOGE("Not able to set Vbus state");
result = false;
}

if (!WriteStringToFile("0", USB_DATA_PATH)) {
ALOGE("Not able to turn on usb connection notification");
result = false;
}

if (!WriteStringToFile("none", PULLUP_PATH)) {
ALOGE("Gadget cannot be pulled down");
result = false;
}
}

return result;
}

// Set by the signal handler to destroy the thread
volatile bool destroyThread;

Expand All @@ -52,8 +92,7 @@ constexpr char kDetectedPath[] = "/sys/class/power_supply/usb/moisture_detected"
constexpr char kConsole[] = "init.svc.console";
constexpr char kDisableContatminantDetection[] = "vendor.usb.contaminantdisable";

void queryVersionHelper(android::hardware::usb::V1_2::implementation::Usb *usb,
hidl_vec<PortStatus> *currentPortStatus_1_2);
void queryVersionHelper(implementation::Usb *usb, hidl_vec<PortStatus> *currentPortStatus_1_2);

int32_t readFile(const std::string &filename, std::string *contents) {
FILE *fp;
Expand Down Expand Up @@ -104,9 +143,9 @@ Status queryMoistureDetectionStatus(hidl_vec<PortStatus> *currentPortStatus_1_2)

(*currentPortStatus_1_2)[0].supportedContaminantProtectionModes = 0;
(*currentPortStatus_1_2)[0].supportedContaminantProtectionModes |=
ContaminantProtectionMode::FORCE_SINK;
(*currentPortStatus_1_2)[0].contaminantProtectionStatus = ContaminantProtectionStatus::NONE;
(*currentPortStatus_1_2)[0].contaminantDetectionStatus = ContaminantDetectionStatus::DISABLED;
V1_2::ContaminantProtectionMode::FORCE_SINK;
(*currentPortStatus_1_2)[0].contaminantProtectionStatus = V1_2::ContaminantProtectionStatus::NONE;
(*currentPortStatus_1_2)[0].contaminantDetectionStatus = V1_2::ContaminantDetectionStatus::DISABLED;
(*currentPortStatus_1_2)[0].supportsEnableContaminantPresenceDetection = true;
(*currentPortStatus_1_2)[0].supportsEnableContaminantPresenceProtection = false;

Expand All @@ -122,12 +161,12 @@ Status queryMoistureDetectionStatus(hidl_vec<PortStatus> *currentPortStatus_1_2)
}
if (status == "1") {
(*currentPortStatus_1_2)[0].contaminantDetectionStatus =
ContaminantDetectionStatus::DETECTED;
V1_2::ContaminantDetectionStatus::DETECTED;
(*currentPortStatus_1_2)[0].contaminantProtectionStatus =
ContaminantProtectionStatus::FORCE_SINK;
V1_2::ContaminantProtectionStatus::FORCE_SINK;
} else
(*currentPortStatus_1_2)[0].contaminantDetectionStatus =
ContaminantDetectionStatus::NOT_DETECTED;
V1_2::ContaminantDetectionStatus::NOT_DETECTED;
}

ALOGI("ContaminantDetectionStatus:%d ContaminantProtectionStatus:%d",
Expand Down Expand Up @@ -557,8 +596,7 @@ Status getPortStatusHelper(hidl_vec<PortStatus> *currentPortStatus_1_2, HALVersi
return Status::ERROR;
}

void queryVersionHelper(android::hardware::usb::V1_2::implementation::Usb *usb,
hidl_vec<PortStatus> *currentPortStatus_1_2) {
void queryVersionHelper(implementation::Usb *usb, hidl_vec<PortStatus> *currentPortStatus_1_2) {
hidl_vec<V1_1::PortStatus_1_1> currentPortStatus_1_1;
hidl_vec<V1_0::PortStatus> currentPortStatus;
Status status;
Expand Down Expand Up @@ -609,7 +647,7 @@ Return<void> Usb::queryPortStatus() {

struct data {
int uevent_fd;
android::hardware::usb::V1_2::implementation::Usb *usb;
android::hardware::usb::V1_3::implementation::Usb *usb;
};

static void uevent_event(uint32_t /*epevents*/, struct data *payload) {
Expand Down Expand Up @@ -682,7 +720,7 @@ void *work(void *param) {
}

payload.uevent_fd = uevent_fd;
payload.usb = (android::hardware::usb::V1_2::implementation::Usb *)param;
payload.usb = (android::hardware::usb::V1_3::implementation::Usb *)param;

fcntl(uevent_fd, F_SETFL, O_NONBLOCK);

Expand Down Expand Up @@ -797,7 +835,7 @@ Return<void> Usb::setCallback(const sp<V1_0::IUsbCallback> &callback) {
}

} // namespace implementation
} // namespace V1_2
} // namespace V1_3
} // namespace usb
} // namespace hardware
} // namespace android
44 changes: 33 additions & 11 deletions usb/Usb.h
Original file line number Diff line number Diff line change
@@ -1,10 +1,26 @@
#ifndef ANDROID_HARDWARE_USB_V1_1_USB_H
#define ANDROID_HARDWARE_USB_V1_1_USB_H
/*
* Copyright (C) 2021 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.
*/
#pragma once

#include <android/hardware/usb/1.2/IUsb.h>
#include <android-base/file.h>
#include <android/hardware/usb/1.2/IUsbCallback.h>
#include <android/hardware/usb/1.2/types.h>
#include <android/hardware/usb/1.3/IUsb.h>
#include <hidl/Status.h>
#include <pixelusb/UsbGadgetCommon.h>
#include <utils/Log.h>

#define UEVENT_MSG_LEN 2048
Expand All @@ -17,10 +33,11 @@
namespace android {
namespace hardware {
namespace usb {
namespace V1_2 {
namespace V1_3 {
namespace implementation {

using ::android::sp;
using ::android::base::WriteStringToFile;
using ::android::hardware::hidl_array;
using ::android::hardware::hidl_memory;
using ::android::hardware::hidl_string;
Expand All @@ -32,21 +49,27 @@ using ::android::hardware::usb::V1_0::PortPowerRole;
using ::android::hardware::usb::V1_0::PortRole;
using ::android::hardware::usb::V1_0::PortRoleType;
using ::android::hardware::usb::V1_0::Status;
using ::android::hardware::usb::V1_2::IUsb;
using ::android::hardware::usb::V1_2::IUsbCallback;

using ::android::hardware::usb::V1_1::PortMode_1_1;
using ::android::hardware::usb::V1_1::PortStatus_1_1;
using ::android::hardware::usb::V1_2::PortStatus;
using ::android::hardware::usb::V1_2::IUsbCallback;
using ::android::hardware::usb::V1_3::IUsb;
using ::android::hidl::base::V1_0::DebugInfo;
using ::android::hidl::base::V1_0::IBase;

enum class HALVersion{
V1_0,
V1_1,
V1_2
V1_2,
V1_3
};

constexpr char kGadgetName[] = "a600000.dwc3";
#define SOC_PATH "/sys/devices/platform/soc/a600000.ssusb/"
#define ID_PATH SOC_PATH "id"
#define VBUS_PATH SOC_PATH "b_sess"
#define USB_DATA_PATH SOC_PATH "usb_data_enabled"

struct Usb : public IUsb {
Usb();

Expand All @@ -55,6 +78,7 @@ struct Usb : public IUsb {
Return<void> queryPortStatus() override;
Return<void> enableContaminantPresenceDetection(const hidl_string& portName, bool enable);
Return<void> enableContaminantPresenceProtection(const hidl_string& portName, bool enable);
Return<bool> enableUsbDataSignal(bool enable) override;

sp<V1_0::IUsbCallback> mCallback_1_0;
// Protects mCallback variable
Expand All @@ -73,9 +97,7 @@ struct Usb : public IUsb {
};

} // namespace implementation
} // namespace V1_2
} // namespace V1_3
} // namespace usb
} // namespace hardware
} // namespace android

#endif // ANDROID_HARDWARE_USB_V1_2_USB_H
13 changes: 0 additions & 13 deletions usb/[email protected]

This file was deleted.

21 changes: 21 additions & 0 deletions usb/[email protected]
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
service vendor.usb-hal-1-3 /vendor/bin/hw/[email protected]
class hal
user root
group root system shell mtp

on boot
chown root system /sys/class/typec/port0/power_role
chown root system /sys/class/typec/port0/data_role
chown root system /sys/class/typec/port0/port_type
chmod 664 /sys/class/typec/port0/power_role
chmod 664 /sys/class/typec/port0/data_role
chmod 664 /sys/class/typec/port0/port_type
chmod 664 /sys/class/power_supply/usb/moisture_detection_enabled

on post-fs
chown root system /sys/devices/platform/soc/a600000.ssusb/id
chown root system /sys/devices/platform/soc/a600000.ssusb/b_sess
chown root system /sys/devices/platform/soc/a600000.ssusb/usb_data_enabled
chmod 664 /sys/devices/platform/soc/a600000.ssusb/id
chmod 664 /sys/devices/platform/soc/a600000.ssusb/b_sess
chmod 664 /sys/devices/platform/soc/a600000.ssusb/usb_data_enabled
2 changes: 1 addition & 1 deletion [email protected][email protected]
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
<hal format="hidl">
<name>android.hardware.usb</name>
<transport>hwbinder</transport>
<version>1.2</version>
<version>1.3</version>
<interface>
<name>IUsb</name>
<instance>default</instance>
Expand Down
8 changes: 4 additions & 4 deletions usb/service.cpp
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2018 The Android Open Source Project
* Copyright (C) 2021 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.
Expand All @@ -14,7 +14,7 @@
* limitations under the License.
*/

#define LOG_TAG "android.hardware.usb@1.2-service.sunfish"
#define LOG_TAG "android.hardware.usb@1.3-service.sunfish"

#include <hidl/HidlTransportSupport.h>
#include "Usb.h"
Expand All @@ -29,8 +29,8 @@ using android::hardware::joinRpcThreadpool;
// Generated HIDL files
using android::hardware::usb::gadget::V1_2::IUsbGadget;
using android::hardware::usb::gadget::V1_2::implementation::UsbGadget;
using android::hardware::usb::V1_2::IUsb;
using android::hardware::usb::V1_2::implementation::Usb;
using android::hardware::usb::V1_3::IUsb;
using android::hardware::usb::V1_3::implementation::Usb;

using android::OK;
using android::status_t;
Expand Down

0 comments on commit 89dfe03

Please sign in to comment.