/*
|
* Copyright (c) 2015 South Silicon Valley Microelectronics Inc.
|
* Copyright (c) 2015 iComm Corporation
|
*
|
* This program is free software: you can redistribute it and/or modify
|
* it under the terms of the GNU General Public License as published by
|
* the Free Software Foundation, either version 3 of the License, or
|
* (at your option) any later version.
|
* This program is distributed in the hope that it will be useful, but
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
* See the GNU General Public License for more details.
|
* You should have received a copy of the GNU General Public License
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
*/
|
|
#ifndef _SSV_CMD_H_
|
#define _SSV_CMD_H_
|
#define CLI_BUFFER_SIZE 256
|
#define CLI_ARG_SIZE 10
|
#define CLI_RESULT_BUF_SIZE (4096)
|
#define DEBUG_DIR_ENTRY "ssv"
|
#define DEBUG_DEVICETYPE_ENTRY "ssv_devicetype"
|
#define DEBUG_CMD_ENTRY "ssv_cmd"
|
#define MAX_CHARS_PER_LINE 256
|
struct ssv_cmd_table {
|
const char *cmd;
|
int (*cmd_func_ptr)(int, char **);
|
const char *usage;
|
};
|
struct ssv6xxx_cfg_cmd_table {
|
u8 *cfg_cmd;
|
void *var;
|
u32 arg;
|
int (*translate_func)(u8 *, void *, u32);
|
};
|
#define SSV_REG_READ1(ops,reg,val) \
|
(ops)->ifops->readreg((ops)->dev, reg, val)
|
#define SSV_REG_WRITE1(ops,reg,val) \
|
(ops)->ifops->writereg((ops)->dev, reg, val)
|
#define SSV_REG_SET_BITS1(ops,reg,set,clr) \
|
{ \
|
u32 reg_val; \
|
SSV_REG_READ(ops, reg, ®_val); \
|
reg_val &= ~(clr); \
|
reg_val |= (set); \
|
SSV_REG_WRITE(ops, reg, reg_val); \
|
}
|
int ssv_cmd_submit(char *cmd);
|
#endif
|