Home | History | Annotate | Download | only in camera2
      1 /*
      2  * Copyright (C) 2013 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 #ifndef ANDROID_HARDWARE_PHOTOGRAPHY_ICAMERADEVICEUSER_H
     18 #define ANDROID_HARDWARE_PHOTOGRAPHY_ICAMERADEVICEUSER_H
     19 
     20 #include <binder/IInterface.h>
     21 #include <binder/Parcel.h>
     22 #include <utils/List.h>
     23 
     24 struct camera_metadata;
     25 
     26 namespace android {
     27 
     28 class ICameraDeviceUserClient;
     29 class IGraphicBufferProducer;
     30 class Surface;
     31 class CaptureRequest;
     32 class CameraMetadata;
     33 
     34 enum {
     35     NO_IN_FLIGHT_REPEATING_FRAMES = -1,
     36 };
     37 
     38 class ICameraDeviceUser : public IInterface
     39 {
     40     /**
     41      * Keep up-to-date with ICameraDeviceUser.aidl in frameworks/base
     42      */
     43 public:
     44     DECLARE_META_INTERFACE(CameraDeviceUser);
     45 
     46     virtual void            disconnect() = 0;
     47 
     48     /**
     49      * Request Handling
     50      **/
     51 
     52     /**
     53      * For streaming requests, output lastFrameNumber is the last frame number
     54      * of the previous repeating request.
     55      * For non-streaming requests, output lastFrameNumber is the expected last
     56      * frame number of the current request.
     57      */
     58     virtual int             submitRequest(sp<CaptureRequest> request,
     59                                           bool streaming = false,
     60                                           /*out*/
     61                                           int64_t* lastFrameNumber = NULL) = 0;
     62 
     63     /**
     64      * For streaming requests, output lastFrameNumber is the last frame number
     65      * of the previous repeating request.
     66      * For non-streaming requests, output lastFrameNumber is the expected last
     67      * frame number of the current request.
     68      */
     69     virtual int             submitRequestList(List<sp<CaptureRequest> > requestList,
     70                                               bool streaming = false,
     71                                               /*out*/
     72                                               int64_t* lastFrameNumber = NULL) = 0;
     73 
     74     /**
     75      * Output lastFrameNumber is the last frame number of the previous repeating request.
     76      */
     77     virtual status_t        cancelRequest(int requestId,
     78                                           /*out*/
     79                                           int64_t* lastFrameNumber = NULL) = 0;
     80 
     81     /**
     82      * Begin the device configuration.
     83      *
     84      * <p>
     85      * beginConfigure must be called before any call to deleteStream, createStream,
     86      * or endConfigure.  It is not valid to call this when the device is not idle.
     87      * <p>
     88      */
     89     virtual status_t        beginConfigure() = 0;
     90 
     91     /**
     92      * End the device configuration.
     93      *
     94      * <p>
     95      * endConfigure must be called after stream configuration is complete (i.e. after
     96      * a call to beginConfigure and subsequent createStream/deleteStream calls).  This
     97      * must be called before any requests can be submitted.
     98      * <p>
     99      */
    100     virtual status_t        endConfigure() = 0;
    101 
    102     virtual status_t        deleteStream(int streamId) = 0;
    103     virtual status_t        createStream(
    104             int width, int height, int format,
    105             const sp<IGraphicBufferProducer>& bufferProducer) = 0;
    106 
    107     // Create a request object from a template.
    108     virtual status_t        createDefaultRequest(int templateId,
    109                                                  /*out*/
    110                                                  CameraMetadata* request) = 0;
    111     // Get static camera metadata
    112     virtual status_t        getCameraInfo(/*out*/
    113                                           CameraMetadata* info) = 0;
    114 
    115     // Wait until all the submitted requests have finished processing
    116     virtual status_t        waitUntilIdle() =  0;
    117 
    118     /**
    119      * Flush all pending and in-progress work as quickly as possible.
    120      * Output lastFrameNumber is the last frame number of the previous repeating request.
    121      */
    122     virtual status_t        flush(/*out*/
    123                                   int64_t* lastFrameNumber = NULL) = 0;
    124 };
    125 
    126 // ----------------------------------------------------------------------------
    127 
    128 class BnCameraDeviceUser: public BnInterface<ICameraDeviceUser>
    129 {
    130 public:
    131     virtual status_t    onTransact( uint32_t code,
    132                                     const Parcel& data,
    133                                     Parcel* reply,
    134                                     uint32_t flags = 0);
    135 };
    136 
    137 }; // namespace android
    138 
    139 #endif
    140