From 8f58d256148b2dfbff3312d7169e43ce11b845c2 Mon Sep 17 00:00:00 2001 From: nelisky Date: Sun, 18 Mar 2012 22:37:37 +0000 Subject: [PATCH] Improved ztex device detection --- ztex.c | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) diff --git a/ztex.c b/ztex.c index 02f672fb..fa68fdc9 100644 --- a/ztex.c +++ b/ztex.c @@ -30,16 +30,24 @@ #define GOLDEN_BACKLOG 5 -struct device_api ztex_api; +struct device_api ztex_api, ztex_hotplug_api; // Forward declarations static void ztex_disable (struct thr_info* thr); +static bool ztex_prepare(struct thr_info *thr); static void ztex_detect() { int cnt; int i; struct libztex_dev_list **ztex_devices; + struct cgpu_info *ztex; + + ztex = calloc(1, sizeof(struct cgpu_info)); + ztex->api = &ztex_hotplug_api; + ztex->threads = 1; + devices[total_devices++] = ztex; + cnt = libztex_scanDevices(&ztex_devices); applog(LOG_WARNING, "Found %d ztex board(s)", cnt); @@ -47,7 +55,6 @@ static void ztex_detect() for (i=0; iapi = &ztex_api; ztex->device_id = total_devices; @@ -280,13 +287,17 @@ static bool ztex_prepare(struct thr_info *thr) static void ztex_shutdown(struct thr_info *thr) { - libztex_destroy_device(thr->cgpu->device); + if (thr->cgpu->device != NULL) { + libztex_destroy_device(thr->cgpu->device); + thr->cgpu->device = NULL; + } } static void ztex_disable (struct thr_info *thr) { applog(LOG_ERR, "%s: Disabling!", thr->cgpu->device->repr); devices[thr->cgpu->device_id]->deven = DEV_DISABLED; + ztex_shutdown(thr); } struct device_api ztex_api = {