aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media
diff options
context:
space:
mode:
authorMauro Carvalho Chehab <m.chehab@samsung.com>2013-11-02 07:13:02 -0400
committerMauro Carvalho Chehab <m.chehab@samsung.com>2013-11-08 06:45:46 -0500
commitc98300a0e8cf160aaea60bc05d2cd156a7666173 (patch)
tree2a1bae8d40adc7cb472361e0a50ab48a188a1dd7 /drivers/media
parent7760e148350bf6df95662bc0db3734e9d991cb03 (diff)
[media] mxl111sf: Don't use dynamic static allocation
Dynamic static allocation is evil, as Kernel stack is too low, and compilation complains about it on some archs: drivers/media/usb/dvb-usb-v2/mxl111sf.c:74:1: warning: 'mxl111sf_ctrl_msg' uses dynamic stack allocation [enabled by default] Instead, let's enforce a limit for the buffer to be the max size of a control URB payload data (64 bytes). Signed-off-by: Mauro Carvalho Chehab <m.chehab@samsung.com> Reviewed-by: Hans Verkuil <hans.verkuil@cisco.com> Signed-off-by: Mauro Carvalho Chehab <m.chehab@samsung.com>
Diffstat (limited to 'drivers/media')
-rw-r--r--drivers/media/usb/dvb-usb-v2/mxl111sf.c10
1 files changed, 9 insertions, 1 deletions
diff --git a/drivers/media/usb/dvb-usb-v2/mxl111sf.c b/drivers/media/usb/dvb-usb-v2/mxl111sf.c
index e97964ef7f56..2627553f7de1 100644
--- a/drivers/media/usb/dvb-usb-v2/mxl111sf.c
+++ b/drivers/media/usb/dvb-usb-v2/mxl111sf.c
@@ -23,6 +23,9 @@
23#include "lgdt3305.h" 23#include "lgdt3305.h"
24#include "lg2160.h" 24#include "lg2160.h"
25 25
26/* Max transfer size done by I2C transfer functions */
27#define MAX_XFER_SIZE 64
28
26int dvb_usb_mxl111sf_debug; 29int dvb_usb_mxl111sf_debug;
27module_param_named(debug, dvb_usb_mxl111sf_debug, int, 0644); 30module_param_named(debug, dvb_usb_mxl111sf_debug, int, 0644);
28MODULE_PARM_DESC(debug, "set debugging level " 31MODULE_PARM_DESC(debug, "set debugging level "
@@ -57,7 +60,12 @@ int mxl111sf_ctrl_msg(struct dvb_usb_device *d,
57{ 60{
58 int wo = (rbuf == NULL || rlen == 0); /* write-only */ 61 int wo = (rbuf == NULL || rlen == 0); /* write-only */
59 int ret; 62 int ret;
60 u8 sndbuf[1+wlen]; 63 u8 sndbuf[MAX_XFER_SIZE];
64
65 if (1 + wlen > sizeof(sndbuf)) {
66 pr_warn("%s: len=%d is too big!\n", __func__, wlen);
67 return -EOPNOTSUPP;
68 }
61 69
62 pr_debug("%s(wlen = %d, rlen = %d)\n", __func__, wlen, rlen); 70 pr_debug("%s(wlen = %d, rlen = %d)\n", __func__, wlen, rlen);
63 71