diff options
author | Andrzej Hajda <a.hajda@samsung.com> | 2012-07-02 10:50:47 +0200 |
---|---|---|
committer | Marek Szyprowski <m.szyprowski@samsung.com> | 2012-07-02 11:17:43 +0200 |
commit | 8b8182da6e16dfd0820ef2418c1bb66d4bcc8079 (patch) | |
tree | e1e318e1ebc676a16d6eea7b1f659482f2d93ebf /v4l2-mfc-encoder/common.h | |
parent | a7e755629a74a7ac137882032a0f7b2480fa1490 (diff) |
v4l-mfc-encoder: version 0.1
Signed-off-by: Andrzej Hajda <a.hajda@samsung.com>
Signed-off-by: Kamil Debski <k.debski@samsung.com>
Diffstat (limited to 'v4l2-mfc-encoder/common.h')
-rw-r--r-- | v4l2-mfc-encoder/common.h | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/v4l2-mfc-encoder/common.h b/v4l2-mfc-encoder/common.h new file mode 100644 index 0000000..ef5276f --- /dev/null +++ b/v4l2-mfc-encoder/common.h @@ -0,0 +1,66 @@ +/* + * mfc codec encoding example application + * Andrzej Hajda <a.hajda@samsung.com> + * + * Common structures. + * + * Copyright 2012 Samsung Electronics Co., Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ + +#ifndef COMMON_H +#define COMMON_H + +#include <stdio.h> +#include <string.h> + +/* When ADD_DETAILS is defined every debug and error message contains + * information about the file, function and line of code where it has + * been called */ +#define ADD_DETAILS +/* When DEBUG is defined debug messages are printed on the screen. + * Otherwise only error messages are displayed. */ +#define DEBUG + +#ifdef ADD_DETAILS +#define err(msg, ...) \ + fprintf(stderr, "%s:%s:%d: error: " msg "\n", __FILE__, \ + __func__, __LINE__, ##__VA_ARGS__) +#else +#define err(msg, ...) \ + fprintf(stderr, "Error: " msg "\n", __FILE__, ##__VA_ARGS__) +#endif /* ADD_DETAILS */ + +#ifdef DEBUG +#ifdef ADD_DETAILS +#include <time.h> +#define dbg(msg, ...) { \ + struct timespec t; \ + clock_gettime(CLOCK_MONOTONIC, &t); \ + fprintf(stderr, "%ld.%ld:%s:%s:%d: " msg "\n", t.tv_sec, t.tv_nsec, __FILE__, \ + __func__, __LINE__, ##__VA_ARGS__); \ +} +#else +#define dbg(msg, ...) \ + fprintf(stderr, msg "\n", ##__VA_ARGS__) +#endif /* ADD_DETAILS */ +#else /* DEBUG */ +#define dbg(...) {} +#endif /* DEBUG */ + +#define array_len(arr) (sizeof(arr) / sizeof(arr[0])) +#define memzero(d) memset(&(d), 0, sizeof(d)) + +#endif |