blob: 2d3e5e263a326f777e8a577b70ac706dbf37e88c [file] [log] [blame]
Arend van Sprield319a7c2012-06-09 22:51:43 +02001/*
2 * Copyright (c) 2012 Broadcom Corporation
3 *
4 * Permission to use, copy, modify, and/or distribute this software for any
5 * purpose with or without fee is hereby granted, provided that the above
6 * copyright notice and this permission notice appear in all copies.
7 *
8 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
9 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
10 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
11 * SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
12 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
13 * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
14 * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
15 */
16#include <linux/debugfs.h>
Arend van Spriel1d4fd8d2012-10-22 10:36:19 -070017#include <linux/netdevice.h>
Arend van Spriel80969832012-06-09 22:51:44 +020018#include <linux/module.h>
Arend van Sprielff4445a2015-10-08 20:33:11 +020019#include <linux/devcoredump.h>
Arend van Sprield319a7c2012-06-09 22:51:43 +020020
Arend van Sprield319a7c2012-06-09 22:51:43 +020021#include <brcmu_wifi.h>
22#include <brcmu_utils.h>
Hante Meuleman122d3d02014-10-28 14:56:18 +010023#include "core.h"
Hante Meulemand14f78b2014-10-28 14:56:14 +010024#include "bus.h"
Arend van Sprielff4445a2015-10-08 20:33:11 +020025#include "fweh.h"
Hante Meulemana8e8ed32014-10-28 14:56:13 +010026#include "debug.h"
Arend van Sprield319a7c2012-06-09 22:51:43 +020027
28static struct dentry *root_folder;
29
Rafał Miłeckif1ac3aa2017-02-24 17:32:46 +010030int brcmf_debug_create_memdump(struct brcmf_bus *bus, const void *data,
31 size_t len)
Arend van Sprielff4445a2015-10-08 20:33:11 +020032{
33 void *dump;
34 size_t ramsize;
Rafał Miłeckif4737a62017-01-30 16:09:51 +010035 int err;
Arend van Sprielff4445a2015-10-08 20:33:11 +020036
37 ramsize = brcmf_bus_get_ramsize(bus);
Rafał Miłeckif4737a62017-01-30 16:09:51 +010038 if (!ramsize)
39 return -ENOTSUPP;
40
41 dump = vzalloc(len + ramsize);
42 if (!dump)
43 return -ENOMEM;
44
45 memcpy(dump, data, len);
46 err = brcmf_bus_get_memdump(bus, dump + len, ramsize);
47 if (err) {
48 vfree(dump);
49 return err;
Arend van Sprielff4445a2015-10-08 20:33:11 +020050 }
Rafał Miłeckif4737a62017-01-30 16:09:51 +010051
52 dev_coredumpv(bus->dev, dump, len + ramsize, GFP_KERNEL);
53
Arend van Sprielff4445a2015-10-08 20:33:11 +020054 return 0;
55}
56
Arend van Sprield319a7c2012-06-09 22:51:43 +020057void brcmf_debugfs_init(void)
58{
59 root_folder = debugfs_create_dir(KBUILD_MODNAME, NULL);
60 if (IS_ERR(root_folder))
61 root_folder = NULL;
62}
63
64void brcmf_debugfs_exit(void)
65{
66 if (!root_folder)
67 return;
68
69 debugfs_remove_recursive(root_folder);
70 root_folder = NULL;
71}
72
Arend van Sprielff4445a2015-10-08 20:33:11 +020073int brcmf_debug_attach(struct brcmf_pub *drvr)
Arend van Sprield319a7c2012-06-09 22:51:43 +020074{
Arend van Sprield9cb2592012-12-05 15:25:54 +010075 struct device *dev = drvr->bus_if->dev;
76
Arend van Sprield319a7c2012-06-09 22:51:43 +020077 if (!root_folder)
78 return -ENODEV;
79
Arend van Sprield9cb2592012-12-05 15:25:54 +010080 drvr->dbgfs_dir = debugfs_create_dir(dev_name(dev), root_folder);
Tonghao Zhang81fc9b5c2017-07-25 00:00:26 -070081 return PTR_ERR_OR_ZERO(drvr->dbgfs_dir);
Arend van Sprield319a7c2012-06-09 22:51:43 +020082}
83
Arend van Sprielff4445a2015-10-08 20:33:11 +020084void brcmf_debug_detach(struct brcmf_pub *drvr)
Arend van Sprield319a7c2012-06-09 22:51:43 +020085{
Arend van Sprielff4445a2015-10-08 20:33:11 +020086 brcmf_fweh_unregister(drvr, BRCMF_E_PSM_WATCHDOG);
87
Arend van Sprield319a7c2012-06-09 22:51:43 +020088 if (!IS_ERR_OR_NULL(drvr->dbgfs_dir))
89 debugfs_remove_recursive(drvr->dbgfs_dir);
90}
91
92struct dentry *brcmf_debugfs_get_devdir(struct brcmf_pub *drvr)
93{
94 return drvr->dbgfs_dir;
95}
Arend van Spriel80969832012-06-09 22:51:44 +020096
Arend van Spriel82d957e2014-07-12 08:49:36 +020097int brcmf_debugfs_add_entry(struct brcmf_pub *drvr, const char *fn,
98 int (*read_fn)(struct seq_file *seq, void *data))
Arend van Spriel349e7102013-03-03 12:45:28 +010099{
Arend van Spriel5b18ffb2015-06-08 14:38:35 +0200100 struct dentry *e;
Arend van Spriel349e7102013-03-03 12:45:28 +0100101
Arend van Spriel5b18ffb2015-06-08 14:38:35 +0200102 e = debugfs_create_devm_seqfile(drvr->bus_if->dev, fn,
103 drvr->dbgfs_dir, read_fn);
104 return PTR_ERR_OR_ZERO(e);
Arend van Spriel349e7102013-03-03 12:45:28 +0100105}