Changes in uspace/srv/net/udp/assoc.c [451481c8:a2e3ee6] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/srv/net/udp/assoc.c
r451481c8 ra2e3ee6 82 82 if (lsock != NULL) 83 83 assoc->ident.local = *lsock; 84 84 85 if (fsock != NULL) 85 86 assoc->ident.foreign = *fsock; … … 251 252 sp.foreign = *fsock; 252 253 253 if (sp.foreign.addr.ipv4 == 0 || sp.foreign.port == 0) 254 if ((inet_addr_is_any(&sp.foreign.addr)) || 255 (sp.foreign.port == UDP_PORT_ANY)) 254 256 return EINVAL; 255 257 … … 279 281 280 282 fibril_mutex_lock(&assoc->lock); 281 while (list_empty(&assoc->rcv_queue) ) {283 while (list_empty(&assoc->rcv_queue) && !assoc->reset) { 282 284 log_msg(LOG_DEFAULT, LVL_DEBUG, "udp_assoc_recv() - waiting"); 283 285 fibril_condvar_wait(&assoc->rcv_queue_cv, &assoc->lock); 286 } 287 288 if (assoc->reset) { 289 log_msg(LOG_DEFAULT, LVL_DEBUG, "udp_assoc_recv() - association was reset"); 290 fibril_mutex_unlock(&assoc->lock); 291 return ECONNABORTED; 284 292 } 285 293 … … 323 331 } 324 332 333 /** Reset association. 334 * 335 * This causes any pendingreceive operations to return immediately with 336 * UDP_ERESET. 337 */ 338 void udp_assoc_reset(udp_assoc_t *assoc) 339 { 340 fibril_mutex_lock(&assoc->lock); 341 assoc->reset = true; 342 fibril_condvar_broadcast(&assoc->rcv_queue_cv); 343 fibril_mutex_unlock(&assoc->lock); 344 } 345 325 346 static int udp_assoc_queue_msg(udp_assoc_t *assoc, udp_sockpair_t *sp, 326 347 udp_msg_t *msg) … … 351 372 static bool udp_socket_match(udp_sock_t *sock, udp_sock_t *patt) 352 373 { 353 log_msg(LOG_DEFAULT, LVL_DEBUG, "udp_socket_match(sock=(%x,%u), pat=(%x,%u))", 354 sock->addr.ipv4, sock->port, patt->addr.ipv4, patt->port); 355 356 if (patt->addr.ipv4 != UDP_IPV4_ANY && 357 patt->addr.ipv4 != sock->addr.ipv4) 374 if ((!inet_addr_is_any(&patt->addr)) && 375 (!inet_addr_compare(&patt->addr, &sock->addr))) 358 376 return false; 359 360 if ( patt->port != UDP_PORT_ANY&&361 patt->port != sock->port)377 378 if ((patt->port != UDP_PORT_ANY) && 379 (patt->port != sock->port)) 362 380 return false; 363 381 364 382 log_msg(LOG_DEFAULT, LVL_DEBUG, " -> match"); 365 383 366 384 return true; 367 385 } … … 395 413 { 396 414 log_msg(LOG_DEFAULT, LVL_DEBUG, "udp_assoc_find_ref(%p)", sp); 397 415 398 416 fibril_mutex_lock(&assoc_list_lock); 399 417 400 418 list_foreach(assoc_list, link) { 401 419 udp_assoc_t *assoc = list_get_instance(link, udp_assoc_t, link); 402 420 udp_sockpair_t *asp = &assoc->ident; 403 log_msg(LOG_DEFAULT, LVL_DEBUG, "compare with assoc (f:(%x,%u), l:(%x,%u))", 404 asp->foreign.addr.ipv4, asp->foreign.port, 405 asp->local.addr.ipv4, asp->local.port); 406 421 407 422 /* Skip unbound associations */ 408 423 if (asp->local.port == UDP_PORT_ANY) 409 424 continue; 410 425 411 426 if (udp_sockpair_match(sp, asp)) { 412 427 log_msg(LOG_DEFAULT, LVL_DEBUG, "Returning assoc %p", assoc); … … 416 431 } 417 432 } 418 433 419 434 fibril_mutex_unlock(&assoc_list_lock); 420 435 return NULL;
Note:
See TracChangeset
for help on using the changeset viewer.