[igt-dev] [PATCH i-g-t RFC] lib/igt_chamelium: Use curl timeout for xmlrpc calls
Juha-Pekka Heikkila
juhapekka.heikkila at gmail.com
Thu Sep 24 13:25:17 UTC 2020
I guess CI isn't going to run this code anywhere for now? The change
look ok to me. Assuming the results will be all green,
Reviewed-by: Juha-Pekka Heikkila <juhapekka.heikkila at gmail.com>
On 24.9.2020 15.36, Petri Latvala wrote:
> Use of timeouts everywhere is meaningless if xmlrpc calls are allowed
> to be blocking forever.
>
> Signed-off-by: Petri Latvala <petri.latvala at intel.com>
> Cc: Kunal Joshi <kunal1.joshi at intel.com>
> Cc: Arkadiusz Hiler <arek at hiler.eu>
> Cc: Juha-Pekka Heikkila <juhapekka.heikkila at gmail.com>
> ---
> lib/igt_chamelium.c | 12 +++++++++++-
> 1 file changed, 11 insertions(+), 1 deletion(-)
>
> diff --git a/lib/igt_chamelium.c b/lib/igt_chamelium.c
> index d9fab902..eac893a6 100644
> --- a/lib/igt_chamelium.c
> +++ b/lib/igt_chamelium.c
> @@ -2427,11 +2427,21 @@ void chamelium_deinit_rpc_only(struct chamelium *chamelium)
> struct chamelium *chamelium_init_rpc_only(void)
> {
> struct chamelium *chamelium = malloc(sizeof(struct chamelium));
> + struct xmlrpc_clientparms clientparms;
> + struct xmlrpc_curl_xportparms curlparms;
>
> if (!chamelium)
> return NULL;
>
> memset(chamelium, 0, sizeof(*chamelium));
> + memset(&clientparms, 0, sizeof(clientparms));
> + memset(&curlparms, 0, sizeof(curlparms));
> +
> + curlparms.timeout = _RECEIVER_RESPONSIVE_AFTER_RESET_SECONDS;
> +
> + clientparms.transport = "curl";
> + clientparms.transportparmsP = &curlparms;
> + clientparms.transportparm_size = XMLRPC_CXPSIZE(timeout);
>
> chamelium->drm_fd = -1;
>
> @@ -2439,7 +2449,7 @@ struct chamelium *chamelium_init_rpc_only(void)
> xmlrpc_env_init(&chamelium->env);
> xmlrpc_client_setup_global_const(&chamelium->env);
> xmlrpc_client_create(&chamelium->env, XMLRPC_CLIENT_NO_FLAGS, PACKAGE,
> - PACKAGE_VERSION, NULL, 0, &chamelium->client);
> + PACKAGE_VERSION, &clientparms, 0, &chamelium->client);
> if (chamelium->env.fault_occurred) {
> igt_debug("Failed to init xmlrpc: %s\n",
> chamelium->env.fault_string);
>
More information about the igt-dev
mailing list