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