1 /* 2 * Copyright (C) 2017 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 #ifndef NOS_DEVICE_H 17 #define NOS_DEVICE_H 18 19 #include <stdint.h> 20 21 #ifdef __cplusplus 22 extern "C" { 23 #endif 24 25 /* Max data size for read/write. 26 * Yes, it's a magic number. See b/37675056#comment8. */ 27 #define MAX_DEVICE_TRANSFER 2044 28 29 struct nos_device_ops { 30 /** 31 * Read a datagram from the device. 32 * 33 * Return 0 on success and a negative value on failure. 34 */ 35 int (*read)(void* ctx, uint32_t command, uint8_t *buf, uint32_t len); 36 37 /** 38 * Write a datagram to the device. 39 * 40 * Return 0 on success and a negative value on failure. 41 */ 42 int (*write)(void *ctx, uint32_t command, const uint8_t *buf, uint32_t len); 43 44 /** 45 * Block until an event has happened on the device, or until timed out. 46 * 47 * Values for msecs 48 * <0 wait forever 49 * 0 return immediately (why?) 50 * >0 timeout after this many milliseconds 51 * 52 * Returns: 53 * <0 on error 54 * 0 timed out 55 * >0 interrupt occurred 56 */ 57 int (*wait_for_interrupt)(void *ctx, int msecs); 58 59 /** 60 * Reset the device. 61 * 62 * Return 0 on success and a negative value on failure. 63 */ 64 int (*reset)(void *ctx); 65 66 /** 67 * Close the connection to the device. 68 * 69 * The device must not be used after closing. 70 */ 71 void (*close)(void *ctx); 72 73 #ifndef ANDROID 74 /** 75 * Get or Set a configuration value. These are opaque, implementation-specific 76 * values useful only for bringup and development. The defaults should be 77 * optimal for production use. 78 * 79 * Return 0 on success and a negative value on failure. 80 */ 81 int (*get_config)(void *ctx, uint32_t config_id, void *value); 82 int (*set_config)(void *ctx, uint32_t config_id, void *value); 83 #endif 84 }; 85 86 struct nos_device { 87 void *ctx; 88 struct nos_device_ops ops; 89 }; 90 91 /* 92 * Open a connection to a Nugget device. 93 * 94 * The name parameter identifies which Nugget device to connect to. Passing 95 * NULL connects to the default device. 96 * 97 * This function is implemented by the host specific variants of this library. 98 * 99 * Returns 0 on success or negative on failure. 100 */ 101 int nos_device_open(const char *name, struct nos_device *device); 102 103 #ifdef __cplusplus 104 } 105 #endif 106 107 #endif /* NOS_DEVICE_H */ 108