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_VIDEOFRAME_H__
10#define __MIX_VIDEOFRAME_H__
11
12#include <mixparams.h>
13#include "mixvideodef.h"
14
15/**
16 * MIX_TYPE_VIDEOFRAME:
17 *
18 * Get type of class.
19 */
20#define MIX_TYPE_VIDEOFRAME (mix_videoframe_get_type ())
21
22/**
23 * MIX_VIDEOFRAME:
24 * @obj: object to be type-casted.
25 */
26#define MIX_VIDEOFRAME(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), MIX_TYPE_VIDEOFRAME, MixVideoFrame))
27
28/**
29 * MIX_IS_VIDEOFRAME:
30 * @obj: an object.
31 *
32 * Checks if the given object is an instance of #MixVideoFrame
33 */
34#define MIX_IS_VIDEOFRAME(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), MIX_TYPE_VIDEOFRAME))
35
36/**
37 * MIX_VIDEOFRAME_CLASS:
38 * @klass: class to be type-casted.
39 */
40#define MIX_VIDEOFRAME_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), MIX_TYPE_VIDEOFRAME, MixVideoFrameClass))
41
42/**
43 * MIX_IS_VIDEOFRAME_CLASS:
44 * @klass: a class.
45 *
46 * Checks if the given class is #MixVideoFrameClass
47 */
48#define MIX_IS_VIDEOFRAME_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), MIX_TYPE_VIDEOFRAME))
49
50/**
51 * MIX_VIDEOFRAME_GET_CLASS:
52 * @obj: a #MixVideoFrame object.
53 *
54 * Get the class instance of the object.
55 */
56#define MIX_VIDEOFRAME_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), MIX_TYPE_VIDEOFRAME, MixVideoFrameClass))
57
58typedef struct _MixVideoFrame MixVideoFrame;
59typedef struct _MixVideoFrameClass MixVideoFrameClass;
60
61/**
62 * MixVideoFrame:
63 *
64 * MI-X VideoConfig Parameter object
65 */
66struct _MixVideoFrame {
67	/*< public > */
68	MixParams parent;
69
70	/*< public > */
71	gulong frame_id;
72	guint ci_frame_idx;
73	guint64 timestamp;
74	gboolean discontinuity;
75	guint32 frame_structure; // 0: frame, 1: top field, 2: bottom field
76
77	void *reserved1;
78	void *reserved2;
79	void *reserved3;
80	void *reserved4;
81};
82
83/**
84 * MixVideoFrameClass:
85 *
86 * MI-X VideoConfig object class
87 */
88struct _MixVideoFrameClass {
89	/*< public > */
90	MixParamsClass parent_class;
91
92	/* class members */
93};
94
95/**
96 * mix_videoframe_get_type:
97 * @returns: type
98 *
99 * Get the type of object.
100 */
101GType mix_videoframe_get_type(void);
102
103/**
104 * mix_videoframe_new:
105 * @returns: A newly allocated instance of #MixVideoFrame
106 *
107 * Use this method to create new instance of #MixVideoFrame
108 */
109MixVideoFrame *mix_videoframe_new(void);
110/**
111 * mix_videoframe_ref:
112 * @mix: object to add reference
113 * @returns: the MixVideoFrame instance where reference count has been increased.
114 *
115 * Add reference count.
116 */
117MixVideoFrame *mix_videoframe_ref(MixVideoFrame * obj);
118
119/**
120 * mix_videoframe_unref:
121 * @obj: object to unref.
122 *
123 * Decrement reference count of the object.
124 */
125void mix_videoframe_unref(MixVideoFrame * obj);
126
127/* Class Methods */
128
129MIX_RESULT mix_videoframe_set_frame_id(MixVideoFrame * obj, gulong frame_id);
130MIX_RESULT mix_videoframe_get_frame_id(MixVideoFrame * obj, gulong * frame_id);
131
132MIX_RESULT mix_videoframe_set_ci_frame_idx(MixVideoFrame * obj, guint ci_frame_idx);
133MIX_RESULT mix_videoframe_get_ci_frame_idx(MixVideoFrame * obj, guint * ci_frame_idx);
134
135MIX_RESULT mix_videoframe_set_timestamp(MixVideoFrame * obj, guint64 timestamp);
136MIX_RESULT mix_videoframe_get_timestamp(MixVideoFrame * obj, guint64 * timestamp);
137
138MIX_RESULT mix_videoframe_set_discontinuity(MixVideoFrame * obj, gboolean discontinuity);
139MIX_RESULT mix_videoframe_get_discontinuity(MixVideoFrame * obj, gboolean * discontinuity);
140
141MIX_RESULT mix_videoframe_set_frame_structure(MixVideoFrame * obj, guint32 frame_structure);
142MIX_RESULT mix_videoframe_get_frame_structure(MixVideoFrame * obj, guint32* frame_structure);
143
144#endif /* __MIX_VIDEOFRAME_H__ */
145