Run script after module is loaded due to device tree Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern) 2019 Community Moderator Election Results Why I closed the “Why is Kali so hard” questionHow to block loading kernel module only in single user boot when blacklist fails?Trigger an init script when a specific device is up and a kernel module has been loadedUpon bootup, all iptables are lost because the kernel module ip_set is not loadedHow kernel decides what is a suitable module for some hardware device?iptables module not loaded after upgrading Ubuntu 14.04 to 16.04How to prevent a kernel module video driver to probe a specific graphic card deviceSuppressing auto loading of Linux kernel modulesDoes udev load kernel modules?Required kernel modules / configuration for OTG host on OMAP3 based deviceHow to blacklist pwm_backlight?
What items from the Roman-age tech-level could be used to deter all creatures from entering a small area?
What do I do if technical issues prevent me from filing my return on time?
How do I automatically answer y in bash script?
What do you call the holes in a flute?
Need a suitable toxic chemical for a murder plot in my novel
Windows 10: How to Lock (not sleep) laptop on lid close?
Is 1 ppb equal to 1 μg/kg?
How do I keep my slimes from escaping their pens?
Antler Helmet: Can it work?
Estimate capacitor parameters
How can I make names more distinctive without making them longer?
Single author papers against my advisor's will?
Can smartphones with the same camera sensor have different image quality?
How to say that you spent the night with someone, you were only sleeping and nothing else?
Why is "Captain Marvel" translated as male in Portugal?
What computer would be fastest for Mathematica Home Edition?
I'm having difficulty getting my players to do stuff in a sandbox campaign
Is drag coefficient lowest at zero angle of attack?
Replacing HDD with SSD; what about non-APFS/APFS?
How to rotate it perfectly?
90's book, teen horror
Jazz greats knew nothing of modes. Why are they used to improvise on standards?
Why use gamma over alpha radiation?
Complexity of many constant time steps with occasional logarithmic steps
Run script after module is loaded due to device tree
Announcing the arrival of Valued Associate #679: Cesar Manara
Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern)
2019 Community Moderator Election Results
Why I closed the “Why is Kali so hard” questionHow to block loading kernel module only in single user boot when blacklist fails?Trigger an init script when a specific device is up and a kernel module has been loadedUpon bootup, all iptables are lost because the kernel module ip_set is not loadedHow kernel decides what is a suitable module for some hardware device?iptables module not loaded after upgrading Ubuntu 14.04 to 16.04How to prevent a kernel module video driver to probe a specific graphic card deviceSuppressing auto loading of Linux kernel modulesDoes udev load kernel modules?Required kernel modules / configuration for OTG host on OMAP3 based deviceHow to blacklist pwm_backlight?
.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty margin-bottom:0;
Why do I want this?
I use the pwm-ir-tx kernel module to blast IR signals from my embedded device. However, when the pwm kernel module is loaded during the boot process, the pin is on high. It takes about 10 seconds or so until I can set it to low with a lirc irsend signal. You can in principle 'overload' the IR-LED to make it brighter, if it is only used in PWM mode and not permanently on. The 10 seconds during the boot process undermine this strategy, however.
What is my system doing so far (e.g. what's working, DT-Overlay file, etc)?
I am using Armbian and modified the pwm-ir-tx driver in the mainline kernel, so that the state after a send is guaranteed low (setting duty cycle to 0, it was randomly 1 or 0 when just disabling the pwm channel on my device).
I am using a device tree overlay that activates the pwm and the pwm-ir-tx.
/dts-v1/;
/plugin/;
/
compatible = "allwinner,sun4i-a10";
fragment@0
target = <&pwm>;
__overlay__
pinctrl-names = "default";
pinctrl-0 = <&pwm0_pin>, <&pwm1_pin>;
status = "okay";
;
;
fragment@1
target-path = "/";
__overlay__
pwm-ir-transmitter
compatible = "pwm-ir-tx";
pwms = <&pwm 0 0 0>;
;
;
;
;
When I boot, the pwm-sun4i modules and pwm-ir-tx are loaded and a /dev/lircx character device is available to be used. To turn the LED off, I enabled a systemd service 'lircd-out' with the Unit entry 'After=lircd.service', that turns the led off, but it runs about 10 seconds after the boot process.
Setting modules in the DT Overlay to "disabled" and loading them with modprobe afterwards is not working (not creating pwm or rc devices in sysfs, or a /dev/lircx character device). Maybe since those modules are built in (i.e. configured with 'Y', not 'M' in the .config file), but I must admit my understanding is still a bit fuzzy, here.
What would be ideal?
The ability to control the loading of the modules pwm-sun4i and pwm-ir-tx and thus be able to run a script after pwm-sun4i was loaded that sets the pwm pin to low and then load pwm-ir-tx. But as I mentioned, when I load those modules manually, they are somehow not accessible for the sysfs.
Alternatively, I could pass a parameter in the fragment@0 to the pwm that sets it to low. But I do not know how and do not see anything in the code of pwm-sun4i.c that would allow this. I do not want to modify the kernel source to keep it compatible for updates.
Any suggestions?
systemd kernel-modules embedded device-tree
New contributor
add a comment |
Why do I want this?
I use the pwm-ir-tx kernel module to blast IR signals from my embedded device. However, when the pwm kernel module is loaded during the boot process, the pin is on high. It takes about 10 seconds or so until I can set it to low with a lirc irsend signal. You can in principle 'overload' the IR-LED to make it brighter, if it is only used in PWM mode and not permanently on. The 10 seconds during the boot process undermine this strategy, however.
What is my system doing so far (e.g. what's working, DT-Overlay file, etc)?
I am using Armbian and modified the pwm-ir-tx driver in the mainline kernel, so that the state after a send is guaranteed low (setting duty cycle to 0, it was randomly 1 or 0 when just disabling the pwm channel on my device).
I am using a device tree overlay that activates the pwm and the pwm-ir-tx.
/dts-v1/;
/plugin/;
/
compatible = "allwinner,sun4i-a10";
fragment@0
target = <&pwm>;
__overlay__
pinctrl-names = "default";
pinctrl-0 = <&pwm0_pin>, <&pwm1_pin>;
status = "okay";
;
;
fragment@1
target-path = "/";
__overlay__
pwm-ir-transmitter
compatible = "pwm-ir-tx";
pwms = <&pwm 0 0 0>;
;
;
;
;
When I boot, the pwm-sun4i modules and pwm-ir-tx are loaded and a /dev/lircx character device is available to be used. To turn the LED off, I enabled a systemd service 'lircd-out' with the Unit entry 'After=lircd.service', that turns the led off, but it runs about 10 seconds after the boot process.
Setting modules in the DT Overlay to "disabled" and loading them with modprobe afterwards is not working (not creating pwm or rc devices in sysfs, or a /dev/lircx character device). Maybe since those modules are built in (i.e. configured with 'Y', not 'M' in the .config file), but I must admit my understanding is still a bit fuzzy, here.
What would be ideal?
The ability to control the loading of the modules pwm-sun4i and pwm-ir-tx and thus be able to run a script after pwm-sun4i was loaded that sets the pwm pin to low and then load pwm-ir-tx. But as I mentioned, when I load those modules manually, they are somehow not accessible for the sysfs.
Alternatively, I could pass a parameter in the fragment@0 to the pwm that sets it to low. But I do not know how and do not see anything in the code of pwm-sun4i.c that would allow this. I do not want to modify the kernel source to keep it compatible for updates.
Any suggestions?
systemd kernel-modules embedded device-tree
New contributor
add a comment |
Why do I want this?
I use the pwm-ir-tx kernel module to blast IR signals from my embedded device. However, when the pwm kernel module is loaded during the boot process, the pin is on high. It takes about 10 seconds or so until I can set it to low with a lirc irsend signal. You can in principle 'overload' the IR-LED to make it brighter, if it is only used in PWM mode and not permanently on. The 10 seconds during the boot process undermine this strategy, however.
What is my system doing so far (e.g. what's working, DT-Overlay file, etc)?
I am using Armbian and modified the pwm-ir-tx driver in the mainline kernel, so that the state after a send is guaranteed low (setting duty cycle to 0, it was randomly 1 or 0 when just disabling the pwm channel on my device).
I am using a device tree overlay that activates the pwm and the pwm-ir-tx.
/dts-v1/;
/plugin/;
/
compatible = "allwinner,sun4i-a10";
fragment@0
target = <&pwm>;
__overlay__
pinctrl-names = "default";
pinctrl-0 = <&pwm0_pin>, <&pwm1_pin>;
status = "okay";
;
;
fragment@1
target-path = "/";
__overlay__
pwm-ir-transmitter
compatible = "pwm-ir-tx";
pwms = <&pwm 0 0 0>;
;
;
;
;
When I boot, the pwm-sun4i modules and pwm-ir-tx are loaded and a /dev/lircx character device is available to be used. To turn the LED off, I enabled a systemd service 'lircd-out' with the Unit entry 'After=lircd.service', that turns the led off, but it runs about 10 seconds after the boot process.
Setting modules in the DT Overlay to "disabled" and loading them with modprobe afterwards is not working (not creating pwm or rc devices in sysfs, or a /dev/lircx character device). Maybe since those modules are built in (i.e. configured with 'Y', not 'M' in the .config file), but I must admit my understanding is still a bit fuzzy, here.
What would be ideal?
The ability to control the loading of the modules pwm-sun4i and pwm-ir-tx and thus be able to run a script after pwm-sun4i was loaded that sets the pwm pin to low and then load pwm-ir-tx. But as I mentioned, when I load those modules manually, they are somehow not accessible for the sysfs.
Alternatively, I could pass a parameter in the fragment@0 to the pwm that sets it to low. But I do not know how and do not see anything in the code of pwm-sun4i.c that would allow this. I do not want to modify the kernel source to keep it compatible for updates.
Any suggestions?
systemd kernel-modules embedded device-tree
New contributor
Why do I want this?
I use the pwm-ir-tx kernel module to blast IR signals from my embedded device. However, when the pwm kernel module is loaded during the boot process, the pin is on high. It takes about 10 seconds or so until I can set it to low with a lirc irsend signal. You can in principle 'overload' the IR-LED to make it brighter, if it is only used in PWM mode and not permanently on. The 10 seconds during the boot process undermine this strategy, however.
What is my system doing so far (e.g. what's working, DT-Overlay file, etc)?
I am using Armbian and modified the pwm-ir-tx driver in the mainline kernel, so that the state after a send is guaranteed low (setting duty cycle to 0, it was randomly 1 or 0 when just disabling the pwm channel on my device).
I am using a device tree overlay that activates the pwm and the pwm-ir-tx.
/dts-v1/;
/plugin/;
/
compatible = "allwinner,sun4i-a10";
fragment@0
target = <&pwm>;
__overlay__
pinctrl-names = "default";
pinctrl-0 = <&pwm0_pin>, <&pwm1_pin>;
status = "okay";
;
;
fragment@1
target-path = "/";
__overlay__
pwm-ir-transmitter
compatible = "pwm-ir-tx";
pwms = <&pwm 0 0 0>;
;
;
;
;
When I boot, the pwm-sun4i modules and pwm-ir-tx are loaded and a /dev/lircx character device is available to be used. To turn the LED off, I enabled a systemd service 'lircd-out' with the Unit entry 'After=lircd.service', that turns the led off, but it runs about 10 seconds after the boot process.
Setting modules in the DT Overlay to "disabled" and loading them with modprobe afterwards is not working (not creating pwm or rc devices in sysfs, or a /dev/lircx character device). Maybe since those modules are built in (i.e. configured with 'Y', not 'M' in the .config file), but I must admit my understanding is still a bit fuzzy, here.
What would be ideal?
The ability to control the loading of the modules pwm-sun4i and pwm-ir-tx and thus be able to run a script after pwm-sun4i was loaded that sets the pwm pin to low and then load pwm-ir-tx. But as I mentioned, when I load those modules manually, they are somehow not accessible for the sysfs.
Alternatively, I could pass a parameter in the fragment@0 to the pwm that sets it to low. But I do not know how and do not see anything in the code of pwm-sun4i.c that would allow this. I do not want to modify the kernel source to keep it compatible for updates.
Any suggestions?
systemd kernel-modules embedded device-tree
systemd kernel-modules embedded device-tree
New contributor
New contributor
edited 16 hours ago
Rui F Ribeiro
42.1k1483142
42.1k1483142
New contributor
asked 17 hours ago
user3117071user3117071
61
61
New contributor
New contributor
add a comment |
add a comment |
0
active
oldest
votes
Your Answer
StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "106"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);
else
createEditor();
);
function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);
);
user3117071 is a new contributor. Be nice, and check out our Code of Conduct.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f512393%2frun-script-after-module-is-loaded-due-to-device-tree%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
0
active
oldest
votes
0
active
oldest
votes
active
oldest
votes
active
oldest
votes
user3117071 is a new contributor. Be nice, and check out our Code of Conduct.
user3117071 is a new contributor. Be nice, and check out our Code of Conduct.
user3117071 is a new contributor. Be nice, and check out our Code of Conduct.
user3117071 is a new contributor. Be nice, and check out our Code of Conduct.
Thanks for contributing an answer to Unix & Linux Stack Exchange!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f512393%2frun-script-after-module-is-loaded-due-to-device-tree%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
-device-tree, embedded, kernel-modules, systemd