1b4c3e9b5SBjoern A. Zeeb // SPDX-License-Identifier: ISC
2b4c3e9b5SBjoern A. Zeeb /*
3b4c3e9b5SBjoern A. Zeeb * Copyright (c) 2012 Broadcom Corporation
4b4c3e9b5SBjoern A. Zeeb */
5b4c3e9b5SBjoern A. Zeeb #include <linux/debugfs.h>
6b4c3e9b5SBjoern A. Zeeb #include <linux/netdevice.h>
7b4c3e9b5SBjoern A. Zeeb #include <linux/module.h>
8b4c3e9b5SBjoern A. Zeeb #include <linux/devcoredump.h>
9b4c3e9b5SBjoern A. Zeeb
10b4c3e9b5SBjoern A. Zeeb #include <brcmu_wifi.h>
11b4c3e9b5SBjoern A. Zeeb #include <brcmu_utils.h>
12b4c3e9b5SBjoern A. Zeeb #include "core.h"
13b4c3e9b5SBjoern A. Zeeb #include "bus.h"
14b4c3e9b5SBjoern A. Zeeb #include "fweh.h"
15b4c3e9b5SBjoern A. Zeeb #include "debug.h"
16b4c3e9b5SBjoern A. Zeeb
brcmf_debug_create_memdump(struct brcmf_bus * bus,const void * data,size_t len)17b4c3e9b5SBjoern A. Zeeb int brcmf_debug_create_memdump(struct brcmf_bus *bus, const void *data,
18b4c3e9b5SBjoern A. Zeeb size_t len)
19b4c3e9b5SBjoern A. Zeeb {
20*902136e0SBjoern A. Zeeb #if defined(__linux__)
21b4c3e9b5SBjoern A. Zeeb void *dump;
22*902136e0SBjoern A. Zeeb #elif defined(__FreeBSD__)
23*902136e0SBjoern A. Zeeb u8 *dump;
24*902136e0SBjoern A. Zeeb #endif
25b4c3e9b5SBjoern A. Zeeb size_t ramsize;
26b4c3e9b5SBjoern A. Zeeb int err;
27b4c3e9b5SBjoern A. Zeeb
28b4c3e9b5SBjoern A. Zeeb ramsize = brcmf_bus_get_ramsize(bus);
29b4c3e9b5SBjoern A. Zeeb if (!ramsize)
30b4c3e9b5SBjoern A. Zeeb return -ENOTSUPP;
31b4c3e9b5SBjoern A. Zeeb
32b4c3e9b5SBjoern A. Zeeb dump = vzalloc(len + ramsize);
33b4c3e9b5SBjoern A. Zeeb if (!dump)
34b4c3e9b5SBjoern A. Zeeb return -ENOMEM;
35b4c3e9b5SBjoern A. Zeeb
36b4c3e9b5SBjoern A. Zeeb if (data && len > 0)
37b4c3e9b5SBjoern A. Zeeb memcpy(dump, data, len);
38b4c3e9b5SBjoern A. Zeeb err = brcmf_bus_get_memdump(bus, dump + len, ramsize);
39b4c3e9b5SBjoern A. Zeeb if (err) {
40b4c3e9b5SBjoern A. Zeeb vfree(dump);
41b4c3e9b5SBjoern A. Zeeb return err;
42b4c3e9b5SBjoern A. Zeeb }
43b4c3e9b5SBjoern A. Zeeb
44b4c3e9b5SBjoern A. Zeeb dev_coredumpv(bus->dev, dump, len + ramsize, GFP_KERNEL);
45b4c3e9b5SBjoern A. Zeeb
46b4c3e9b5SBjoern A. Zeeb return 0;
47b4c3e9b5SBjoern A. Zeeb }
48b4c3e9b5SBjoern A. Zeeb
brcmf_debugfs_get_devdir(struct brcmf_pub * drvr)49b4c3e9b5SBjoern A. Zeeb struct dentry *brcmf_debugfs_get_devdir(struct brcmf_pub *drvr)
50b4c3e9b5SBjoern A. Zeeb {
51b4c3e9b5SBjoern A. Zeeb return drvr->wiphy->debugfsdir;
52b4c3e9b5SBjoern A. Zeeb }
53b4c3e9b5SBjoern A. Zeeb
brcmf_debugfs_add_entry(struct brcmf_pub * drvr,const char * fn,int (* read_fn)(struct seq_file * seq,void * data))54b4c3e9b5SBjoern A. Zeeb void brcmf_debugfs_add_entry(struct brcmf_pub *drvr, const char *fn,
55b4c3e9b5SBjoern A. Zeeb int (*read_fn)(struct seq_file *seq, void *data))
56b4c3e9b5SBjoern A. Zeeb {
57b4c3e9b5SBjoern A. Zeeb WARN(!drvr->wiphy->debugfsdir, "wiphy not (yet) registered\n");
58*902136e0SBjoern A. Zeeb #if defined(__linux__)
59b4c3e9b5SBjoern A. Zeeb debugfs_create_devm_seqfile(drvr->bus_if->dev, fn,
60b4c3e9b5SBjoern A. Zeeb drvr->wiphy->debugfsdir, read_fn);
61*902136e0SBjoern A. Zeeb #elif defined(__FreeBSD__)
62*902136e0SBjoern A. Zeeb pr_debug("%s: TODO\n", __func__);
63*902136e0SBjoern A. Zeeb #endif
64b4c3e9b5SBjoern A. Zeeb }
65