@@ -165,11 +165,65 @@ class StableDiffusionGGML {
165165#endif
166166#ifdef SD_USE_VULKAN
167167 LOG_DEBUG (" Using Vulkan backend" );
168- for (int device = 0 ; device < ggml_backend_vk_get_device_count (); ++device) {
169- backend = ggml_backend_vk_init (device);
168+ int dev_count = ggml_backend_vk_get_device_count ();
169+ int dev = 0 ;
170+
171+ // Log available devices
172+ LOG_INFO (" Found %d Vulkan devices:" , dev_count);
173+ for (int i = 0 ; i < dev_count; ++i) {
174+ char desc[256 ] = {0 };
175+ size_t free_mem = 0 ;
176+ size_t total_mem = 0 ;
177+ ggml_backend_vk_get_device_description (i, desc, sizeof (desc));
178+ ggml_backend_vk_get_device_memory (i, &free_mem, &total_mem);
179+ LOG_INFO (" - %d: %s (VRAM: %.2f / %.2f GB)" , i, desc, free_mem / 1024.0 / 1024.0 / 1024.0 , total_mem / 1024.0 / 1024.0 / 1024.0 );
170180 }
181+
182+ if (const char * s = getenv (" GGML_VK_DEVICE" )) {
183+ int v = atoi (s);
184+ if (v >= 0 && v < dev_count) {
185+ dev = v;
186+ }
187+ } else {
188+ // If no device is specified, try to find the best one
189+ int64_t max_score = -1 ;
190+ int best_dev = 0 ;
191+ for (int i = 0 ; i < dev_count; i++) {
192+ char desc[256 ] = {0 };
193+ size_t free_mem = 0 ;
194+ size_t total_mem = 0 ;
195+ ggml_backend_vk_get_device_description (i, desc, sizeof (desc));
196+ ggml_backend_vk_get_device_memory (i, &free_mem, &total_mem);
197+
198+ int64_t score = total_mem; // Base score on VRAM
199+
200+ std::string d (desc);
201+ // Adjust score based on device type
202+ if (d.find (" Radeon" ) != std::string::npos || d.find (" NVIDIA" ) != std::string::npos || d.find (" Arc" ) != std::string::npos) {
203+ score += 1LL << 40 ; // Discrete GPU bonus
204+ }
205+ if (d.find (" Integrated" ) != std::string::npos) {
206+ score -= 1LL << 40 ; // Integrated GPU penalty
207+ }
208+ if (d.find (" SwiftShader" ) != std::string::npos) {
209+ score = -1 ; // Heavily penalize software renderer
210+ }
211+
212+ if (score > max_score) {
213+ max_score = score;
214+ best_dev = i;
215+ }
216+ }
217+ dev = best_dev;
218+ }
219+
220+ backend = ggml_backend_vk_init (dev);
171221 if (!backend) {
172- LOG_WARN (" Failed to initialize Vulkan backend" );
222+ LOG_WARN (" Failed to initialize Vulkan backend (device %d)" , dev);
223+ } else {
224+ char desc[256 ] = {0 };
225+ ggml_backend_vk_get_device_description (dev, desc, sizeof (desc));
226+ LOG_INFO (" Vulkan selected device: %d - %s" , dev, desc);
173227 }
174228#endif
175229#ifdef SD_USE_OPENCL
0 commit comments