Changes in uspace/srv/net/udp/assoc.c [451481c8:c0f3460] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/srv/net/udp/assoc.c
r451481c8 rc0f3460 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 log_msg(LOG_DEFAULT, LVL_DEBUG, 375 "udp_socket_match(sock=(%u), pat=(%u))", sock->port, patt->port); 376 377 if ((!inet_addr_is_any(&patt->addr)) && 378 (!inet_addr_compare(&patt->addr, &sock->addr))) 358 379 return false; 359 360 if ( patt->port != UDP_PORT_ANY&&361 patt->port != sock->port)380 381 if ((patt->port != UDP_PORT_ANY) && 382 (patt->port != sock->port)) 362 383 return false; 363 384 364 385 log_msg(LOG_DEFAULT, LVL_DEBUG, " -> match"); 365 386 366 387 return true; 367 388 } … … 395 416 { 396 417 log_msg(LOG_DEFAULT, LVL_DEBUG, "udp_assoc_find_ref(%p)", sp); 397 418 398 419 fibril_mutex_lock(&assoc_list_lock); 399 420 400 421 list_foreach(assoc_list, link) { 401 422 udp_assoc_t *assoc = list_get_instance(link, udp_assoc_t, link); 402 423 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 424 407 425 /* Skip unbound associations */ 408 426 if (asp->local.port == UDP_PORT_ANY) 409 427 continue; 410 428 411 429 if (udp_sockpair_match(sp, asp)) { 412 430 log_msg(LOG_DEFAULT, LVL_DEBUG, "Returning assoc %p", assoc); … … 416 434 } 417 435 } 418 436 419 437 fibril_mutex_unlock(&assoc_list_lock); 420 438 return NULL;
Note:
See TracChangeset
for help on using the changeset viewer.