Hi Takashi, Really sorry for missed your reply for so long due to a problem of my inbox filter... I will upload a new patch to address your comments. Thanks, Hsin-yu On Thu, Mar 24, 2016 at 9:19 PM, Takashi Iwai <tiwai@xxxxxxx> wrote: > On Thu, 24 Mar 2016 03:28:21 +0100, > Hsin-Yu Chao wrote: >> >> This patch enables UCM to set a file in TLV format to kcontrol by: >> cset-tlv "name='<kcontrol-name>' <path-to-file>" >> This new 'cset-tlv' command will be used to write audio DSP to >> specific alsa control, where the driver expectes a file in TLV >> format. >> The TLV file to set to kcontrol will be checked first by file size >> not larger than 16 MB, and then examine if the length field reports >> correct number of bytes in the TLV file. >> >> Signed-off-by: Hsin-Yu Chao <hychao@xxxxxxxxxxxx> >> --- >> src/ucm/main.c | 91 +++++++++++++++++++++++++++++++++++++++++++++-------- >> src/ucm/parser.c | 10 ++++++ >> src/ucm/ucm_local.h | 1 + >> 3 files changed, 89 insertions(+), 13 deletions(-) >> >> diff --git a/src/ucm/main.c b/src/ucm/main.c >> index 7e44603..d0929a2 100644 >> --- a/src/ucm/main.c >> +++ b/src/ucm/main.c >> @@ -161,6 +161,54 @@ static int open_ctl(snd_use_case_mgr_t *uc_mgr, >> return 0; >> } >> >> +static int read_tlv_file(char **res, >> + const char *filepath) >> +{ >> + int err = 0; >> + int fd; >> + struct stat st; >> + size_t sz; >> + ssize_t sz_read; >> + unsigned int *tlv; >> + >> + fd = open(filepath, O_RDONLY); >> + if (fd < 0) { >> + err = -errno; >> + return err; >> + } >> + if (stat(filepath, &st) == -1) { > > Better to use fstat() with the opened fd. > > >> + err = -errno; >> + goto __fail; >> + } >> + sz = st.st_size; >> + if (sz > 16 * 1024 * 1024 || sz < 8) { >> + uc_error("File size should be less than 16 MB"); >> + goto __fail; > > The error code is missing. > > >> + } >> + *res = malloc(sz); >> + if (res == NULL) { >> + err = -ENOMEM; >> + goto __fail; >> + } >> + sz_read = read(fd, *res, sz); >> + if (sz_read < 0 || (size_t)sz_read != sz) { >> + err = -errno; > > The size shortage won't set the errno. You'd need to give the error > code explicitly, or repeat the read. > > >> + free(*res); >> + *res = NULL; >> + } >> + /* Check if the tlv file specifies valid size. */ >> + tlv = (unsigned int *)(*res); >> + if (tlv[1] + 2 * sizeof(unsigned int) != sz) { >> + uc_error("Invalid tlv size"); >> + free(*res); >> + *res = NULL; > > The missing error code. > > > thanks, > > Takashi _______________________________________________ Alsa-devel mailing list Alsa-devel@xxxxxxxxxxxxxxxx http://mailman.alsa-project.org/mailman/listinfo/alsa-devel