mirror of
https://github.com/ipxe/ipxe
synced 2025-12-20 03:55:46 +03:00
Make URI structures reference-counted.
This commit is contained in:
@@ -121,7 +121,7 @@ int start_download ( const char *uri_string, struct async *parent,
|
||||
err:
|
||||
async_uninit ( &download->async );
|
||||
ufree ( download->buffer.addr );
|
||||
free_uri ( download->uri );
|
||||
uri_put ( download->uri );
|
||||
free ( download );
|
||||
return rc;
|
||||
}
|
||||
@@ -150,7 +150,7 @@ static void download_sigchld ( struct async *async,
|
||||
/* Discard the buffer */
|
||||
ufree ( download->buffer.addr );
|
||||
}
|
||||
free_uri ( download->uri );
|
||||
uri_put ( download->uri );
|
||||
download->uri = NULL;
|
||||
|
||||
/* Terminate ourselves */
|
||||
|
||||
@@ -52,6 +52,7 @@ static struct socket_opener socket_openers_end[0]
|
||||
int xfer_open_uri ( struct xfer_interface *xfer, const char *uri_string ) {
|
||||
struct uri *uri;
|
||||
struct uri_opener *opener;
|
||||
int rc = -ENOTSUP;
|
||||
|
||||
DBGC ( xfer, "XFER %p opening URI %s\n", xfer, uri_string );
|
||||
|
||||
@@ -61,14 +62,16 @@ int xfer_open_uri ( struct xfer_interface *xfer, const char *uri_string ) {
|
||||
|
||||
for ( opener = uri_openers ; opener < uri_openers_end ; opener++ ) {
|
||||
if ( strcmp ( uri->scheme, opener->scheme ) == 0 ) {
|
||||
return opener->open ( xfer, uri );
|
||||
rc = opener->open ( xfer, uri );
|
||||
goto done;
|
||||
}
|
||||
}
|
||||
|
||||
DBGC ( xfer, "XFER %p attempted to open unsupported URI scheme "
|
||||
"\"%s\"\n", xfer, uri->scheme );
|
||||
free_uri ( uri );
|
||||
return -ENOTSUP;
|
||||
done:
|
||||
uri_put ( uri );
|
||||
return rc;
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
@@ -35,7 +35,7 @@
|
||||
*
|
||||
* Splits a URI into its component parts. The return URI structure is
|
||||
* dynamically allocated and must eventually be freed by calling
|
||||
* free_uri().
|
||||
* uri_put().
|
||||
*/
|
||||
struct uri * parse_uri ( const char *uri_string ) {
|
||||
struct uri *uri;
|
||||
|
||||
Reference in New Issue
Block a user