1 /*
2  INTEL CONFIDENTIAL
3  Copyright 2009 Intel Corporation All Rights Reserved.
4  The source code contained or described herein and all documents related to the source code ("Material") are owned by Intel Corporation or its suppliers or licensors. Title to the Material remains with Intel Corporation or its suppliers and licensors. The Material contains trade secrets and proprietary and confidential information of Intel or its suppliers and licensors. The Material is protected by worldwide copyright and trade secret laws and treaty provisions. No part of the Material may be used, copied, reproduced, modified, published, uploaded, posted, transmitted, distributed, or disclosed in any way without Intel’s prior express written permission.
5 
6  No license under any patent, copyright, trade secret or other intellectual property right is granted to or conferred upon you by disclosure or delivery of the Materials, either expressly, by implication, inducement, estoppel or otherwise. Any license under such intellectual property rights must be express and approved by Intel in writing.
7  */
8 
9 #ifndef __MIX_FRAMEMANAGER_H__
10 #define __MIX_FRAMEMANAGER_H__
11 
12 #include <glib-object.h>
13 #include "mixvideodef.h"
14 #include "mixvideoframe.h"
15 
16 /*
17  * Type macros.
18  */
19 #define MIX_TYPE_FRAMEMANAGER                  (mix_framemanager_get_type ())
20 #define MIX_FRAMEMANAGER(obj)                  (G_TYPE_CHECK_INSTANCE_CAST ((obj), MIX_TYPE_FRAMEMANAGER, MixFrameManager))
21 #define MIX_IS_FRAMEMANAGER(obj)               (G_TYPE_CHECK_INSTANCE_TYPE ((obj), MIX_TYPE_FRAMEMANAGER))
22 #define MIX_FRAMEMANAGER_CLASS(klass)          (G_TYPE_CHECK_CLASS_CAST ((klass), MIX_TYPE_FRAMEMANAGER, MixFrameManagerClass))
23 #define MIX_IS_FRAMEMANAGER_CLASS(klass)       (G_TYPE_CHECK_CLASS_TYPE ((klass), MIX_TYPE_FRAMEMANAGER))
24 #define MIX_FRAMEMANAGER_GET_CLASS(obj)        (G_TYPE_INSTANCE_GET_CLASS ((obj), MIX_TYPE_FRAMEMANAGER, MixFrameManagerClass))
25 
26 typedef struct _MixFrameManager MixFrameManager;
27 typedef struct _MixFrameManagerClass MixFrameManagerClass;
28 
29 struct _MixFrameManager {
30 	/*< public > */
31 	GObject parent;
32 
33 	/*< public > */
34 
35 	/*< private > */
36 	gboolean initialized;
37 	gboolean flushing;
38 	gboolean eos;
39 
40 	GMutex *lock;
41 	GPtrArray *frame_array;
42 	GQueue *frame_queue;
43 
44 	gint framerate_numerator;
45 	gint framerate_denominator;
46 	guint64 frame_timestamp_delta;
47 
48 	MixFrameOrderMode mode;
49 
50 	gboolean is_first_frame;
51 	guint64 next_frame_timestamp;
52 
53 	/*
54 	 * For VC-1 in ASF.
55 	 */
56 
57 	MixVideoFrame *p_frame;
58 	guint64 prev_timestamp;
59 
60 	gboolean timebased_ordering;
61 };
62 
63 /**
64  * MixFrameManagerClass:
65  *
66  * MI-X Video object class
67  */
68 struct _MixFrameManagerClass {
69 	/*< public > */
70 	GObjectClass parent_class;
71 
72 /* class members */
73 
74 /*< public > */
75 };
76 
77 /**
78  * mix_framemanager_get_type:
79  * @returns: type
80  *
81  * Get the type of object.
82  */
83 GType mix_framemanager_get_type(void);
84 
85 /**
86  * mix_framemanager_new:
87  * @returns: A newly allocated instance of #MixFrameManager
88  *
89  * Use this method to create new instance of #MixFrameManager
90  */
91 MixFrameManager *mix_framemanager_new(void);
92 
93 /**
94  * mix_framemanager_ref:
95  * @mix: object to add reference
96  * @returns: the MixFrameManager instance where reference count has been increased.
97  *
98  * Add reference count.
99  */
100 MixFrameManager *mix_framemanager_ref(MixFrameManager * mix);
101 
102 /**
103  * mix_framemanager_unref:
104  * @obj: object to unref.
105  *
106  * Decrement reference count of the object.
107  */
108 #define mix_framemanager_unref(obj) g_object_unref (G_OBJECT(obj))
109 
110 /* Class Methods */
111 
112 /*
113  * Initialize FM
114  */
115 MIX_RESULT mix_framemanager_initialize(MixFrameManager *fm,
116 		MixFrameOrderMode mode, gint framerate_numerator,
117 		gint framerate_denominator, gboolean timebased_ordering);
118 /*
119  * Deinitialize FM
120  */
121 MIX_RESULT mix_framemanager_deinitialize(MixFrameManager *fm);
122 
123 /*
124  * Set new framerate
125  */
126 MIX_RESULT mix_framemanager_set_framerate(MixFrameManager *fm,
127 						gint framerate_numerator, gint framerate_denominator);
128 
129 /*
130  * Get framerate
131  */
132 MIX_RESULT mix_framemanager_get_framerate(MixFrameManager *fm,
133 						gint *framerate_numerator, gint *framerate_denominator);
134 
135 
136 /*
137  * Get Frame Order Mode
138  */
139 MIX_RESULT mix_framemanager_get_frame_order_mode(MixFrameManager *fm,
140 													MixFrameOrderMode *mode);
141 
142 /*
143  * For discontiunity, reset FM
144  */
145 MIX_RESULT mix_framemanager_flush(MixFrameManager *fm);
146 
147 /*
148  * Enqueue MixVideoFrame
149  */
150 MIX_RESULT mix_framemanager_enqueue(MixFrameManager *fm, MixVideoFrame *mvf);
151 
152 /*
153  * Dequeue MixVideoFrame in proper order depends on MixFrameOrderMode value
154  * during initialization.
155  */
156 MIX_RESULT mix_framemanager_dequeue(MixFrameManager *fm, MixVideoFrame **mvf);
157 
158 /*
159  * End of stream.
160  */
161 MIX_RESULT mix_framemanager_eos(MixFrameManager *fm);
162 
163 
164 #endif /* __MIX_FRAMEMANAGER_H__ */
165