diff --git a/android/avrcp-lib.c b/android/avrcp-lib.c
index f3cdab9..60d6e97 100644
--- a/android/avrcp-lib.c
+++ b/android/avrcp-lib.c
ret = handler->func(session, transaction, pdu->params_len, pdu->params,
session->control_data);
+ if (ret == 0)
+ return -EAGAIN;
+
if (ret < 0) {
if (ret == -EAGAIN)
return ret;
ret = handler->func(session, transaction, pdu->params_len, pdu->params,
session->control_data);
+ if (ret == 0)
+ return -EAGAIN;
+
if (ret < 0) {
if (ret == -EAGAIN)
return ret;
if (err < 0)
return -EINVAL;
- return -EAGAIN;
+ return 0;
}
static ssize_t abort_continuing(struct avrcp *session, uint8_t transaction,
continuing_free(session->continuing);
session->continuing = NULL;
+ avrcp_send_internal(session, transaction, AVC_CTYPE_ACCEPTED,
+ AVC_SUBUNIT_PANEL, AVRCP_ABORT_CONTINUING,
+ AVRCP_PACKET_TYPE_SINGLE, NULL, 0);
+
return 0;
}
diff --git a/android/avrcp.c b/android/avrcp.c
index 940de0b..a0d412d 100644
--- a/android/avrcp.c
+++ b/android/avrcp.c
avrcp_get_capabilities_rsp(session, transaction, sizeof(events),
events);
- return -EAGAIN;
+ return 0;
}
static void push_request(struct avrcp_device *dev, uint8_t pdu_id,
push_request(dev, AVRCP_GET_PLAY_STATUS, 0, transaction);
- return -EAGAIN;
+ return 0;
}
static int handle_get_element_attrs_cmd(struct avrcp *session,
push_request(dev, AVRCP_GET_ELEMENT_ATTRIBUTES, 0, transaction);
- return -EAGAIN;
+ return 0;
}
push_request(dev, AVRCP_REGISTER_NOTIFICATION, event, transaction);
- return -EAGAIN;
+ return 0;
}
static const struct avrcp_control_ind control_ind = {
diff --git a/unit/test-avrcp.c b/unit/test-avrcp.c
index a6a1872..4f6526c 100644
--- a/unit/test-avrcp.c
+++ b/unit/test-avrcp.c
avrcp_list_player_attributes_rsp(session, transaction, 0, NULL);
- return -EAGAIN;
+ return 0;
}
static int get_attribute_text(struct avrcp *session, uint8_t transaction,
avrcp_get_player_attribute_text_rsp(session, transaction, number, attrs,
text);
- return -EAGAIN;
+ return 0;
}
static int list_values(struct avrcp *session, uint8_t transaction,
avrcp_get_current_player_value_rsp(session, transaction, number, attrs,
values);
- return -EAGAIN;
+ return 0;
}
static int set_value(struct avrcp *session, uint8_t transaction,
avrcp_set_player_value_rsp(session, transaction);
- return -EAGAIN;
+ return 0;
}
static int get_play_status(struct avrcp *session, uint8_t transaction,
avrcp_get_play_status_rsp(session, transaction, 0xaaaaaaaa, 0xbbbbbbbb,
0x00);
- return -EAGAIN;
+ return 0;
}
static int get_element_attributes(struct avrcp *session, uint8_t transaction,
} else
avrcp_get_element_attrs_rsp(session, transaction, NULL, 0);
- return -EAGAIN;
+ return 0;
}
static int track_changed(struct avrcp *session, uint8_t transaction,
AVRCP_EVENT_TRACK_CHANGED,
&track, sizeof(track));
- return -EAGAIN;
+ return 0;
}
static int settings_changed(struct avrcp *session, uint8_t transaction,
AVRCP_EVENT_SETTINGS_CHANGED,
settings, sizeof(settings));
- return -EAGAIN;
+ return 0;
}
static int available_players_changed(struct avrcp *session, uint8_t transaction,
AVRCP_EVENT_AVAILABLE_PLAYERS_CHANGED,
NULL, 0);
- return -EAGAIN;
+ return 0;
}
static int addressed_player_changed(struct avrcp *session, uint8_t transaction,
AVRCP_EVENT_ADDRESSED_PLAYER_CHANGED,
player, sizeof(player));
- return -EAGAIN;
+ return 0;
}
static int uids_changed(struct avrcp *session, uint8_t transaction,
if (!g_str_equal(context->data->test_name, "/TP/MCN/CB/BV-11-C") &&
!g_str_equal(context->data->test_name, "/TP/MCN/CB/BI-05-C"))
- return -EAGAIN;
+ return 0;
avrcp_register_notification_rsp(session, transaction, AVC_CTYPE_CHANGED,
AVRCP_EVENT_UIDS_CHANGED,
&counter, sizeof(counter));
- return -EAGAIN;
+ return 0;
}
static int register_notification(struct avrcp *session, uint8_t transaction,
avrcp_set_volume_rsp(session, transaction, volume);
- return -EAGAIN;
+ return 0;
}
static int set_addressed(struct avrcp *session, uint8_t transaction,
avrcp_set_addressed_player_rsp(session, transaction, status);
- return -EAGAIN;
+ return 0;
}
static int set_browsed(struct avrcp *session, uint8_t transaction,
AVRCP_STATUS_SUCCESS,
0xabcd, 0, 1, folders);
- return -EAGAIN;
+ return 0;
}
static int get_folder_items(struct avrcp *session, uint8_t transaction,
avrcp_get_folder_items_rsp(session, transaction, AVRCP_STATUS_SUCCESS,
0xabcd, 0, NULL, NULL, NULL);
- return -EAGAIN;
+ return 0;
}
static int change_path(struct avrcp *session, uint8_t transaction,
avrcp_change_path_rsp(session, transaction, AVRCP_STATUS_SUCCESS, 0);
- return -EAGAIN;
+ return 0;
}
static int get_item_attributes(struct avrcp *session, uint8_t transaction,
avrcp_get_item_attributes_rsp(session, transaction, status, 0, NULL,
NULL);
- return -EAGAIN;
+ return 0;
}
static int play_item(struct avrcp *session, uint8_t transaction, uint8_t scope,
avrcp_play_item_rsp(session, transaction, AVRCP_STATUS_SUCCESS);
- return -EAGAIN;
+ return 0;
}
static int search(struct avrcp *session, uint8_t transaction,
avrcp_search_rsp(session, transaction, AVRCP_STATUS_SUCCESS, 0xaabb, 0);
- return -EAGAIN;
+ return 0;
}
static int add_to_now_playing(struct avrcp *session, uint8_t transaction,
avrcp_add_to_now_playing_rsp(session, transaction,
AVRCP_STATUS_SUCCESS);
- return -EAGAIN;
+ return 0;
}
static const struct avrcp_control_ind control_ind = {