int i, len = 0;
int *datalen = NULL;
char *dest;
+ int subsystem_len = 0, code_len = 0;
if (n_data) {
len = n_data * sizeof(char *);
}
}
+ if (subsystem) {
+ subsystem_len = strlen(subsystem) + 1;
+ len += subsystem_len;
+ }
+
+ if (code) {
+ code_len = strlen(code) + 1;
+ len += code_len;
+ }
+
error = calloc(1, sizeof(*error) + sizeof(char *) + len);
if (!error)
return;
list_add_tail(&error->list, &iface->errors);
- error->subsystem = subsystem;
- error->code = code;
dest = (char *) &error->data[n_data + 1];
for (i = 0; i < n_data; i++) {
memcpy(dest, data[i], datalen[i]);
dest += datalen[i];
}
- error->data[n_data] = NULL;
+ error->data[n_data++] = NULL;
+
+ dest = (char *) &error->data[n_data];
+ if (subsystem) {
+ error->subsystem = dest;
+ strcpy(dest, subsystem);
+ dest += subsystem_len;
+ }
+
+ if (code) {
+ error->code = dest;
+ strcpy(dest, code);
+ dest += code_len;
+ }
}
static void
static void
interface_flush_state(struct interface *iface)
{
- if (iface->main_dev.dev)
- device_release(&iface->main_dev);
if (iface->l3_dev.dev)
device_release(&iface->l3_dev);
interface_data_flush(iface);
void
__interface_set_down(struct interface *iface, bool force)
{
- interface_clear_errors(iface);
-
if (iface->state == IFS_DOWN ||
iface->state == IFS_TEARDOWN)
return;
iface->state = IFS_UP;
iface->start_time = system_get_rtime();
interface_event(iface, IFEV_UP);
- interface_write_resolv_conf();
netifd_log_message(L_NOTICE, "Interface '%s' is now up\n", iface->name);
break;
case IFPEV_DOWN:
netifd_log_message(L_NOTICE, "Interface '%s' is now down\n", iface->name);
mark_interface_down(iface);
+ if (iface->main_dev.dev)
+ device_release(&iface->main_dev);
interface_handle_config_change(iface);
break;
case IFPEV_LINK_LOST:
iface->state = IFS_SETUP;
break;
}
+
+ interface_write_resolv_conf();
}
void interface_set_proto_state(struct interface *iface, struct interface_proto_state *state)