Add oneplus-motor command
This commit is contained in:
parent
1a2c9165c8
commit
05e6d4b94f
@ -111,3 +111,15 @@ cc_binary {
|
|||||||
"libhidlbase",
|
"libhidlbase",
|
||||||
],
|
],
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cc_binary {
|
||||||
|
name: "oneplus-motor",
|
||||||
|
srcs: [
|
||||||
|
"oneplus-motor.cpp",
|
||||||
|
],
|
||||||
|
shared_libs: [
|
||||||
|
"vendor.oneplus.hardware.motorcontrol@1.0",
|
||||||
|
"libutils",
|
||||||
|
"libhidlbase",
|
||||||
|
],
|
||||||
|
}
|
||||||
|
32
cmds/oneplus-motor.cpp
Normal file
32
cmds/oneplus-motor.cpp
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
#include <iostream>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <vendor/oneplus/hardware/motorcontrol/1.0/IOPMotorControl.h>
|
||||||
|
|
||||||
|
using ::vendor::oneplus::hardware::motorcontrol::V1_0::IOPMotorControl;
|
||||||
|
using ::android::sp;
|
||||||
|
|
||||||
|
int main(int argc, char **argv) {
|
||||||
|
auto svc = IOPMotorControl::getService();
|
||||||
|
if(svc == nullptr) {
|
||||||
|
std::cerr << "Failed getting IMotor" << std::endl;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
if(argc<2) {
|
||||||
|
std::cerr << "Usage: " << argv[0] << " <read|down|up>" << std::endl;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
std::string cmd(argv[1]);
|
||||||
|
if(cmd == "read") {
|
||||||
|
int ret = svc->readMotorData(1, 16);
|
||||||
|
std::cout << "Read motor data 1/16 returned " << ret << std::endl;
|
||||||
|
return 0;
|
||||||
|
} else if(cmd == "down") {
|
||||||
|
int ret = svc->writeMotorData(1, 0, 1);
|
||||||
|
std::cout << "Down motor control data 1/0/1 returned " << ret << std::endl;
|
||||||
|
return 0;
|
||||||
|
} else if(cmd == "up") {
|
||||||
|
int ret = svc->writeMotorData(1, 1, 1);
|
||||||
|
std::cout << "Down motor control data 1/1/1 returned " << ret << std::endl;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user