Commit 3d2f2cd0 authored by Christian Lamparter's avatar Christian Lamparter Committed by John W. Linville

carl9170: fix memory leak issue in async cmd macro wrappers

This patch continues where the previous commit:
	"carl9170: fix async command buffer leak"
left off.

Similar to carl9170_reboot/carl9170_powersave, the
carl9170_async_regwrite* macros would leak the
temporary command buffer, if __carl9170_exec_cmd
fails to upload the command to the device.
Signed-off-by: default avatarChristian Lamparter <chunkeey@googlemail.com>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent 5f4e6b2d
...@@ -116,8 +116,9 @@ __regwrite_out : \ ...@@ -116,8 +116,9 @@ __regwrite_out : \
} while (0); } while (0);
#define carl9170_async_get_buf() \ #define carl9170_async_regwrite_get_buf() \
do { \ do { \
__nreg = 0; \
__cmd = carl9170_cmd_buf(__carl, CARL9170_CMD_WREG_ASYNC, \ __cmd = carl9170_cmd_buf(__carl, CARL9170_CMD_WREG_ASYNC, \
CARL9170_MAX_CMD_PAYLOAD_LEN); \ CARL9170_MAX_CMD_PAYLOAD_LEN); \
if (__cmd == NULL) { \ if (__cmd == NULL) { \
...@@ -128,38 +129,42 @@ do { \ ...@@ -128,38 +129,42 @@ do { \
#define carl9170_async_regwrite_begin(carl) \ #define carl9170_async_regwrite_begin(carl) \
do { \ do { \
int __nreg = 0, __err = 0; \
struct ar9170 *__carl = carl; \ struct ar9170 *__carl = carl; \
struct carl9170_cmd *__cmd; \ struct carl9170_cmd *__cmd; \
carl9170_async_get_buf(); \ unsigned int __nreg; \
int __err = 0; \
carl9170_async_regwrite_get_buf(); \
#define carl9170_async_regwrite(r, v) do { \ #define carl9170_async_regwrite_flush() \
__cmd->wreg.regs[__nreg].addr = cpu_to_le32(r); \ do { \
__cmd->wreg.regs[__nreg].val = cpu_to_le32(v); \ if (__cmd == NULL || __nreg == 0) \
__nreg++; \ break; \
if ((__nreg >= PAYLOAD_MAX/2)) { \ \
if (IS_ACCEPTING_CMD(__carl)) { \ if (IS_ACCEPTING_CMD(__carl) && __nreg) { \
__cmd->hdr.len = 8 * __nreg; \ __cmd->hdr.len = 8 * __nreg; \
__err = __carl9170_exec_cmd(__carl, __cmd, true);\ __err = __carl9170_exec_cmd(__carl, __cmd, true); \
__cmd = NULL; \ __cmd = NULL; \
carl9170_async_get_buf(); \ break; \
} else { \
goto __async_regwrite_out; \
} \ } \
__nreg = 0; \
if (__err) \
goto __async_regwrite_out; \ goto __async_regwrite_out; \
} \
} while (0) } while (0)
#define carl9170_async_regwrite_finish() \ #define carl9170_async_regwrite(r, v) do { \
if (__cmd == NULL) \
carl9170_async_regwrite_get_buf(); \
__cmd->wreg.regs[__nreg].addr = cpu_to_le32(r); \
__cmd->wreg.regs[__nreg].val = cpu_to_le32(v); \
__nreg++; \
if ((__nreg >= PAYLOAD_MAX / 2)) \
carl9170_async_regwrite_flush(); \
} while (0)
#define carl9170_async_regwrite_finish() do { \
__async_regwrite_out : \ __async_regwrite_out : \
if (__err == 0 && __nreg) { \ if (__cmd != NULL && __err == 0) \
__cmd->hdr.len = 8 * __nreg; \ carl9170_async_regwrite_flush(); \
if (IS_ACCEPTING_CMD(__carl)) \ kfree(__cmd); \
__err = __carl9170_exec_cmd(__carl, __cmd, true);\ } while (0) \
__nreg = 0; \
}
#define carl9170_async_regwrite_result() \ #define carl9170_async_regwrite_result() \
__err; \ __err; \
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment