i have no message of line 87…had appended the full log to my last posting…
Sorry I meant dmesg
log. Those printk’s end up in there, but also get spammed on the serial console when boot is done.
this log is from dmesg…i have only removed part before wifi init
you mean this message, right?
int reset_controller_register(struct reset_controller_dev *rcdev)
{
+ printk(KERN_WARNING "%s: (%s:%i) of_node=%s", __FUNCTION__, __FILE__, __LINE__, rcdev->of_node ? rcdev->of_node->name : "<NULL>");
should this be done on boot or when calling wmt-tools?
For the items currently in the list most likely on boot somewhere when the devices are probed. When wmt-tools inserts kernel modules, it might be called again, but not yet apparently.
ok, then i have stripped to much will do it when i’m at home again, also with additional printk for list-entries
full dmesg including changed printk and #reset-cells: wifi-debug.log (31,1 KB)
at boottime i see nothing consys-related…
uploaded changes done for this log to repo (branch 4.16-wlan)
When starting the wlan modules, it’s looking for a device_node called ‘watchdog’, but there are only ‘syscon’ entries in the list:
[ 51.702101] __of_reset_control_get: (drivers/reset/core.c:469) watchdog == syscon
looks like watchdog is enabled though
[ 1.394286] mtk-wdt 10007000.watchdog: Watchdog enabled (timeout=31 sec, nowayout=0)
Something is missing… not quite sure yet what. Maybe check what happens with the same printk’s in 4.14.
By the way, do you have a file called /sys/kernel/debug/pinctrl-handles
?
Can you cat
it’s contents?
If it’s not there, could you first try to: mount -t debugfs none /sys/kernel/debug
.
This is to check why the following message is printed:
[ 51.701826] [WMT-CONSYS-HW][E]mtk_wmt_probe(125):Wmt Cannot find pinctrl default!
how should the watchdog-node get into the list? i guess this should be done at boot-time by parsing the full dts(i)…is this done for full nodes or only nodes with resets?
will do 4.14-printk’s and the cat of debugfs (i should have it mounted because other tests before) when i’m at home
4.16-pinctrl-handles.txt (10,7 KB)
4.14-pinctrl-handles.txt (11,2 KB)
test with 4.14 (dmesg after wifi-script on same system as 4.16 before): wifi-debug-4.14.log (43,4 KB)
[ 1.535524] mtk-wdt 10007000.watchdog: Watchdog enabled (timeout=31 sec, nowayout=0)
[ 1.543534] reset_controller_register: (drivers/reset/core.c:87) of_node=watchdog
As far as I understand it, the driver modules get compiled into the kernel, they get probed during boot and then will look into the dts how to initialize the hardware etc.
Interesting logs. This line should most likely also happen in 4.16 for the wifi module to find it, unless in 4.16 they altered this behavior. I expect it to be somewhere (indirectly) in the mtk-wdt driver.
Just for fun I tried those printk’s also on 4.17-rc1, which also doesn’t call reset_controller_register for watchdog, same as your 4.16.
maybe this is related: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=7e6127c1240ed569cdda2a67c8f03836f9f28c05
there is a patch for 7621 (not bpi-chip, but maybe interesting) which changes watchdog_register_device to devm_watchdog_register_device
Good find, but I don’t think these changes have any impact.
Could you please add some printk’s to: mtk_infrasys_init, at least at the top and before mtk_register_reset_controller
. If reset controller is called, then continue in there. At the end of that function, the reset controller is registered. This method should be called. If you see no prints at all, check if the drivers/clk/mediatek/clk-mt2701.o
file exists and has recent changes.
i try to include some printk’s:
printk(KERN_WARNING "%s: (%s:%i) regmap=%s", __FUNCTION__, __FILE__, __LINE__, regmap ? regmap->name : "<NULL>");
got this error:
drivers/clk/mediatek/reset.c:75:97: error: dereferencing pointer to incomplete type 'struct regmap'
printk(KERN_WARNING "%s: (%s:%i) regmap=%s", __FUNCTION__, __FILE__, __LINE__, regmap ? regmap->name : "<NULL>");
and i wonder how this can work:
struct regmap *regmap;
because variable-name is same as type…without the var-content log is here:
4.16-infrasys.txt (24,4 KB)
patch-file: infrasys.patch (2,6 KB)
Incomplete type in this case probably means the type was forward declared and only used as pointer (not as regmap type).
The logs are sufficient, thanks. On a quick look it seems that sadly were not on the right path as everything is called as it’s supposed to. I didn’t have any time yet to dive into further, busy weekend , but we need to find out how kernel 4.14 mtk_wdt_probe finally causes calling reset_controller_register. This what your earlier log was showing:
Note that the Watchdog enabled
is the last line of mtk_wdt_probe, while the register_controller_register is called after, according to the log. I now suspect this is because the watchdog is scheduled somewhere, and registered upon start. I was hoping the infrasys logs would give some more insight…
In your wifi-debug.log (4.16-wlan) I don’t see the line MTK_WDT_NONRST_REG(0) that is in wifi-debug-4.14.log. I think you forgot to merge drivers/watchdog/mtk_wdt.c
Hah! you’re probably right… 4.14 from your 4.14-main branch has DRIVER_VERSION 2.0
and 4.16 has 1.0
. Also for 4.14 the file is 621 lines vs 280 in 4.16… pff I was comparing with 4.14 mainline
Seems this is the missing part:
Forum-software stripped the #diff-a7c2e83ff71c648e58025d54ffb50e02
I will add this later…
[12:00] root@bpi-r2:~# uname -r
4.16.7-bpi-r2-wlan
[12:00] root@bpi-r2:~# uname -a
Linux bpi-r2 4.16.7-bpi-r2-wlan #211 SMP Mon May 21 11:54:59 CEST 2018 armv7l Gx
[12:00] root@bpi-r2:~# ifconfig ap0
ap0 Link encap:Ethernet HWaddr 02:08:22:52:61:fc
inet addr:192.168.10.1 Bcast:0.0.0.0 Mask:255.255.255.0
inet6 addr: fe80::8:22ff:fe52:61fc/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:7 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:0 (0.0 B) TX bytes:746 (746.0 B)
[12:00] root@bpi-r2:~# dmesg |grep MTK
[ 1.510238] MTK-BTIF[E]hal_btif_clk_get_and_prepare(286):[CCF]clk_btif=3ac2d9
[ 1.517534] MTK-BTIF[E]hal_btif_clk_get_and_prepare(292):[CCF]clk_btif_apdma0
[ 1.711568] MTK_WDT_NONRST_REG(0)
[ 54.664170] [MTK-BT] BT_init: mtk_stp_BT_chrdev driver(major 192) installed
[ 54.664636] [GPS-MOD-INIT][I]do_gps_drv_init:CONFIG_MTK_COMBO_GPS is not defd
[ 54.664917] [MTK-WIFI] WIFI_init: mtk_wmt_WIFI_chrdev driver(major 155) inst.
[ 61.686268] [MTK-WIFI] WIFI_open: WIFI_open: major 155 minor 0 (pid 1000)
[ 61.686360] [MTK-WIFI] WIFI_write: WIFI_write A
[ 62.916939] [MTK-WIFI] register_set_p2p_mode_handler: (pid 1026) register se7
[ 62.917058] [MTK-WIFI] WIFI_write: WMT turn on WIFI success!
[ 62.918513] [MTK-WIFI] WIFI_write: Set wlan mode 0 --> 1
[ 62.918578] [MTK-WIFI] WIFI_close: WIFI_close: major 155 minor 0 (pid 1000)
looks well thank you @BitMaster & @dfiloni very much
i can also connect to the AP
Wow, great! Good job! You still did most of the work
Do you know why this awful wmt whatever tool and stp blabla loader is required? Maybe we can combine some efforts to ban them as well, if it’s not too much work.
Wmt-tools are required because this driver is from android…i also want to kickoff these tools,but don’t know where these hook into the driver…i’m still no kernel-developer…i only copy files,compile them and try to fix the errors the compiler reports me
Stp_art_launcher throw firmware-file to the driver, wmt_loader makes the init