xref: /openbmc/linux/drivers/net/wireless/broadcom/brcm80211/brcmfmac/debug.c (revision 38a523a2946d3a0961d141d477a1ee2b1f3bdbb1)
1daeccac2SArend van Spriel // SPDX-License-Identifier: ISC
205491d2cSKalle Valo /*
305491d2cSKalle Valo  * Copyright (c) 2012 Broadcom Corporation
405491d2cSKalle Valo  */
505491d2cSKalle Valo #include <linux/debugfs.h>
605491d2cSKalle Valo #include <linux/netdevice.h>
705491d2cSKalle Valo #include <linux/module.h>
805491d2cSKalle Valo #include <linux/devcoredump.h>
905491d2cSKalle Valo 
1005491d2cSKalle Valo #include <brcmu_wifi.h>
1105491d2cSKalle Valo #include <brcmu_utils.h>
1205491d2cSKalle Valo #include "core.h"
1305491d2cSKalle Valo #include "bus.h"
1405491d2cSKalle Valo #include "fweh.h"
1505491d2cSKalle Valo #include "debug.h"
1605491d2cSKalle Valo 
brcmf_debug_create_memdump(struct brcmf_bus * bus,const void * data,size_t len)17f1ac3aa2SRafał Miłecki int brcmf_debug_create_memdump(struct brcmf_bus *bus, const void *data,
1805491d2cSKalle Valo 			       size_t len)
1905491d2cSKalle Valo {
2005491d2cSKalle Valo 	void *dump;
2105491d2cSKalle Valo 	size_t ramsize;
22f4737a62SRafał Miłecki 	int err;
2305491d2cSKalle Valo 
2405491d2cSKalle Valo 	ramsize = brcmf_bus_get_ramsize(bus);
25f4737a62SRafał Miłecki 	if (!ramsize)
26f4737a62SRafał Miłecki 		return -ENOTSUPP;
27f4737a62SRafał Miłecki 
2805491d2cSKalle Valo 	dump = vzalloc(len + ramsize);
2905491d2cSKalle Valo 	if (!dump)
3005491d2cSKalle Valo 		return -ENOMEM;
31f4737a62SRafał Miłecki 
32d2af9b56SFranky Lin 	if (data && len > 0)
3305491d2cSKalle Valo 		memcpy(dump, data, len);
34f4737a62SRafał Miłecki 	err = brcmf_bus_get_memdump(bus, dump + len, ramsize);
35f4737a62SRafał Miłecki 	if (err) {
36f4737a62SRafał Miłecki 		vfree(dump);
37f4737a62SRafał Miłecki 		return err;
3805491d2cSKalle Valo 	}
39f4737a62SRafał Miłecki 
40*38a523a2SGreg Kroah-Hartman 	dev_coredumpv(bus->dev, dump, len + ramsize, GFP_KERNEL);
41f4737a62SRafał Miłecki 
4205491d2cSKalle Valo 	return 0;
4305491d2cSKalle Valo }
4405491d2cSKalle Valo 
brcmf_debugfs_get_devdir(struct brcmf_pub * drvr)4505491d2cSKalle Valo struct dentry *brcmf_debugfs_get_devdir(struct brcmf_pub *drvr)
4605491d2cSKalle Valo {
4734789d0cSArend Van Spriel 	return drvr->wiphy->debugfsdir;
4805491d2cSKalle Valo }
4905491d2cSKalle Valo 
brcmf_debugfs_add_entry(struct brcmf_pub * drvr,const char * fn,int (* read_fn)(struct seq_file * seq,void * data))50ea1b3bc6SGreg Kroah-Hartman void brcmf_debugfs_add_entry(struct brcmf_pub *drvr, const char *fn,
5105491d2cSKalle Valo 			    int (*read_fn)(struct seq_file *seq, void *data))
5205491d2cSKalle Valo {
5334789d0cSArend Van Spriel 	WARN(!drvr->wiphy->debugfsdir, "wiphy not (yet) registered\n");
54ea1b3bc6SGreg Kroah-Hartman 	debugfs_create_devm_seqfile(drvr->bus_if->dev, fn,
5534789d0cSArend Van Spriel 				    drvr->wiphy->debugfsdir, read_fn);
5605491d2cSKalle Valo }
57