* [PATCH - UCM 1/2] control: add hexadecimal parse
@ 2015-01-12 5:21 han.lu
2015-01-12 5:21 ` [PATCH - UCM 2/2] ucm: add binary file parse han.lu
2015-01-12 7:50 ` [PATCH - UCM 1/2] control: add hexadecimal parse Takashi Iwai
0 siblings, 2 replies; 6+ messages in thread
From: han.lu @ 2015-01-12 5:21 UTC (permalink / raw)
To: patch; +Cc: Lu, Han, alsa-devel
From: "Lu, Han" <han.lu@intel.com>
Signed-off-by: Lu, Han <han.lu@intel.com>
diff --git a/src/control/ctlparse.c b/src/control/ctlparse.c
index 978977d..92e2f95 100644
--- a/src/control/ctlparse.c
+++ b/src/control/ctlparse.c
@@ -59,7 +59,10 @@ static long get_integer(const char **ptr, long min, long max)
goto out;
s = p;
- val = strtol(s, &p, 10);
+ if (*p == '0' && (*(p+1) == 'x' || *(p+1) == 'X'))
+ val = strtol(s, &p, 16);
+ else
+ val = strtol(s, &p, 10);
if (*p == '.') {
p++;
strtol(p, &p, 10);
@@ -87,7 +90,10 @@ static long long get_integer64(const char **ptr, long long min, long long max)
goto out;
s = p;
- val = strtol(s, &p, 10);
+ if (*p == '0' && (*(p+1) == 'x' || *(p+1) == 'X'))
+ val = strtol(s, &p, 16);
+ else
+ val = strtol(s, &p, 10);
if (*p == '.') {
p++;
strtol(p, &p, 10);
--
1.9.1
^ permalink raw reply related [flat|nested] 6+ messages in thread
* [PATCH - UCM 2/2] ucm: add binary file parse
2015-01-12 5:21 [PATCH - UCM 1/2] control: add hexadecimal parse han.lu
@ 2015-01-12 5:21 ` han.lu
2015-01-12 14:50 ` Takashi Iwai
2015-01-12 7:50 ` [PATCH - UCM 1/2] control: add hexadecimal parse Takashi Iwai
1 sibling, 1 reply; 6+ messages in thread
From: han.lu @ 2015-01-12 5:21 UTC (permalink / raw)
To: patch; +Cc: Lu, Han, alsa-devel
From: "Lu, Han" <han.lu@intel.com>
Signed-off-by: Lu, Han <han.lu@intel.com>
diff --git a/src/ucm/main.c b/src/ucm/main.c
index 37ae4c8..1496b22 100644
--- a/src/ucm/main.c
+++ b/src/ucm/main.c
@@ -160,11 +160,45 @@ static int open_ctl(snd_use_case_mgr_t *uc_mgr,
return 0;
}
+static int binary_file_parse(snd_ctl_elem_value_t *dst,
+ const char *filepath)
+{
+ int err = 0;
+ FILE *in;
+ long len;
+ char *res;
+ unsigned int idx;
+
+ in = fopen(filepath, "r");
+ if (!in) {
+ err = -errno;
+ goto __fail;
+ }
+ fseek(in, 0L, SEEK_END);
+ len = ftell(in);
+ rewind(in);
+ if (len > 512)
+ len = 512;
+ res = calloc(1, (size_t)len);
+ if (res == NULL) {
+ err = -ENOMEM;
+ goto __fail_nomem;
+ }
+ fread(res, (size_t)len, 1, in);
+ for (idx = 0; idx < len; idx++)
+ snd_ctl_elem_value_set_byte(dst, idx, *(res + idx));
+ free(res);
+ __fail_nomem:
+ fclose(in);
+ __fail:
+ return err;
+}
+
extern int __snd_ctl_ascii_elem_id_parse(snd_ctl_elem_id_t *dst,
const char *str,
const char **ret_ptr);
-static int execute_cset(snd_ctl_t *ctl, const char *cset)
+static int execute_cset(snd_ctl_t *ctl, const char *cset, int isbin)
{
const char *pos;
int err;
@@ -194,7 +228,10 @@ static int execute_cset(snd_ctl_t *ctl, const char *cset)
err = snd_ctl_elem_info(ctl, info);
if (err < 0)
goto __fail;
- err = snd_ctl_ascii_value_parse(ctl, value, info, pos);
+ if (isbin)
+ err = binary_file_parse(value, pos);
+ else
+ err = snd_ctl_ascii_value_parse(ctl, value, info, pos);
if (err < 0)
goto __fail;
err = snd_ctl_elem_write(ctl, value);
@@ -239,6 +276,7 @@ static int execute_sequence(snd_use_case_mgr_t *uc_mgr,
goto __fail_nomem;
break;
case SEQUENCE_ELEMENT_TYPE_CSET:
+ case SEQUENCE_ELEMENT_TYPE_BCSETF:
if (cdev == NULL) {
const char *cdev1 = NULL, *cdev2 = NULL;
err = get_value3(&cdev1, "PlaybackCTL",
@@ -274,7 +312,7 @@ static int execute_sequence(snd_use_case_mgr_t *uc_mgr,
goto __fail;
}
}
- err = execute_cset(ctl, s->data.cset);
+ err = execute_cset(ctl, s->data.cset, s->isbin);
if (err < 0) {
uc_error("unable to execute cset '%s'\n", s->data.cset);
goto __fail;
diff --git a/src/ucm/parser.c b/src/ucm/parser.c
index d7517f6..686c883 100644
--- a/src/ucm/parser.c
+++ b/src/ucm/parser.c
@@ -306,6 +306,17 @@ static int parse_sequence(snd_use_case_mgr_t *uc_mgr ATTRIBUTE_UNUSED,
continue;
}
+ if (strcmp(cmd, "bcsetf") == 0) {
+ curr->type = SEQUENCE_ELEMENT_TYPE_BCSETF;
+ curr->isbin = 1;
+ err = parse_string(n, &curr->data.cset);
+ if (err < 0) {
+ uc_error("error: bcsetf requires a string!");
+ return err;
+ }
+ continue;
+ }
+
if (strcmp(cmd, "usleep") == 0) {
curr->type = SEQUENCE_ELEMENT_TYPE_SLEEP;
err = snd_config_get_integer(n, &curr->data.sleep);
diff --git a/src/ucm/ucm_local.h b/src/ucm/ucm_local.h
index 87f14a2..80d7335 100644
--- a/src/ucm/ucm_local.h
+++ b/src/ucm/ucm_local.h
@@ -47,6 +47,7 @@
#define SEQUENCE_ELEMENT_TYPE_CSET 2
#define SEQUENCE_ELEMENT_TYPE_SLEEP 3
#define SEQUENCE_ELEMENT_TYPE_EXEC 4
+#define SEQUENCE_ELEMENT_TYPE_BCSETF 5
struct ucm_value {
struct list_head list;
@@ -63,6 +64,7 @@ struct sequence_element {
char *cset;
char *exec;
} data;
+ int isbin; /* Indicate cset is binary array or ascii array */
};
/*
--
1.9.1
^ permalink raw reply related [flat|nested] 6+ messages in thread
* Re: [PATCH - UCM 1/2] control: add hexadecimal parse
2015-01-12 5:21 [PATCH - UCM 1/2] control: add hexadecimal parse han.lu
2015-01-12 5:21 ` [PATCH - UCM 2/2] ucm: add binary file parse han.lu
@ 2015-01-12 7:50 ` Takashi Iwai
2015-01-13 3:02 ` Lu, Han
1 sibling, 1 reply; 6+ messages in thread
From: Takashi Iwai @ 2015-01-12 7:50 UTC (permalink / raw)
To: han.lu; +Cc: alsa-devel
At Mon, 12 Jan 2015 13:21:16 +0800,
han.lu@intel.com wrote:
>
> From: "Lu, Han" <han.lu@intel.com>
>
> Signed-off-by: Lu, Han <han.lu@intel.com>
>
> diff --git a/src/control/ctlparse.c b/src/control/ctlparse.c
> index 978977d..92e2f95 100644
> --- a/src/control/ctlparse.c
> +++ b/src/control/ctlparse.c
> @@ -59,7 +59,10 @@ static long get_integer(const char **ptr, long min, long max)
> goto out;
>
> s = p;
> - val = strtol(s, &p, 10);
> + if (*p == '0' && (*(p+1) == 'x' || *(p+1) == 'X'))
> + val = strtol(s, &p, 16);
> + else
> + val = strtol(s, &p, 10);
Just pass 0 to the base of strtol() instead of 10. That'll do
everything.
Takashi
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH - UCM 2/2] ucm: add binary file parse
2015-01-12 5:21 ` [PATCH - UCM 2/2] ucm: add binary file parse han.lu
@ 2015-01-12 14:50 ` Takashi Iwai
2015-01-13 3:04 ` Lu, Han
0 siblings, 1 reply; 6+ messages in thread
From: Takashi Iwai @ 2015-01-12 14:50 UTC (permalink / raw)
To: han.lu; +Cc: alsa-devel
At Mon, 12 Jan 2015 13:21:17 +0800,
han.lu@intel.com wrote:
>
> From: "Lu, Han" <han.lu@intel.com>
>
> Signed-off-by: Lu, Han <han.lu@intel.com>
The most important part is missing -- the patch description. Please
give a more detailed description, i.e. what this patch does, why this
is needed and how it's implemented. (And what does BCSETF mean? Is
another form of WTF? :)
thanks,
Takashi
>
> diff --git a/src/ucm/main.c b/src/ucm/main.c
> index 37ae4c8..1496b22 100644
> --- a/src/ucm/main.c
> +++ b/src/ucm/main.c
> @@ -160,11 +160,45 @@ static int open_ctl(snd_use_case_mgr_t *uc_mgr,
> return 0;
> }
>
> +static int binary_file_parse(snd_ctl_elem_value_t *dst,
> + const char *filepath)
> +{
> + int err = 0;
> + FILE *in;
> + long len;
> + char *res;
> + unsigned int idx;
> +
> + in = fopen(filepath, "r");
> + if (!in) {
> + err = -errno;
> + goto __fail;
> + }
> + fseek(in, 0L, SEEK_END);
> + len = ftell(in);
> + rewind(in);
> + if (len > 512)
> + len = 512;
> + res = calloc(1, (size_t)len);
> + if (res == NULL) {
> + err = -ENOMEM;
> + goto __fail_nomem;
> + }
> + fread(res, (size_t)len, 1, in);
> + for (idx = 0; idx < len; idx++)
> + snd_ctl_elem_value_set_byte(dst, idx, *(res + idx));
> + free(res);
> + __fail_nomem:
> + fclose(in);
> + __fail:
> + return err;
> +}
> +
> extern int __snd_ctl_ascii_elem_id_parse(snd_ctl_elem_id_t *dst,
> const char *str,
> const char **ret_ptr);
>
> -static int execute_cset(snd_ctl_t *ctl, const char *cset)
> +static int execute_cset(snd_ctl_t *ctl, const char *cset, int isbin)
> {
> const char *pos;
> int err;
> @@ -194,7 +228,10 @@ static int execute_cset(snd_ctl_t *ctl, const char *cset)
> err = snd_ctl_elem_info(ctl, info);
> if (err < 0)
> goto __fail;
> - err = snd_ctl_ascii_value_parse(ctl, value, info, pos);
> + if (isbin)
> + err = binary_file_parse(value, pos);
> + else
> + err = snd_ctl_ascii_value_parse(ctl, value, info, pos);
> if (err < 0)
> goto __fail;
> err = snd_ctl_elem_write(ctl, value);
> @@ -239,6 +276,7 @@ static int execute_sequence(snd_use_case_mgr_t *uc_mgr,
> goto __fail_nomem;
> break;
> case SEQUENCE_ELEMENT_TYPE_CSET:
> + case SEQUENCE_ELEMENT_TYPE_BCSETF:
> if (cdev == NULL) {
> const char *cdev1 = NULL, *cdev2 = NULL;
> err = get_value3(&cdev1, "PlaybackCTL",
> @@ -274,7 +312,7 @@ static int execute_sequence(snd_use_case_mgr_t *uc_mgr,
> goto __fail;
> }
> }
> - err = execute_cset(ctl, s->data.cset);
> + err = execute_cset(ctl, s->data.cset, s->isbin);
> if (err < 0) {
> uc_error("unable to execute cset '%s'\n", s->data.cset);
> goto __fail;
> diff --git a/src/ucm/parser.c b/src/ucm/parser.c
> index d7517f6..686c883 100644
> --- a/src/ucm/parser.c
> +++ b/src/ucm/parser.c
> @@ -306,6 +306,17 @@ static int parse_sequence(snd_use_case_mgr_t *uc_mgr ATTRIBUTE_UNUSED,
> continue;
> }
>
> + if (strcmp(cmd, "bcsetf") == 0) {
> + curr->type = SEQUENCE_ELEMENT_TYPE_BCSETF;
> + curr->isbin = 1;
> + err = parse_string(n, &curr->data.cset);
> + if (err < 0) {
> + uc_error("error: bcsetf requires a string!");
> + return err;
> + }
> + continue;
> + }
> +
> if (strcmp(cmd, "usleep") == 0) {
> curr->type = SEQUENCE_ELEMENT_TYPE_SLEEP;
> err = snd_config_get_integer(n, &curr->data.sleep);
> diff --git a/src/ucm/ucm_local.h b/src/ucm/ucm_local.h
> index 87f14a2..80d7335 100644
> --- a/src/ucm/ucm_local.h
> +++ b/src/ucm/ucm_local.h
> @@ -47,6 +47,7 @@
> #define SEQUENCE_ELEMENT_TYPE_CSET 2
> #define SEQUENCE_ELEMENT_TYPE_SLEEP 3
> #define SEQUENCE_ELEMENT_TYPE_EXEC 4
> +#define SEQUENCE_ELEMENT_TYPE_BCSETF 5
>
> struct ucm_value {
> struct list_head list;
> @@ -63,6 +64,7 @@ struct sequence_element {
> char *cset;
> char *exec;
> } data;
> + int isbin; /* Indicate cset is binary array or ascii array */
> };
>
> /*
> --
> 1.9.1
>
> _______________________________________________
> Alsa-devel mailing list
> Alsa-devel@alsa-project.org
> http://mailman.alsa-project.org/mailman/listinfo/alsa-devel
>
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH - UCM 1/2] control: add hexadecimal parse
2015-01-12 7:50 ` [PATCH - UCM 1/2] control: add hexadecimal parse Takashi Iwai
@ 2015-01-13 3:02 ` Lu, Han
0 siblings, 0 replies; 6+ messages in thread
From: Lu, Han @ 2015-01-13 3:02 UTC (permalink / raw)
To: Takashi Iwai; +Cc: alsa-devel@alsa-project.org
Hi Takashi,
BR,
Han Lu
> -----Original Message-----
> From: Takashi Iwai [mailto:tiwai@suse.de]
> Sent: Monday, January 12, 2015 3:50 PM
> To: Lu, Han
> Cc: alsa-devel@alsa-project.org
> Subject: Re: [PATCH - UCM 1/2] control: add hexadecimal parse
>
> At Mon, 12 Jan 2015 13:21:16 +0800,
> han.lu@intel.com wrote:
> >
> > From: "Lu, Han" <han.lu@intel.com>
> >
> > Signed-off-by: Lu, Han <han.lu@intel.com>
> >
> > diff --git a/src/control/ctlparse.c b/src/control/ctlparse.c index
> > 978977d..92e2f95 100644
> > --- a/src/control/ctlparse.c
> > +++ b/src/control/ctlparse.c
> > @@ -59,7 +59,10 @@ static long get_integer(const char **ptr, long min,
> long max)
> > goto out;
> >
> > s = p;
> > - val = strtol(s, &p, 10);
> > + if (*p == '0' && (*(p+1) == 'x' || *(p+1) == 'X'))
> > + val = strtol(s, &p, 16);
> > + else
> > + val = strtol(s, &p, 10);
>
> Just pass 0 to the base of strtol() instead of 10. That'll do everything.
>
Thank you, I have validated it and resend the patch.
>
> Takashi
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH - UCM 2/2] ucm: add binary file parse
2015-01-12 14:50 ` Takashi Iwai
@ 2015-01-13 3:04 ` Lu, Han
0 siblings, 0 replies; 6+ messages in thread
From: Lu, Han @ 2015-01-13 3:04 UTC (permalink / raw)
To: Takashi Iwai; +Cc: alsa-devel@alsa-project.org
Hi Takashi,
BR,
Han Lu
> -----Original Message-----
> From: Takashi Iwai [mailto:tiwai@suse.de]
> Sent: Monday, January 12, 2015 10:50 PM
> To: Lu, Han
> Cc: alsa-devel@alsa-project.org
> Subject: Re: [alsa-devel] [PATCH - UCM 2/2] ucm: add binary file parse
>
> At Mon, 12 Jan 2015 13:21:17 +0800,
> han.lu@intel.com wrote:
> >
> > From: "Lu, Han" <han.lu@intel.com>
> >
> > Signed-off-by: Lu, Han <han.lu@intel.com>
>
> The most important part is missing -- the patch description. Please give a
> more detailed description, i.e. what this patch does, why this is needed and
> how it's implemented. (And what does BCSETF mean? Is another form of
> WTF? :)
>
Sorry, I have added description and resend the patch, please review. Thanks.
>
> thanks,
>
> Takashi
>
> >
> > diff --git a/src/ucm/main.c b/src/ucm/main.c index 37ae4c8..1496b22
> > 100644
> > --- a/src/ucm/main.c
> > +++ b/src/ucm/main.c
> > @@ -160,11 +160,45 @@ static int open_ctl(snd_use_case_mgr_t *uc_mgr,
> > return 0;
> > }
> >
> > +static int binary_file_parse(snd_ctl_elem_value_t *dst,
> > + const char *filepath)
> > +{
> > + int err = 0;
> > + FILE *in;
> > + long len;
> > + char *res;
> > + unsigned int idx;
> > +
> > + in = fopen(filepath, "r");
> > + if (!in) {
> > + err = -errno;
> > + goto __fail;
> > + }
> > + fseek(in, 0L, SEEK_END);
> > + len = ftell(in);
> > + rewind(in);
> > + if (len > 512)
> > + len = 512;
> > + res = calloc(1, (size_t)len);
> > + if (res == NULL) {
> > + err = -ENOMEM;
> > + goto __fail_nomem;
> > + }
> > + fread(res, (size_t)len, 1, in);
> > + for (idx = 0; idx < len; idx++)
> > + snd_ctl_elem_value_set_byte(dst, idx, *(res + idx));
> > + free(res);
> > + __fail_nomem:
> > + fclose(in);
> > + __fail:
> > + return err;
> > +}
> > +
> > extern int __snd_ctl_ascii_elem_id_parse(snd_ctl_elem_id_t *dst,
> > const char *str,
> > const char **ret_ptr);
> >
> > -static int execute_cset(snd_ctl_t *ctl, const char *cset)
> > +static int execute_cset(snd_ctl_t *ctl, const char *cset, int isbin)
> > {
> > const char *pos;
> > int err;
> > @@ -194,7 +228,10 @@ static int execute_cset(snd_ctl_t *ctl, const char
> *cset)
> > err = snd_ctl_elem_info(ctl, info);
> > if (err < 0)
> > goto __fail;
> > - err = snd_ctl_ascii_value_parse(ctl, value, info, pos);
> > + if (isbin)
> > + err = binary_file_parse(value, pos);
> > + else
> > + err = snd_ctl_ascii_value_parse(ctl, value, info, pos);
> > if (err < 0)
> > goto __fail;
> > err = snd_ctl_elem_write(ctl, value); @@ -239,6 +276,7 @@ static int
> > execute_sequence(snd_use_case_mgr_t *uc_mgr,
> > goto __fail_nomem;
> > break;
> > case SEQUENCE_ELEMENT_TYPE_CSET:
> > + case SEQUENCE_ELEMENT_TYPE_BCSETF:
> > if (cdev == NULL) {
> > const char *cdev1 = NULL, *cdev2 = NULL;
> > err = get_value3(&cdev1, "PlaybackCTL", @@
> -274,7 +312,7 @@
> > static int execute_sequence(snd_use_case_mgr_t *uc_mgr,
> > goto __fail;
> > }
> > }
> > - err = execute_cset(ctl, s->data.cset);
> > + err = execute_cset(ctl, s->data.cset, s->isbin);
> > if (err < 0) {
> > uc_error("unable to execute cset '%s'\n", s-
> >data.cset);
> > goto __fail;
> > diff --git a/src/ucm/parser.c b/src/ucm/parser.c index
> > d7517f6..686c883 100644
> > --- a/src/ucm/parser.c
> > +++ b/src/ucm/parser.c
> > @@ -306,6 +306,17 @@ static int parse_sequence(snd_use_case_mgr_t
> *uc_mgr ATTRIBUTE_UNUSED,
> > continue;
> > }
> >
> > + if (strcmp(cmd, "bcsetf") == 0) {
> > + curr->type = SEQUENCE_ELEMENT_TYPE_BCSETF;
> > + curr->isbin = 1;
> > + err = parse_string(n, &curr->data.cset);
> > + if (err < 0) {
> > + uc_error("error: bcsetf requires a string!");
> > + return err;
> > + }
> > + continue;
> > + }
> > +
> > if (strcmp(cmd, "usleep") == 0) {
> > curr->type = SEQUENCE_ELEMENT_TYPE_SLEEP;
> > err = snd_config_get_integer(n, &curr->data.sleep);
> diff --git
> > a/src/ucm/ucm_local.h b/src/ucm/ucm_local.h index 87f14a2..80d7335
> > 100644
> > --- a/src/ucm/ucm_local.h
> > +++ b/src/ucm/ucm_local.h
> > @@ -47,6 +47,7 @@
> > #define SEQUENCE_ELEMENT_TYPE_CSET 2
> > #define SEQUENCE_ELEMENT_TYPE_SLEEP 3
> > #define SEQUENCE_ELEMENT_TYPE_EXEC 4
> > +#define SEQUENCE_ELEMENT_TYPE_BCSETF 5
> >
> > struct ucm_value {
> > struct list_head list;
> > @@ -63,6 +64,7 @@ struct sequence_element {
> > char *cset;
> > char *exec;
> > } data;
> > + int isbin; /* Indicate cset is binary array or ascii array */
> > };
> >
> > /*
> > --
> > 1.9.1
> >
> > _______________________________________________
> > Alsa-devel mailing list
> > Alsa-devel@alsa-project.org
> > http://mailman.alsa-project.org/mailman/listinfo/alsa-devel
> >
^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2015-01-13 3:04 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-01-12 5:21 [PATCH - UCM 1/2] control: add hexadecimal parse han.lu
2015-01-12 5:21 ` [PATCH - UCM 2/2] ucm: add binary file parse han.lu
2015-01-12 14:50 ` Takashi Iwai
2015-01-13 3:04 ` Lu, Han
2015-01-12 7:50 ` [PATCH - UCM 1/2] control: add hexadecimal parse Takashi Iwai
2015-01-13 3:02 ` Lu, Han
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.