mirror of
https://github.com/DigitalDevices/octonet.git
synced 2023-10-10 13:36:52 +02:00
issue 45 and 46
This commit is contained in:
parent
f6c13c7a6b
commit
9251fed043
@ -59,9 +59,14 @@ static void update_switch_vec(struct ossess *sess)
|
|||||||
{
|
{
|
||||||
struct osmcc *mcc;
|
struct osmcc *mcc;
|
||||||
uint32_t vec = 0;
|
uint32_t vec = 0;
|
||||||
|
struct ossess *ownsess = sess->stream->session;
|
||||||
|
|
||||||
|
if (!sess->os->has_switch)
|
||||||
|
return;
|
||||||
for (mcc = sess->mccs.lh_first; mcc; mcc = mcc->mcc.le_next)
|
for (mcc = sess->mccs.lh_first; mcc; mcc = mcc->mcc.le_next)
|
||||||
vec |= mcc->port_vec;
|
vec |= mcc->port_vec;
|
||||||
|
if (conform && ownsess->trans.mcast && (ownsess->playing & 2))
|
||||||
|
vec |= 0x1f;
|
||||||
if (vec != sess->mcc_port_vec_set || sess->port_vec != sess->port_vec_set) {
|
if (vec != sess->mcc_port_vec_set || sess->port_vec != sess->port_vec_set) {
|
||||||
sess->mcc_port_vec_set = vec;
|
sess->mcc_port_vec_set = vec;
|
||||||
sess->port_vec_set = sess->port_vec;
|
sess->port_vec_set = sess->port_vec;
|
||||||
@ -468,7 +473,8 @@ static uint32_t session_is_playing(struct ossess *sess)
|
|||||||
return sess->playing;
|
return sess->playing;
|
||||||
pthread_mutex_lock(&os->lock);
|
pthread_mutex_lock(&os->lock);
|
||||||
for (i = 0; i < MAX_SESSION; i++)
|
for (i = 0; i < MAX_SESSION; i++)
|
||||||
if (os->session[i].state &&
|
if (os->session[i].state &&
|
||||||
|
os->session[i].trans.mcast &&
|
||||||
(os->session[i].stream == str)) {
|
(os->session[i].stream == str)) {
|
||||||
playing |= os->session[i].playing;
|
playing |= os->session[i].playing;
|
||||||
dbgprintf(DEBUG_DEBUG, "playing[%u] = %u\n",
|
dbgprintf(DEBUG_DEBUG, "playing[%u] = %u\n",
|
||||||
@ -1591,8 +1597,7 @@ static int setup_session(struct oscon *con, int newtrans)
|
|||||||
set_pmt(str->ca, p->pmt);
|
set_pmt(str->ca, p->pmt);
|
||||||
}
|
}
|
||||||
if (con->session->trans.mcast) {
|
if (con->session->trans.mcast) {
|
||||||
if (con->os->has_switch)
|
update_switch_vec(sess);
|
||||||
update_switch_vec(sess);
|
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -1602,29 +1607,29 @@ static int stop_session(struct ossess *sess)
|
|||||||
if (!session_is_playing(sess))
|
if (!session_is_playing(sess))
|
||||||
return 0;
|
return 0;
|
||||||
sess->playing &= ~1;
|
sess->playing &= ~1;
|
||||||
if (session_is_playing(sess))
|
if (!session_is_playing(sess)) {
|
||||||
return 0;
|
printf("stopping session %d\n", sess->nr);
|
||||||
printf("stopping session %d\n", sess->nr);
|
if (sess->nsfd >= 0)
|
||||||
if (sess->nsfd >= 0)
|
ioctl(sess->nsfd, NS_STOP);
|
||||||
ioctl(sess->nsfd, NS_STOP);
|
}
|
||||||
|
update_switch_vec(sess);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int start_session(struct ossess *sess)
|
static int start_session(struct ossess *sess)
|
||||||
{
|
{
|
||||||
if (session_is_playing(sess)) {
|
if (!session_is_playing(sess)) {
|
||||||
sess->playing |= 1;
|
dbgprintf(DEBUG_SYS, "start session %d\n", sess->nr);
|
||||||
return 0;
|
if (sess->stream->ca) {
|
||||||
}
|
uint8_t canum = sess->stream->ca->nr - 1;
|
||||||
dbgprintf(DEBUG_SYS, "start session %d\n", sess->nr);
|
if (sess->nsfd >= 0)
|
||||||
if (sess->stream->ca) {
|
ioctl(sess->nsfd, NS_SET_CI, &canum);
|
||||||
uint8_t canum = sess->stream->ca->nr - 1;
|
}
|
||||||
if (sess->nsfd >= 0)
|
if (sess->nsfd >= 0)
|
||||||
ioctl(sess->nsfd, NS_SET_CI, &canum);
|
ioctl(sess->nsfd, NS_START);
|
||||||
}
|
}
|
||||||
if (sess->nsfd >= 0)
|
|
||||||
ioctl(sess->nsfd, NS_START);
|
|
||||||
sess->playing |= 1;
|
sess->playing |= 1;
|
||||||
|
update_switch_vec(sess);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1653,13 +1658,15 @@ static int play_session(struct oscon *con)
|
|||||||
start_session(str->session);
|
start_session(str->session);
|
||||||
} else {
|
} else {
|
||||||
#ifndef IGNORE_NS
|
#ifndef IGNORE_NS
|
||||||
if (sess->nsfd < 0)
|
if (sess->nsfd < 0)
|
||||||
return -455;
|
return -455;
|
||||||
#endif
|
#endif
|
||||||
start_session(sess);
|
start_session(sess);
|
||||||
}
|
}
|
||||||
|
dbgprintf(DEBUG_SYS, "%s set playing =2\n", __FUNCTION__);
|
||||||
sess->playing |= 2;
|
sess->playing |= 2;
|
||||||
pthread_mutex_unlock(&os->lock);
|
pthread_mutex_unlock(&os->lock);
|
||||||
|
update_switch_vec(sess);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1672,6 +1679,8 @@ static struct ossess *match_session(struct octoserve *os, uint8_t *group)
|
|||||||
sess = &os->session[i];
|
sess = &os->session[i];
|
||||||
if (!sess->state || !sess->trans.mcast)
|
if (!sess->state || !sess->trans.mcast)
|
||||||
continue;
|
continue;
|
||||||
|
if (conform && sess->stream->session != sess)
|
||||||
|
continue;
|
||||||
if (!memcmp(sess->trans.mcip, group, 4))
|
if (!memcmp(sess->trans.mcip, group, 4))
|
||||||
return sess;
|
return sess;
|
||||||
}
|
}
|
||||||
@ -1699,10 +1708,9 @@ void mc_check(struct ossess *sess, int update)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (update) {
|
if (update) {
|
||||||
if (os->has_switch)
|
update_switch_vec(sess);
|
||||||
update_switch_vec(sess);
|
|
||||||
if (!sess->mccs.lh_first)
|
if (!sess->mccs.lh_first)
|
||||||
//if (mtime() > sess->mc_timeout)
|
//if (mtime() > sess->mc_timeout)
|
||||||
stop_session(sess);
|
stop_session(sess);
|
||||||
}
|
}
|
||||||
pthread_mutex_unlock(&os->lock);
|
pthread_mutex_unlock(&os->lock);
|
||||||
@ -1719,8 +1727,7 @@ void mc_del(struct ossess *sess)
|
|||||||
LIST_REMOVE(mcc, mcc);
|
LIST_REMOVE(mcc, mcc);
|
||||||
free(mcc);
|
free(mcc);
|
||||||
}
|
}
|
||||||
if (os->has_switch)
|
update_switch_vec(sess);
|
||||||
update_switch_vec(sess);
|
|
||||||
pthread_mutex_unlock(&os->lock);
|
pthread_mutex_unlock(&os->lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1779,8 +1786,7 @@ void mc_join(struct octoserve *os, uint8_t *ip, uint8_t *mac, uint8_t *group)
|
|||||||
newmcc->port_vec = port;
|
newmcc->port_vec = port;
|
||||||
sess->mcc_port_vec |= port;
|
sess->mcc_port_vec |= port;
|
||||||
}
|
}
|
||||||
if (os->has_switch)
|
update_switch_vec(sess);
|
||||||
update_switch_vec(sess);
|
|
||||||
}
|
}
|
||||||
if (!session_is_playing(sess))
|
if (!session_is_playing(sess))
|
||||||
start_session(sess);
|
start_session(sess);
|
||||||
@ -1823,8 +1829,7 @@ void mc_leave(struct octoserve *os, uint8_t *ip, uint8_t *group)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (os->has_switch)
|
update_switch_vec(sess);
|
||||||
update_switch_vec(sess);
|
|
||||||
out:
|
out:
|
||||||
pthread_mutex_unlock(&os->lock);
|
pthread_mutex_unlock(&os->lock);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user