X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Flogin%2Flogind-device.c;h=9ff91ba03568b2472aee6c229d783d8fcdbf02af;hb=d7d1c8f983599dca6ee30229375215978657c072;hp=2bcd6a10c5432cdbd2eaee4d92373e82664bf4b8;hpb=718d006a63f773c42106494e823250c48942cf08;p=elogind.git diff --git a/src/login/logind-device.c b/src/login/logind-device.c index 2bcd6a10c..9ff91ba03 100644 --- a/src/login/logind-device.c +++ b/src/login/logind-device.c @@ -67,13 +67,17 @@ void device_free(Device *d) { void device_detach(Device *d) { Seat *s; + SessionDevice *sd; assert(d); if (!d->seat) return; + while ((sd = d->session_devices)) + session_device_free(sd); + s = d->seat; - LIST_REMOVE(Device, devices, d->seat->devices, d); + LIST_REMOVE(devices, d->seat->devices, d); d->seat = NULL; if (!seat_has_master_device(s)) { @@ -106,11 +110,11 @@ void device_attach(Device *d, Seat *s) { * per seat, so we iterate only a few times. */ if (d->master || !s->devices) - LIST_PREPEND(Device, devices, s->devices, d); + LIST_PREPEND(devices, s->devices, d); else { LIST_FOREACH(devices, i, s->devices) { if (!i->devices_next || !i->master) { - LIST_INSERT_AFTER(Device, devices, s->devices, i, d); + LIST_INSERT_AFTER(devices, s->devices, i, d); break; } }