[svn-commits] dvossel: branch dvossel/fixtheworld_phase1_step3 r303902 - /team/dvossel/fixt...
SVN commits to the Digium repositories
svn-commits at lists.digium.com
Tue Jan 25 13:35:44 CST 2011
Author: dvossel
Date: Tue Jan 25 13:35:41 2011
New Revision: 303902
URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=303902
Log:
Addresses reviewboard comments
Modified:
team/dvossel/fixtheworld_phase1_step3/main/format.c
team/dvossel/fixtheworld_phase1_step3/main/format_cap.c
team/dvossel/fixtheworld_phase1_step3/main/translate.c
Modified: team/dvossel/fixtheworld_phase1_step3/main/format.c
URL: http://svnview.digium.com/svn/asterisk/team/dvossel/fixtheworld_phase1_step3/main/format.c?view=diff&rev=303902&r1=303901&r2=303902
==============================================================================
--- team/dvossel/fixtheworld_phase1_step3/main/format.c (original)
+++ team/dvossel/fixtheworld_phase1_step3/main/format.c Tue Jan 25 13:35:41 2011
@@ -262,15 +262,11 @@
}
ast_rwlock_rdlock(&wrapper->wraplock);
- if (!wrapper->interface || !wrapper->interface->format_attr_get_joint) {
- ast_rwlock_unlock(&wrapper->wraplock);
- ao2_ref(wrapper, -1);
- return res;
- }
-
- res = wrapper->interface->format_attr_get_joint(&format1->fattr, &format2->fattr, &result->fattr);
-
+ if (wrapper->interface && wrapper->interface->format_attr_get_joint) {
+ res = wrapper->interface->format_attr_get_joint(&format1->fattr, &format2->fattr, &result->fattr);
+ }
ast_rwlock_unlock(&wrapper->wraplock);
+
ao2_ref(wrapper, -1);
return res;
@@ -492,10 +488,13 @@
int ast_format_attr_init()
{
- if (!(interfaces = ao2_container_alloc(256, interface_hash_cb, interface_cmp_cb))) {
- return -1;
- }
- ast_rwlock_init(&ilock);
+ if (ast_rwlock_init(&ilock)) {
+ return -1;
+ }
+ if (!(interfaces = ao2_container_alloc(283, interface_hash_cb, interface_cmp_cb))) {
+ ast_rwlock_destroy(&ilock);
+ return -1;
+ }
return 0;
}
Modified: team/dvossel/fixtheworld_phase1_step3/main/format_cap.c
URL: http://svnview.digium.com/svn/asterisk/team/dvossel/fixtheworld_phase1_step3/main/format_cap.c?view=diff&rev=303902&r1=303901&r2=303902
==============================================================================
--- team/dvossel/fixtheworld_phase1_step3/main/format_cap.c (original)
+++ team/dvossel/fixtheworld_phase1_step3/main/format_cap.c Tue Jan 25 13:35:41 2011
@@ -71,7 +71,7 @@
return NULL;
}
cap->nolock = nolock ? OBJ_NOLOCK : 0;
- if (!(cap->formats = ao2_container_alloc(256, hash_cb, cmp_cb))) {
+ if (!(cap->formats = ao2_container_alloc(283, hash_cb, cmp_cb))) {
ast_free(cap);
return NULL;
}
@@ -257,21 +257,19 @@
return -1;
}
+static int multiple_by_type_cb(void *obj, void *arg, int flag)
+{
+ int *type = arg;
+ struct ast_format *format = obj;
+ return ((AST_FORMAT_GET_TYPE(format->id)) == *type) ? CMP_MATCH : 0;
+}
+
void ast_format_cap_remove_bytype(struct ast_format_cap *cap, enum ast_format_type type)
{
- /* There is no benifit of using an ao2 callback here. Instead
- * the container is just interated over */
- struct ao2_iterator it;
- struct ast_format *tmp;
-
- it = ao2_iterator_init(cap->formats, cap->nolock ? AO2_ITERATOR_DONTLOCK : 0);
- while ((tmp = ao2_iterator_next(&it))) {
- if (AST_FORMAT_GET_TYPE(tmp->id) == type) {
- ao2_callback(cap->formats, OBJ_UNLINK | OBJ_POINTER | OBJ_NODATA | cap->nolock, cmp_cb, tmp);
- }
- ao2_ref(tmp, -1);
- }
- ao2_iterator_destroy(&it);
+ ao2_callback(cap->formats,
+ OBJ_UNLINK | OBJ_NODATA | OBJ_MULTIPLE | cap->nolock,
+ multiple_by_type_cb,
+ &type);
}
void ast_format_cap_remove_all(struct ast_format_cap *cap)
@@ -326,9 +324,10 @@
{
struct ao2_iterator it;
struct ast_format *tmp;
- struct find_joint_data data;
- data.joint_found = 0;
- data.joint_cap = NULL;
+ struct find_joint_data data = {
+ .joint_found = 0,
+ .joint_cap = NULL,
+ };
it = ao2_iterator_init(cap1->formats, cap1->nolock ? AO2_ITERATOR_DONTLOCK : 0);
while ((tmp = ao2_iterator_next(&it))) {
@@ -372,13 +371,13 @@
struct ao2_iterator it;
struct ast_format_cap *result = ast_format_cap_alloc_nolock();
struct ast_format *tmp;
- struct find_joint_data data;
-
+ struct find_joint_data data = {
+ .joint_found = 0,
+ .joint_cap = result,
+ };
if (!result) {
return NULL;
}
- data.joint_cap = result;
- data.joint_found = 0;
it = ao2_iterator_init(cap1->formats, cap1->nolock ? AO2_ITERATOR_DONTLOCK : 0);
while ((tmp = ao2_iterator_next(&it))) {
Modified: team/dvossel/fixtheworld_phase1_step3/main/translate.c
URL: http://svnview.digium.com/svn/asterisk/team/dvossel/fixtheworld_phase1_step3/main/translate.c?view=diff&rev=303902&r1=303901&r2=303902
==============================================================================
--- team/dvossel/fixtheworld_phase1_step3/main/translate.c (original)
+++ team/dvossel/fixtheworld_phase1_step3/main/translate.c Tue Jan 25 13:35:41 2011
@@ -56,7 +56,7 @@
struct ast_translator *step; /*!< Next step translator */
uint32_t table_cost; /*!< Complete table cost to destination */
uint8_t multistep; /*!< Multiple conversions required for this translation */
-} __attribute__((packed));
+};
/*!
* \brief a matrix that, for any pair of supported formats,
@@ -113,7 +113,7 @@
return -1; /* not found */
}
-/*
+/*!
* \internal
* \brief add a new format to the matrix and index table structures.
*
@@ -145,7 +145,7 @@
* \internal
* \brief converts index value back to format id
*/
-static force_inline enum ast_format_id index2format(int index)
+static enum ast_format_id index2format(int index)
{
enum ast_format_id format_id;
@@ -159,7 +159,7 @@
return format_id;
}
-/*
+/*!
* \internal
* \brief resize both the matrix and index table so they can represent
* more translators
More information about the svn-commits
mailing list