Integrate DNS with address parsing
This commit is contained in:
parent
8d4e4fc0e5
commit
f0f4253cd2
4 changed files with 124 additions and 4 deletions
|
@ -32,7 +32,7 @@
|
||||||
GRUB_MOD_LICENSE ("GPLv3+");
|
GRUB_MOD_LICENSE ("GPLv3+");
|
||||||
|
|
||||||
/* Real mode IVT slot (seg:off far pointer) for interrupt 0x13. */
|
/* Real mode IVT slot (seg:off far pointer) for interrupt 0x13. */
|
||||||
static grub_uint32_t *const int13slot = UINT_TO_PTR (4 * 0x13);
|
static grub_uint32_t *const int13slot = (void *) (4 * 0x13);
|
||||||
|
|
||||||
/* Remember to update enum opt_idxs accordingly. */
|
/* Remember to update enum opt_idxs accordingly. */
|
||||||
static const struct grub_arg_option options[] = {
|
static const struct grub_arg_option options[] = {
|
||||||
|
|
|
@ -35,6 +35,41 @@ struct dns_cache_element
|
||||||
#define DNS_HASH_BASE 423
|
#define DNS_HASH_BASE 423
|
||||||
|
|
||||||
static struct dns_cache_element dns_cache[DNS_CACHE_SIZE];
|
static struct dns_cache_element dns_cache[DNS_CACHE_SIZE];
|
||||||
|
static struct grub_net_network_level_address *dns_servers;
|
||||||
|
static grub_size_t dns_nservers, dns_servers_alloc;
|
||||||
|
|
||||||
|
grub_err_t
|
||||||
|
grub_net_add_dns_server (const struct grub_net_network_level_address *s)
|
||||||
|
{
|
||||||
|
if (dns_servers_alloc <= dns_nservers)
|
||||||
|
{
|
||||||
|
int na = dns_servers_alloc * 2;
|
||||||
|
struct grub_net_network_level_address *ns;
|
||||||
|
if (na < 8)
|
||||||
|
na = 8;
|
||||||
|
ns = grub_malloc (na * sizeof (ns[0]));
|
||||||
|
if (!ns)
|
||||||
|
return grub_errno;
|
||||||
|
dns_servers_alloc = na;
|
||||||
|
dns_servers = ns;
|
||||||
|
}
|
||||||
|
dns_servers[dns_nservers++] = *s;
|
||||||
|
return GRUB_ERR_NONE;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
grub_net_remove_dns_server (const struct grub_net_network_level_address *s)
|
||||||
|
{
|
||||||
|
grub_size_t i;
|
||||||
|
for (i = 0; i < dns_nservers; i++)
|
||||||
|
if (grub_net_addr_cmp (s, &dns_servers[i]) == 0)
|
||||||
|
break;
|
||||||
|
if (i < dns_nservers)
|
||||||
|
{
|
||||||
|
dns_servers[i] = dns_servers[dns_nservers - 1];
|
||||||
|
dns_nservers--;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
struct dns_header
|
struct dns_header
|
||||||
{
|
{
|
||||||
|
@ -394,6 +429,15 @@ grub_net_dns_lookup (const char *name,
|
||||||
grub_uint8_t *nbd;
|
grub_uint8_t *nbd;
|
||||||
int have_server = 0;
|
int have_server = 0;
|
||||||
|
|
||||||
|
if (!servers)
|
||||||
|
{
|
||||||
|
servers = dns_servers;
|
||||||
|
n_servers = dns_nservers;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!n_servers)
|
||||||
|
return grub_error (GRUB_ERR_BAD_ARGUMENT, "no DNS servers");
|
||||||
|
|
||||||
*naddresses = 0;
|
*naddresses = 0;
|
||||||
if (cache)
|
if (cache)
|
||||||
{
|
{
|
||||||
|
@ -572,10 +616,58 @@ grub_cmd_nslookup (struct grub_command *cmd __attribute__ ((unused)),
|
||||||
grub_net_addr_to_str (&addresses[i], buf);
|
grub_net_addr_to_str (&addresses[i], buf);
|
||||||
grub_printf ("%s\n", buf);
|
grub_printf ("%s\n", buf);
|
||||||
}
|
}
|
||||||
|
grub_free (addresses);
|
||||||
return GRUB_ERR_NONE;
|
return GRUB_ERR_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static grub_command_t cmd;
|
static grub_err_t
|
||||||
|
grub_cmd_list_dns (struct grub_command *cmd __attribute__ ((unused)),
|
||||||
|
int argc __attribute__ ((unused)),
|
||||||
|
char **args __attribute__ ((unused)))
|
||||||
|
{
|
||||||
|
grub_size_t i;
|
||||||
|
for (i = 0; i < dns_nservers; i++)
|
||||||
|
{
|
||||||
|
char buf[GRUB_NET_MAX_STR_ADDR_LEN];
|
||||||
|
grub_net_addr_to_str (&dns_servers[i], buf);
|
||||||
|
grub_printf ("%s\n", buf);
|
||||||
|
}
|
||||||
|
return GRUB_ERR_NONE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static grub_err_t
|
||||||
|
grub_cmd_add_dns (struct grub_command *cmd __attribute__ ((unused)),
|
||||||
|
int argc, char **args)
|
||||||
|
{
|
||||||
|
grub_err_t err;
|
||||||
|
struct grub_net_network_level_address server;
|
||||||
|
|
||||||
|
if (argc != 1)
|
||||||
|
return grub_error (GRUB_ERR_BAD_ARGUMENT, "1 argument expected");
|
||||||
|
err = grub_net_resolve_address (args[0], &server);
|
||||||
|
if (err)
|
||||||
|
return err;
|
||||||
|
|
||||||
|
return grub_net_add_dns_server (&server);
|
||||||
|
}
|
||||||
|
|
||||||
|
static grub_err_t
|
||||||
|
grub_cmd_del_dns (struct grub_command *cmd __attribute__ ((unused)),
|
||||||
|
int argc, char **args)
|
||||||
|
{
|
||||||
|
grub_err_t err;
|
||||||
|
struct grub_net_network_level_address server;
|
||||||
|
|
||||||
|
if (argc != 1)
|
||||||
|
return grub_error (GRUB_ERR_BAD_ARGUMENT, "1 argument expected");
|
||||||
|
err = grub_net_resolve_address (args[1], &server);
|
||||||
|
if (err)
|
||||||
|
return err;
|
||||||
|
|
||||||
|
return grub_net_add_dns_server (&server);
|
||||||
|
}
|
||||||
|
|
||||||
|
static grub_command_t cmd, cmd_add, cmd_del, cmd_list;
|
||||||
|
|
||||||
void
|
void
|
||||||
grub_dns_init (void)
|
grub_dns_init (void)
|
||||||
|
@ -583,10 +675,21 @@ grub_dns_init (void)
|
||||||
cmd = grub_register_command ("net_nslookup", grub_cmd_nslookup,
|
cmd = grub_register_command ("net_nslookup", grub_cmd_nslookup,
|
||||||
"ADDRESS DNSSERVER",
|
"ADDRESS DNSSERVER",
|
||||||
N_("perform a DNS lookup"));
|
N_("perform a DNS lookup"));
|
||||||
|
cmd_add = grub_register_command ("net_add_dns", grub_cmd_add_dns,
|
||||||
|
"DNSSERVER",
|
||||||
|
N_("add a DNS server"));
|
||||||
|
cmd_del = grub_register_command ("net_del_dns", grub_cmd_del_dns,
|
||||||
|
"DNSSERVER",
|
||||||
|
N_("remove a DNS server"));
|
||||||
|
cmd_list = grub_register_command ("net_del_dns", grub_cmd_list_dns,
|
||||||
|
NULL, N_("remove a DNS server"));
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
grub_dns_fini (void)
|
grub_dns_fini (void)
|
||||||
{
|
{
|
||||||
grub_unregister_command (cmd);
|
grub_unregister_command (cmd);
|
||||||
|
grub_unregister_command (cmd_add);
|
||||||
|
grub_unregister_command (cmd_del);
|
||||||
|
grub_unregister_command (cmd_list);
|
||||||
}
|
}
|
||||||
|
|
|
@ -501,6 +501,10 @@ grub_net_resolve_address (const char *name,
|
||||||
grub_net_network_level_address_t *addr)
|
grub_net_network_level_address_t *addr)
|
||||||
{
|
{
|
||||||
const char *rest;
|
const char *rest;
|
||||||
|
grub_err_t err;
|
||||||
|
grub_size_t naddresses;
|
||||||
|
struct grub_net_network_level_address *addresses;
|
||||||
|
|
||||||
if (parse_ip (name, &addr->ipv4, &rest) && *rest == 0)
|
if (parse_ip (name, &addr->ipv4, &rest) && *rest == 0)
|
||||||
{
|
{
|
||||||
addr->type = GRUB_NET_NETWORK_LEVEL_PROTOCOL_IPV4;
|
addr->type = GRUB_NET_NETWORK_LEVEL_PROTOCOL_IPV4;
|
||||||
|
@ -511,8 +515,16 @@ grub_net_resolve_address (const char *name,
|
||||||
addr->type = GRUB_NET_NETWORK_LEVEL_PROTOCOL_IPV6;
|
addr->type = GRUB_NET_NETWORK_LEVEL_PROTOCOL_IPV6;
|
||||||
return GRUB_ERR_NONE;
|
return GRUB_ERR_NONE;
|
||||||
}
|
}
|
||||||
return grub_error (GRUB_ERR_NET_BAD_ADDRESS, N_("unrecognised address %s"),
|
err = grub_net_dns_lookup (name, 0, 0, &naddresses, &addresses, 1);
|
||||||
|
if (err)
|
||||||
|
return err;
|
||||||
|
if (!naddresses)
|
||||||
|
grub_error (GRUB_ERR_NET_BAD_ADDRESS, N_("unresolvable address %s"),
|
||||||
name);
|
name);
|
||||||
|
/* FIXME: use other results as well. */
|
||||||
|
*addr = addresses[0];
|
||||||
|
grub_free (addresses);
|
||||||
|
return GRUB_ERR_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
grub_err_t
|
grub_err_t
|
||||||
|
|
|
@ -483,6 +483,11 @@ grub_net_dns_lookup (const char *name,
|
||||||
grub_size_t *naddresses,
|
grub_size_t *naddresses,
|
||||||
struct grub_net_network_level_address **addresses,
|
struct grub_net_network_level_address **addresses,
|
||||||
int cache);
|
int cache);
|
||||||
|
grub_err_t
|
||||||
|
grub_net_add_dns_server (const struct grub_net_network_level_address *s);
|
||||||
|
void
|
||||||
|
grub_net_remove_dns_server (const struct grub_net_network_level_address *s);
|
||||||
|
|
||||||
|
|
||||||
extern char *grub_net_default_server;
|
extern char *grub_net_default_server;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue