blob: da3fc5a5d85587d5027fd62b8ed3dc132c689cc0 [file] [log] [blame]
Tomasz Wasilczyk87329672019-07-12 11:43:00 -07001/*
2 * Copyright (C) 2019 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#pragma once
18
19#include "CanSocket.h"
20
21#include <android-base/unique_fd.h>
22#include <android/hardware/automotive/can/1.0/ICanBus.h>
23#include <android/hardware/automotive/can/1.0/ICanController.h>
24#include <utils/Mutex.h>
25
26#include <atomic>
27#include <thread>
28
29namespace android {
30namespace hardware {
31namespace automotive {
32namespace can {
33namespace V1_0 {
34namespace implementation {
35
36struct CanBus : public ICanBus {
Tomasz Wasilczyka9061962019-11-04 12:53:09 -080037 using ErrorCallback = std::function<void()>;
38
Tomasz Wasilczyk87329672019-07-12 11:43:00 -070039 virtual ~CanBus();
40
41 Return<Result> send(const CanMessage& message) override;
42 Return<void> listen(const hidl_vec<CanMessageFilter>& filter,
43 const sp<ICanMessageListener>& listener, listen_cb _hidl_cb) override;
Tomasz Wasilczyka9061962019-11-04 12:53:09 -080044 Return<sp<ICloseHandle>> listenForErrors(const sp<ICanErrorListener>& listener) override;
Tomasz Wasilczyk87329672019-07-12 11:43:00 -070045
Tomasz Wasilczyka9061962019-11-04 12:53:09 -080046 void setErrorCallback(ErrorCallback errcb);
Tomasz Wasilczyk87329672019-07-12 11:43:00 -070047 ICanController::Result up();
48 bool down();
49
50 protected:
chrisweircf36cea2019-11-08 16:41:02 -080051 /**
52 * Blank constructor, since some interface types (such as SLCAN) don't get a name until after
53 * being initialized.
54 *
55 * If using this constructor, you MUST initialize mIfname prior to the completion of preUp().
56 */
57 CanBus();
58
Tomasz Wasilczyk87329672019-07-12 11:43:00 -070059 CanBus(const std::string& ifname);
60
61 /**
62 * Prepare the SocketCAN interface.
63 *
64 * After calling this method, mIfname network interface is available and ready to be brought up.
chrisweircf36cea2019-11-08 16:41:02 -080065 *
66 * \return OK on success, or an error state on failure. See ICanController::Result
Tomasz Wasilczyk87329672019-07-12 11:43:00 -070067 */
68 virtual ICanController::Result preUp();
69
70 /**
71 * Cleanup after bringing the interface down.
72 *
73 * This is a counterpart to preUp().
chrisweircf36cea2019-11-08 16:41:02 -080074 *
75 * \return true upon success and false upon failure
Tomasz Wasilczyk87329672019-07-12 11:43:00 -070076 */
77 virtual bool postDown();
78
79 /** Network interface name. */
chrisweircf36cea2019-11-08 16:41:02 -080080 std::string mIfname;
Tomasz Wasilczyk87329672019-07-12 11:43:00 -070081
82 private:
83 struct CanMessageListener {
84 sp<ICanMessageListener> callback;
85 hidl_vec<CanMessageFilter> filter;
86 wp<ICloseHandle> closeHandle;
Tomasz Wasilczyka9061962019-11-04 12:53:09 -080087 bool failedOnce = false;
Tomasz Wasilczyk87329672019-07-12 11:43:00 -070088 };
Tomasz Wasilczyka9061962019-11-04 12:53:09 -080089 void clearMsgListeners();
90 void clearErrListeners();
Tomasz Wasilczyk87329672019-07-12 11:43:00 -070091
chrisweirbee3d2c2019-11-19 10:23:37 -080092 void notifyErrorListeners(ErrorEvent err, bool isFatal);
93
Tomasz Wasilczyk87329672019-07-12 11:43:00 -070094 void onRead(const struct canfd_frame& frame, std::chrono::nanoseconds timestamp);
Tomasz Wasilczyka9061962019-11-04 12:53:09 -080095 void onError(int errnoVal);
Tomasz Wasilczyk87329672019-07-12 11:43:00 -070096
Tomasz Wasilczyka9061962019-11-04 12:53:09 -080097 std::mutex mMsgListenersGuard;
98 std::vector<CanMessageListener> mMsgListeners GUARDED_BY(mMsgListenersGuard);
99
100 std::mutex mErrListenersGuard;
101 std::vector<sp<ICanErrorListener>> mErrListeners GUARDED_BY(mErrListenersGuard);
Tomasz Wasilczyk87329672019-07-12 11:43:00 -0700102
103 std::unique_ptr<CanSocket> mSocket;
Tomasz Wasilczyka9061962019-11-04 12:53:09 -0800104 bool mDownAfterUse;
Tomasz Wasilczyk87329672019-07-12 11:43:00 -0700105
106 /**
107 * Guard for up flag is required to be held for entire time when the interface is being used
108 * (i.e. message being sent), because we don't want the interface to be torn down while
109 * executing that operation.
110 */
111 std::mutex mIsUpGuard;
112 bool mIsUp GUARDED_BY(mIsUpGuard) = false;
Tomasz Wasilczyka9061962019-11-04 12:53:09 -0800113
114 ErrorCallback mErrCb;
Tomasz Wasilczyk87329672019-07-12 11:43:00 -0700115};
116
117} // namespace implementation
118} // namespace V1_0
119} // namespace can
120} // namespace automotive
121} // namespace hardware
122} // namespace android