Fix Svace issue - BUFFER_OVERFLOW
[platform/core/api/recorder.git] / include / recorder_private.h
index de3cb0e..46ba469 100644 (file)
 extern "C" {
 #endif
 
-#define RECORDER_PARSE_STRING_SIZE 30
-#define RECORDER_MSG_LENGTH_MAX    5120
+#define RECORDER_CB_TIMEOUT        5
+#define RECORDER_FILENAME_MAX      256
 
+#define RECORDER_MSG_PARAM_SET(param, msg_type, set_value) { \
+       param.type = MUSE_TYPE_##msg_type; \
+       param.name = #set_value; \
+       param.value.value_##msg_type = set_value; \
+}
+
+enum {
+       _RECORDER_GET_INT_STATE = 0,
+       _RECORDER_GET_INT_VIDEO_RESOLUTION,
+       _RECORDER_GET_INT_FILE_FORMAT,
+       _RECORDER_GET_INT_AUDIO_ENCODER,
+       _RECORDER_GET_INT_VIDEO_ENCODER,
+       _RECORDER_GET_INT_SIZE_LIMIT,
+       _RECORDER_GET_INT_TIME_LIMIT,
+       _RECORDER_GET_INT_AUDIO_DEVICE,
+       _RECORDER_GET_INT_AUDIO_SAMPLERATE,
+       _RECORDER_GET_INT_AUDIO_ENCODER_BITRATE,
+       _RECORDER_GET_INT_VIDEO_ENCODER_BITRATE,
+       _RECORDER_GET_INT_AUDIO_CHANNEL,
+       _RECORDER_GET_INT_ORIENTATION_TAG,
+       _RECORDER_GET_INT_MAX
+};
+
+enum {
+       _RECORDER_GET_DOUBLE_AUDIO_LEVEL = 0,
+       _RECORDER_GET_DOUBLE_RECORDING_MOTION_RATE,
+       _RECORDER_GET_DOUBLE_MAX
+};
+
+enum {
+       _RECORDER_MESSAGE_HANDLER_TYPE_GENERAL,
+       _RECORDER_MESSAGE_HANDLER_TYPE_AUDIO_STREAM_CB
+};
+
+typedef struct _recorder_msg_handler_info_s {
+       int type;
+       void *cb_info;
+       int running;
+       GCond cond;
+       GMutex mutex;
+       GQueue *queue;
+       GThread *thread;
+} recorder_msg_handler_info_s;
 
 typedef struct _recorder_cb_info_s {
+       /* server connection */
        gint fd;
+       gboolean is_server_connected;
+
+       /* message receive thread */
        GThread *msg_recv_thread;
-       GThread *msg_handler_thread;
        gint msg_recv_running;
-       gint msg_handler_running;
-       GCond msg_handler_cond;
-       GMutex msg_handler_mutex;
-       GQueue *msg_queue;
+       gchar recv_msg[MUSE_MSG_MAX_LENGTH + 1];
+       GCond api_cond[MUSE_RECORDER_API_MAX];
+       GMutex api_mutex[MUSE_RECORDER_API_MAX];
+       gint api_activating[MUSE_RECORDER_API_MAX];
+       gint api_ret[MUSE_RECORDER_API_MAX];
+
+       /* general message handler info */
+       recorder_msg_handler_info_s msg_handler_info;
+
+       /* preview cb message handler info */
+       recorder_msg_handler_info_s audio_stream_cb_info;
+
+       /* idle event */
        GList *idle_event_list;
        GCond idle_event_cond;
        GMutex idle_event_mutex;
+
+       /* user callback */
        gpointer user_cb[MUSE_RECORDER_EVENT_TYPE_NUM];
        gpointer user_data[MUSE_RECORDER_EVENT_TYPE_NUM];
-       gchar recv_msg[RECORDER_MSG_LENGTH_MAX];
-       GCond api_cond[MUSE_RECORDER_API_MAX];
-       GMutex api_mutex[MUSE_RECORDER_API_MAX];
-       gint *api_activating;
-       gint *api_ret;
+
+       /* tbm */
        tbm_bufmgr bufmgr;
+
+       /* get values */
+       char *get_filename;
+       gint get_int_value[_RECORDER_GET_INT_MAX];
+       gdouble get_double_value[_RECORDER_GET_DOUBLE_MAX];
 } recorder_cb_info_s;
 
 typedef struct _recorder_message_s {
-       gchar recv_msg[MUSE_RECORDER_MSG_MAX_LENGTH];
+       gchar recv_msg[MUSE_RECORDER_MSG_MAX_LENGTH + 1];
        muse_recorder_api_e api;
+       muse_recorder_event_e event;
+       muse_recorder_event_class_e event_class;
 } recorder_message_s;
 
 typedef struct _recorder_idle_event_s {
        recorder_cb_info_s *cb_info;
-       gchar recv_msg[MUSE_RECORDER_MSG_MAX_LENGTH];
+       gchar recv_msg[MUSE_RECORDER_MSG_MAX_LENGTH + 1];
        muse_recorder_event_e event;
        GMutex event_mutex;
 } recorder_idle_event_s;
@@ -67,13 +128,30 @@ typedef struct _recorder_idle_event_s {
 typedef struct _recorder_cli_s {
        intptr_t remote_handle;
        recorder_cb_info_s *cb_info;
+       camera_h camera;
 } recorder_cli_s;
 
+typedef struct _recorder_msg_param {
+       int type;
+       const char *name;
+       union {
+               int value_INT;
+               double value_DOUBLE;
+               const char *value_STRING;
+       } value;
+} recorder_msg_param;
+
 typedef struct _camera_cli_s {
        intptr_t remote_handle;
        void *cb_info;
 } camera_cli_s;
 
+typedef struct _recorder_cb_info {
+       int id;
+       void *callback;
+       void *user_data;
+} recorder_cb_info;
+
 int __convert_recorder_error_code(const char *func, int code);
 
 #ifdef __cplusplus