From: Jan-Simon Moeller Date: Mon, 19 Dec 2016 21:12:33 +0000 (+0000) Subject: Merge "Remove SIMULATE_HVAC define to make hvac use can bus" X-Git-Tag: 3.0.0~3 X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=commitdiff_plain;h=52233abc17f2238ffa4ee0a10b72376d503766b2;hp=-c;p=apps%2Fhvac.git Merge "Remove SIMULATE_HVAC define to make hvac use can bus" --- 52233abc17f2238ffa4ee0a10b72376d503766b2 diff --combined binding/hvac-demo-binding.c index 96b448a,d35330e..4913380 --- a/binding/hvac-demo-binding.c +++ b/binding/hvac-demo-binding.c @@@ -31,12 -31,56 +31,56 @@@ #include #include - #define CAN_DEV "vcan0" + // Uncomment this line to pass into can simulation mode + //#define SIMULATE_HVAC - #define SIMULATE_HVAC + #define CAN_DEV "vcan0" static const struct afb_binding_interface *interface; + /*****************************************************************************************/ + /*****************************************************************************************/ + /** **/ + /** **/ + /** SECTION: UTILITY FUNCTIONS **/ + /** **/ + /** **/ + /*****************************************************************************************/ + /*****************************************************************************************/ + + /* + * @brief Retry a function 3 times + * + * @param int function(): function that return an int wihtout any parameter + * + * @ return : 0 if ok, -1 if failed + * + */ + static int retry( int(*func)()) + { + int i; + + for (i=0;i<4;i++) + { + if ( (*func)() >= 0) + { + return 0; + } + usleep(100000); + } + return -1; + } + + /*****************************************************************************************/ + /*****************************************************************************************/ + /** **/ + /** **/ + /** SECTION: HANDLE CAN DEVICE **/ + /** **/ + /** **/ + /*****************************************************************************************/ + /*****************************************************************************************/ + // Initialize CAN hvac array that will be sent trough the socket static struct { const char *name; @@@ -55,16 -99,6 +99,6 @@@ struct can_handler static struct can_handler can_handler = { .socket = -1 }; - /*****************************************************************************************/ - /*****************************************************************************************/ - /** **/ - /** **/ - /** SECTION: HANDLE CAN DEVICE **/ - /** **/ - /** **/ - /*****************************************************************************************/ - /*****************************************************************************************/ - static int open_can_dev() { #if defined(SIMULATE_HVAC) @@@ -74,6 -108,9 +108,9 @@@ #else struct ifreq ifr; + DEBUG(interface, "CAN Handler socket : %d", can_handler.socket); + close(can_handler.socket); + can_handler.socket = socket(PF_CAN, SOCK_RAW, CAN_RAW); if (can_handler.socket < 0) { @@@ -137,7 -174,7 +174,7 @@@ static uint8_t read_temp( static uint8_t read_fanspeed() { - return hvac_values[3].value; + return hvac_values[3].value ^ 0xFF; } static int write_can() @@@ -175,13 -212,15 +212,15 @@@ (struct sockaddr*)&can_handler.txAddress, sizeof(can_handler.txAddress)); if (rc < 0) { - ERROR(interface, "Sending can frame failed"); + ERROR(interface, "Sending can frame failed. Attempt to reopen can device socket."); + retry(open_can_dev); } #endif } else { - ERROR(interface, "socket not initialized"); + ERROR(interface, "socket not initialized. Attempt to reopen can device socket."); + retry(open_can_dev); } return rc; } @@@ -343,7 -382,7 +382,7 @@@ static void set(struct afb_req request rc = write_can(); if (rc >= 0) afb_req_success(request, NULL, NULL); - else { + else if (retry(write_can)) { /* restore initial values */ i = (int)(sizeof hvac_values / sizeof *hvac_values); while (i) { @@@ -386,5 -425,5 +425,5 @@@ const struct afb_binding *afbBindingV1R int afbBindingV1ServiceInit(struct afb_service service) { - return open_can_dev(); + return retry(open_can_dev); }