Warum Debian und/oder eine seiner Spielarten? Was muss ich vorher wissen? Wo geht es nach der Installation weiter?
-
TomL
Beitrag
von TomL » 29.01.2018 21:09:17
Xantorix hat geschrieben: 29.01.2018 20:53:36
Was müsste ich für die entsprechende Unit tun?
Code: Alles auswählen
[Unit]
Description=thlu:before-shutdown.service: Start at shutdown, reboot, halt
DefaultDependencies=no
Before=shutdown.target reboot.target halt.target
[Service]
Type=oneshot
ExecStart=/bin/sh -c "pkill roger"
[Install]
RequiredBy=shutdown.target reboot.target halt.target
Rechte setzen: root:root, 644
Das sollte aber nur eine vorübergehende Lösung sein! Ich würde unbedingt den Weg verfolgen, wie NAB ihn schon vorgeschlagen hat... und zwar in diesem Forum zum Programm Roger.
-
Xantorix
- Beiträge: 177
- Registriert: 27.01.2018 13:33:06
Beitrag
von Xantorix » 29.01.2018 21:15:27
Danke. Bevor ich das probiere warte ich mal auf ne Antwort von Tabos.
Wie schon geschrieben gibt es leider keine mir bekannte Alternative zu Roger Router.
Gruß Xante
-
TomL
Beitrag
von TomL » 29.01.2018 21:20:08
NAB hat geschrieben: 29.01.2018 20:59:16
TomL hat geschrieben: 29.01.2018 19:52:43
Das läuft über systemd-automount und ich denke, dass da kein Problem besteht.
Wie könnte das funktionieren? Systemd kann doch nicht in das Flatpak reingucken ... und das Flatpak keine Automount-Unit erstellen?
Nöö, das hat meiner Meinung nach gar nix mit flatpak zu tun, das ist anscheinend der ganz normale automount, der immer funktioniert. Flatpak nutzt anscheinend nur einen sowieso vorhandenen Mount.
Das sehe ich ähnlich ... aber dazu, ein eigenes Mint-Repository für die neusten RogerRouter-Versionen zu unterhalten, hat anscheinend auch keiner Bock ...
Ich halte das ganze Konstrukt für zweifelhaft, nicht nur flatpak ... also, vor dem Hintergrund betrieblich genutzter Systeme.
-
geier22
Beitrag
von geier22 » 29.01.2018 21:25:13
Ich hab ja kaum bis gar keine Ahnung von Flatpaks aber in dem neuen Log funktioniert ja schon das Starten des Flatpaks nicht richtig:
Code: Alles auswählen
Jan 29 17:55:32 xante-I7 org.freedesktop.systemd1[1643]: ** (process:1655): WARNING **: cgmanager method call org.linuxcontainers.cgmanager0_0.SetValue failed: GDBus.Error:org.freedesktop.DBus.Error.InvalidArgs: invalid request. Use G_DBUS_DEBUG=message for more info.
Jan 29 17:55:32 xante-I7 org.freedesktop.systemd1[1643]: ** (process:1655): CRITICAL **: Unable to acquire bus name 'org.freedesktop.systemd1'. Quitting.
Jan 29 17:55:32 xante-I7 cgmanager[1009]: cgmanager:per_ctrl_move_pid_main: pid 1661 (uid 1000 gid 1000) may not write to /run/cgmanager/fs/blkio///tasks
....
....
Jan 29 17:55:32 xante-I7 org.freedesktop.systemd1[1643]: ** (process:1661): WARNING **: cgmanager method call org.linuxcontainers.cgmanager0_0.MovePidAbs failed: GDBus.Error:org.freedesktop.DBus.Error.InvalidArgs: invalid request. Use G_DBUS_DEBUG=message for more info.
Jan 29 17:55:32 xante-I7 org.freedesktop.systemd1[1643]: ** (process:1661): WARNING **: cgmanager method call org.linuxcontainers.cgmanager0_0.GetValue failed: GDBus.Error:org.freedesktop.DBus.Error.InvalidArgs: invalid request. Use G_DBUS_DEBUG=message for more info.
Jan 29 17:55:32 xante-I7 org.freedesktop.systemd1[1643]: ** (process:1661): WARNING **: cgmanager method call org.linuxcontainers.cgmanager0_0.SetValue failed: GDBus.Error:org.freedesktop.DBus.Error.InvalidArgs: invalid request. Use G_DBUS_DEBUG=message for more info.
Und das geht einen ganze Weile so weiter
Umgekehrt wird /run/cgmanager/fs erst nach den 1:30 timeout unmounted, und nachdem das Flatpak gekillt wurde
Code: Alles auswählen
Jan 29 17:57:49 xante-I7 systemd[1574]: Stopped flatpak-org.tabos.roger-1799.scope.
Jan 29 17:57:49 xante-I7 systemd[1574]: flatpak-org.tabos.roger-1799.scope: Unit entered failed state.
Jan 29 17:57:49 xante-I7 systemd[1574]: Reached target Shutdown.
....
....
Jan 29 17:57:50 xante-I7 systemd[1]: Unmounting /run/cgmanager/fs...
-
Xantorix
- Beiträge: 177
- Registriert: 27.01.2018 13:33:06
Beitrag
von Xantorix » 29.01.2018 21:32:11
NAB hat geschrieben: 29.01.2018 20:59:16
Xantorix, du könntest noch mal versuchen, das Flatpak per Hand zu starten und zu gucken, was es überhaupt macht. Ich wüsste zwar auch nicht, wonach man gucken sollte, aber nachher ist man ja manchmal schlauer. Die Syntax wäre:
flatpak run -v <Paketname>
Beenden mit Strg+C (das entspräche wohl dem, was Systemd macht) oder mit der Maus bzw. pkill (das entspräche dem, was reibungslos funktioniert). Gibt's da Unterschiede?
So sieht es aus:
Code: Alles auswählen
flatpak run -v org.tabos.roger
F: No installations directory in /etc/flatpak/installations.d. Skipping
F: Opening user flatpak installation at path /home/gerd/.local/share/flatpak
F: Opening system flatpak installation at path /var/lib/flatpak
F: Opening user flatpak installation at path /home/gerd/.local/share/flatpak
F: Opening system flatpak installation at path /var/lib/flatpak
F: Allowing homedir access
F: Allowing x11 access
F: Allowing wayland access
F: Allowing pulseaudio access
Unterschiede ob STRG+C oder Maus gibt es nicht.
Gruß Xante
-
TomL
Beitrag
von TomL » 29.01.2018 21:36:57
Starte es nach einem Kill nochmal von Hand, aber vorher in einem zweiten Terminal
starten. Dann sieht man genau die System-Meldungen, die der Start verursacht und ob Fehlermeldungen passieren.
-
Xantorix
- Beiträge: 177
- Registriert: 27.01.2018 13:33:06
Beitrag
von Xantorix » 29.01.2018 22:11:02
Kommt nur:
'Jan 29 22:09:19 xante-I7 systemd[1562]: Started flatpak-org.tabos.roger-11134.scope.'
Gruß Xante
-
NAB
- Beiträge: 5501
- Registriert: 06.03.2011 16:02:23
- Lizenz eigener Beiträge: MIT Lizenz
Beitrag
von NAB » 29.01.2018 22:40:14
Nun könnte man im dritten (?) Terminal ja mal
systemctl stop flatpak-org.tabos.roger-11134.scope
eingeben und gucken, was passiert ...
Google hat mich eben noch mit systemd.kill bekannt gemacht:
https://www.freedesktop.org/software/sy ... .kill.html
Ist das vielleicht die system(d)-konforme Alternative zu pkill?
Ach, und
Code: Alles auswählen
Jan 29 17:55:33 xante-I7 systemd[1574]: Started flatpak-org.tabos.roger-1799.scope.
Jan 29 17:55:57 xante-I7 systemd[1]: Starting flatpak system helper...
Jan 29 17:56:19 xante-I7 systemd[1574]: Stopping flatpak-org.tabos.roger-1799.scope.
Jan 29 17:56:19 xante-I7 systemd[1]: Stopping flatpak system helper...
Weiß jemand, ob die Reihenfolge so stimmt?
Never change a broken system. It could be worse afterwards.
"No computer system can be absolutely secure." Intel Document Number: 336983-001
-
Xantorix
- Beiträge: 177
- Registriert: 27.01.2018 13:33:06
Beitrag
von Xantorix » 30.01.2018 10:02:33
NAB hat geschrieben: 29.01.2018 22:40:14
Nun könnte man im dritten (?) Terminal ja mal
systemctl stop flatpak-org.tabos.roger-11134.scope
eingeben und gucken, was passiert ...
journal -f
Code: Alles auswählen
-- Logs begin at Mo 2018-01-29 17:55:17 CET. --
Jan 30 09:47:00 xante-I7 systemd[1484]: Stopped target Basic System.
Jan 30 09:47:00 xante-I7 systemd[1484]: Stopped target Paths.
Jan 30 09:47:00 xante-I7 systemd[1484]: Reached target Shutdown.
Jan 30 09:47:01 xante-I7 systemd[1484]: Starting Exit the Session...
Jan 30 09:47:01 xante-I7 systemd[1484]: Stopped target Timers.
Jan 30 09:47:01 xante-I7 systemd[1484]: Stopped target Sockets.
Jan 30 09:47:01 xante-I7 systemd[1484]: Received SIGRTMIN+24 from PID 3049 (kill).
Jan 30 09:47:01 xante-I7 systemd[1485]: pam_unix(systemd-user:session): session closed for user lightdm
Jan 30 09:47:01 xante-I7 systemd[1]: Stopped User Manager for UID 123.
Jan 30 09:47:01 xante-I7 systemd[1]: Removed slice User Slice of lightdm.
Jan 30 09:47:41 xante-I7 systemd[1638]: Started flatpak-org.tabos.roger-3149.scope.
Jan 30 09:48:12 xante-I7 polkitd(authority=local)[1069]: Registered Authentication Agent for unix-process:3194:20479 (system bus name :1.66 [/usr/bin/pkttyagent --notify-fd 4 --fallback], object path /org/freedesktop/PolicyKit1/AuthenticationAgent, locale de_DE.UTF-8)
Jan 30 09:48:17 xante-I7 polkitd(authority=local)[1069]: Operator of unix-session:c2 successfully authenticated as unix-user:xante to gain TEMPORARY authorization for action org.freedesktop.systemd1.manage-units for system-bus-name::1.67 [systemctl stop flatpak-org.tabos.roger-3149.scope] (owned by unix-user:xante)
Jan 30 09:48:17 xante-I7 polkitd(authority=local)[1069]: Unregistered Authentication Agent for unix-process:3194:20479 (system bus name :1.66, object path /org/freedesktop/PolicyKit1/AuthenticationAgent, locale de_DE.UTF-8) (disconnected from bus)
systemctl stop flatpak-org.tabos.roger-3149.scope
Code: Alles auswählen
Failed to stop flatpak-org.tabos.roger-3149.scope: Unit flatpak-org.tabos.roger-3149.scope not loaded.
Die App Roger Router wird so nicht beendet.
Gruß Xante
-
TomL
Beitrag
von TomL » 30.01.2018 10:45:22
Xantorix hat geschrieben: 30.01.2018 10:02:33
Code: Alles auswählen
systemctl stop flatpak-org.tabos.roger-3149.scope [code]Failed to stop flatpak-org.tabos.roger-3149.scope: Unit flatpak-org.tabos.roger-3149.scope not loaded.
Die App Roger Router wird so nicht beendet.
Ja, ich glaube, das ist auch eindeutig... die Meldung bedeutet m.M.n., dass dafür gar keine Service-Unit geladen wurde - deshalb kann auch nix beendet werden. Man weiss auch gar nicht, wie tief dieses flatpak tatsächlich ins System eingreift und ob es sich wirklich an übliche systemd-Spielregeln hält oder einfach eigene Regeln anwendet. Meines Erachtens sollten die mal aus dem tabos-Forum erklären, warum sich das Programm nicht zur Beendigung auffordern lässt, so das systemd nach dem Timeout den Job killen muss. Genau da liegt das Problem. Oder die erklären, wie man es einstellen muss, damit es sich ordentlich innerhalb des von systemd durchgeführten shutdown-prozesses beendet. Aber ich halte diese flatpak-Idee sowieso für zweifelhaft und wäre bestrebt, das bei einer betrieblichen Nutzung der Hardware zu vermeiden.
-
NAB
- Beiträge: 5501
- Registriert: 06.03.2011 16:02:23
- Lizenz eigener Beiträge: MIT Lizenz
Beitrag
von NAB » 30.01.2018 12:52:30
Xantorix hat geschrieben: 30.01.2018 10:02:33
Die App Roger Router wird so nicht beendet.
Ich glaube eher, ein Systemd "Scope" wird so nicht beendet. Ich weiß nicht mal, ob man Scopes überhaupt beenden kann/sollte.
Andererseits bezeichnet Systemd es als Unit:
Code: Alles auswählen
flatpak-org.tabos.roger-1799.scope: Unit entered failed state.
Wie startest du Roger Router überhaupt?
Never change a broken system. It could be worse afterwards.
"No computer system can be absolutely secure." Intel Document Number: 336983-001
-
Xantorix
- Beiträge: 177
- Registriert: 27.01.2018 13:33:06
Beitrag
von Xantorix » 30.01.2018 13:14:42
NAB hat geschrieben: 30.01.2018 12:52:30
Wie startest du Roger Router überhaupt?
Mit Autostart in Startprogramme. Dort wird folgender Befehl ausgeführt:
Code: Alles auswählen
/usr/bin/flatpak run --filesystem=host --branch=master --arch=x86_64 --command=roger --file-forwarding org.tabos.roger @@u %u @@
Xante
-
TomL
Beitrag
von TomL » 30.01.2018 15:36:44
Ich muss zugeben, dass ich das mit den scopes noch gar nicht kannte... hab das jetzt zum ersten Mal gesehen:
https://www.freedesktop.org/software/sy ... scope.html
Anscheinend wird da auf Anforderung dynamisch eine Unit generiert... aber man kommt da nicht dran.
Code: Alles auswählen
thomas@thomaspc:~
$ systemd-run --user --scope echo hello;sleep 30 &
Running scope as unit: run-rb16f130b84ed453699040121d67da788.scope
hello
[1] 10663
$ systemctl cat run-rb16f130b84ed453699040121d67da788.scope
No files found for run-rb16f130b84ed453699040121d67da788.scope.
$ systemctl status run-rb16f130b84ed453699040121d67da788.scope
Unit run-rb16f130b84ed453699040121d67da788.scope could not be found.
Keine Ahnung, wie man damit umgeht.
-
Teddybear
- Beiträge: 3163
- Registriert: 07.05.2005 13:52:55
- Lizenz eigener Beiträge: GNU Free Documentation License
- Wohnort: Altomünster
-
Kontaktdaten:
Beitrag
von Teddybear » 30.01.2018 16:24:43
Moin Gemeinde,
Das Problem ist, ganz einfach.
Der Code nutzt nicht die gegbenen Möglichkeiten um seine scopes geregelt zu beenden, wärend des shutdown.
Optionally, it is possible for a program that registers a scope unit (the "scope manager") for one or more of its child processes to hook into the shutdown logic of the scope unit. Normally, if this is not done, and the scope needs to be shut down (regardless if during normal operation when the user invokes systemctl stop -- or something equivalent -- on the scope unit, or during system shutdown), then systemd will simply send SIGTERM to its processes. After a timeout this will be followed by SIGKILL unless the scope processes exited by then. If a scope manager program wants to be involved in the shutdown logic of its scopes it may set the Controller property of the scope unit when creating it via StartTransientUnit(). It should be set to the bus name (either unique name or well-known name) of the scope manager program. If this is done then instead of SIGTERM to the scope processes systemd will send the RequestStop() bus signal to the specified name. If the name is gone by then it will automatically fallback to SIGTERM, in order to make this robust. As before in either case this will be followed by SIGKILL to the scope unit processes after a timeout.
Versuchungen sollte man nachgeben. Wer weiß, ob sie wiederkommen!
Oscar Wilde
Mod-Voice / My Voice
-
Xantorix
- Beiträge: 177
- Registriert: 27.01.2018 13:33:06
Beitrag
von Xantorix » 30.01.2018 17:19:46
Teddybear hat geschrieben: 30.01.2018 16:24:43
Das Problem ist, ganz einfach.
So sehe ich in meinem Job zum Glück auch viele Probleme.
Nur leider ist EDV nicht mein Job. Was kann ich also tun?
Leider kann ich auf die Roger Router App nicht verzichten.
Ist es definitiv die App?
Ich nutze nfs Freigaben und den Network Manager. Soll ja auch Schwierig sein?
Ich werde mal warten ob sich jemand im Tabos Forum äußert.
Gruß Xante
-
TomL
Beitrag
von TomL » 30.01.2018 17:32:58
Xantorix hat geschrieben: 30.01.2018 17:19:46
Leider kann ich auf die Roger Router App nicht verzichten.Ist es definitiv die App?
Ich denke ja. Wie in dem Link oberhalb drinsteht, sendet systemd ein sigterm an den Prozess als Aufforderung sich zu beenden. Und der reagiert nicht darauf, deswegen dauerts die Timeout-Zeit von 90 Sekunden bis er gekillt wird. Mit dem Log-Auszug ist das m.M.n. auch ganz offensichtlich erkennbar, wann systemd den Prozess auffordert und wie lange es wartet bis zum kill. Vielleich tummelt sich in diesem Tabos-Forum auch der Entwickler, deshalb würde ich das dort ansprechen.
-
NAB
- Beiträge: 5501
- Registriert: 06.03.2011 16:02:23
- Lizenz eigener Beiträge: MIT Lizenz
Beitrag
von NAB » 30.01.2018 17:42:45
Teddybear, danke, aber ich seh da ein Zuständigkeitsgerangel.
Xantorix startet flatpak ja an Systemd vorbei. Systemd startet dann ungefragt einen flatpack-Scope.
Beim Herunterfahren will Systemd dann diesen Scope beenden, müsste demzufolge versuchen flatpak zu beenden, weiß aber nicht, dass es zusätzlich Roger Router beenden müsste. Müsste es eigentlich auch gar nicht wissen, weil das flatpaks Job wäre (finde ich). flatpak will sich nicht beenden, solange Roger Router läuft (danach geht's ja). Und Roger Router weiß von nichts (sonst tät's sich ja beenden).
flatpack weiß genau, dass es Roger Router gestartet hat. Systemd scheint aber nicht danach zu fragen.
Ist nun Roger Router taub, flatpak ignorant oder Systemd zu blöd? (Es geht hier ja um Mint, denen traue ich alles zu)
Zuletzt geändert von
NAB am 30.01.2018 17:46:35, insgesamt 1-mal geändert.
Never change a broken system. It could be worse afterwards.
"No computer system can be absolutely secure." Intel Document Number: 336983-001
-
TomL
Beitrag
von TomL » 30.01.2018 17:46:33
NAB hat geschrieben: 30.01.2018 17:42:45
Teddybear, danke, aber ich seh da ein Zuständigkeitsgerangel.
Xantorix startet flatpak ja an Systemd vorbei. Systemd startet dann ungefragt einen flatpack-Scope.
Bist Du Dir sicher? Ich glaube nämlich, dass es gar nicht des Users-Aufgabe sein kann, einen Job systemd-konform zu starten. Ich könnte mir auch vorstellen, dass das, was xantorix da startet, nur ein Wrapper ist, der dann diese systemd-Scope-Runs ausführt. An systemd liegts wohl nicht, das Log zeigt ja, das es den Job stoppen will bzw. dazu auffordert.
Roger gibts ja bei Debian auch.... wieso kommt Debian ohne diesen Flatpak-Kram aus?
Zuletzt geändert von TomL am 30.01.2018 17:50:32, insgesamt 1-mal geändert.
-
Xantorix
- Beiträge: 177
- Registriert: 27.01.2018 13:33:06
Beitrag
von Xantorix » 30.01.2018 17:50:19
TomL hat geschrieben: 30.01.2018 17:32:58
Vielleich tummelt sich in diesem Tabos-Forum auch der Entwickler, deshalb würde ich das dort ansprechen.
Das Forum ist leider nicht so aktiv. Der Entwickler ist wohl der einzige der dort antwortet.
Ich hab dort gefragt und warte mal was kommt. Auch habe ich zu dem Thema hier verlinkt.
Vielen Dank an alle. Gruß Xante
-
NAB
- Beiträge: 5501
- Registriert: 06.03.2011 16:02:23
- Lizenz eigener Beiträge: MIT Lizenz
Beitrag
von NAB » 30.01.2018 17:57:34
TomL hat geschrieben: 30.01.2018 17:46:33
Bist Du Dir sicher?
Ich bin mir sicher, dass Xantorix nicht danach gefragt hat, ja. Darum hatte ich ihn ja gefragt, wie er Roger Router startet. Dass dann irgendein Automatismus einen Systemd-User-Scope starten muss, ist klar. Entweder fragt flatpak danach, oder Systemd reagiert eigenmächtig auf flatpak-Starts. Das weiß ich nicht. Oder es hängt sogar mit der Konfiguration des RogerRouter-Paketes zusammen. Weiß ich auch nicht. Deshalb frag ich.
TomL hat geschrieben: 30.01.2018 17:46:33
Roger gibts ja bei Debian auch.... wieso kommt Debian ohne diesen Flatpak-Kram aus?
Weil irgendein netter Mensch seine Freizeit opfert, um Roger Router für Debian zu paketieren. Und das ist dann auch nur eine veraltete Version. Wenn du den neusten Scheiß haben willst, braucht du trotzdem das Flatpak ... und den neusten Scheiß brauchst du manchmal für die neusten Fritzboxen bzw. deren neuste Funktionen.
Never change a broken system. It could be worse afterwards.
"No computer system can be absolutely secure." Intel Document Number: 336983-001
-
Xantorix
- Beiträge: 177
- Registriert: 27.01.2018 13:33:06
Beitrag
von Xantorix » 30.01.2018 18:10:58
NAB hat geschrieben: 30.01.2018 17:57:34
Wenn du den neusten Scheiß haben willst, braucht du trotzdem das Flatpak ... und den neusten Scheiß brauchst du manchmal für die neusten Fritzboxen bzw. deren neuste Funktionen.
Und auch weil sich die für mich wichtigste Funktion das Faxen über IP deutlich verbessert hat.
Hylafax ist für meine überschaubaren Fähigkeiten leider ne Nummer zu groß. Aber vielleicht finde ja doch noch ne schöne deutsche Dokumentation. Dann bau ich mir noch nen Faxserver.
Gruß Xante
-
KP97
- Beiträge: 3737
- Registriert: 01.02.2013 15:07:36
Beitrag
von KP97 » 30.01.2018 19:43:16
Ganz unabhängig von meinen beiden "Vorschreibern" und von der Reaktion aus dem anderen Forum könntest Du vorab die 90 sec. verkürzen auf z.B. 10 sec. oder noch kürzer.
Dann kannst Du Dir erstmal Zeit lassen mit den weiteren Aktionen.
Zu finden in /etc/systemd/system.conf Zeile 36 entkommentieren
DefaultTimeoutStopSec=10s
Die Zeile 35 betrifft übrigens den "Startjob is running.."
In der logind.conf kann zusätzlich auch erlaubt werden, einen Job zu killen.
Zeile 17 - KillUserProcesses=yes
-
Xantorix
- Beiträge: 177
- Registriert: 27.01.2018 13:33:06
Beitrag
von Xantorix » 30.01.2018 20:20:12
@ KP97 Und das haut mein System nicht zusammen?
Xante
-
TomL
Beitrag
von TomL » 30.01.2018 20:54:16
Xantorix hat geschrieben: 30.01.2018 20:20:12
Und das haut mein System nicht zusammen?
Ich bin zwar nicht KP97, aber es haut Dein System nicht zusammen. Nur ist das halt eine generelle Einstellung, die möglicherweise die Anzeige später auftretender neuer/anderer Probleme dann ebenfalls unterdrückt. Der Nachteil ist, das verschwiegene Probleme dann vielleicht nicht gelöst werden... was dann daraus wieder entstehen kann, weiss nur der CPU-Gott....
Wenn Dich das beunruhigt, verwende die von mir beschriebene Service-Unit, die macht eh nix anderes, als 90 Sekunden später systemd sowieso macht und lässt ansonsten alles andere unberührt.
-
scientific
- Beiträge: 3022
- Registriert: 03.11.2009 13:45:23
- Lizenz eigener Beiträge: Artistic Lizenz
-
Kontaktdaten:
Beitrag
von scientific » 30.01.2018 22:20:03
Immer wieder... Zum Debuggen von Shutdown-Problemen ist die Debug-shell super
Code: Alles auswählen
systemctl enable debug-shell
systemctl start debug-shell
Und auf strg+alt+f9 findest du diese Shell die außerhalb eines Usercontext läuft. Damit kannst du als root untersuchen, was los ist, und warum ein Dienst nicht beendet wird.