1 // SPDX-License-Identifier: GPL-2.0-or-later 2 /* Driver for Virtio crypto device. 3 * 4 * Copyright 2016 HUAWEI TECHNOLOGIES CO., LTD. 5 */ 6 7 #include <linux/err.h> 8 #include <linux/module.h> 9 #include <linux/virtio_config.h> 10 #include <linux/cpu.h> 11 12 #include <uapi/linux/virtio_crypto.h> 13 #include "virtio_crypto_common.h" 14 15 16 void 17 virtcrypto_clear_request(struct virtio_crypto_request *vc_req) 18 { 19 if (vc_req) { 20 kfree_sensitive(vc_req->req_data); 21 kfree(vc_req->sgs); 22 } 23 } 24 25 static void virtcrypto_dataq_callback(struct virtqueue *vq) 26 { 27 struct virtio_crypto *vcrypto = vq->vdev->priv; 28 struct virtio_crypto_request *vc_req; 29 unsigned long flags; 30 unsigned int len; 31 unsigned int qid = vq->index; 32 33 spin_lock_irqsave(&vcrypto->data_vq[qid].lock, flags); 34 do { 35 virtqueue_disable_cb(vq); 36 while ((vc_req = virtqueue_get_buf(vq, &len)) != NULL) { 37 spin_unlock_irqrestore( 38 &vcrypto->data_vq[qid].lock, flags); 39 if (vc_req->alg_cb) 40 vc_req->alg_cb(vc_req, len); 41 spin_lock_irqsave( 42 &vcrypto->data_vq[qid].lock, flags); 43 } 44 } while (!virtqueue_enable_cb(vq)); 45 spin_unlock_irqrestore(&vcrypto->data_vq[qid].lock, flags); 46 } 47 48 static int virtcrypto_find_vqs(struct virtio_crypto *vi) 49 { 50 vq_callback_t **callbacks; 51 struct virtqueue **vqs; 52 int ret = -ENOMEM; 53 int i, total_vqs; 54 const char **names; 55 struct device *dev = &vi->vdev->dev; 56 57 /* 58 * We expect 1 data virtqueue, followed by 59 * possible N-1 data queues used in multiqueue mode, 60 * followed by control vq. 61 */ 62 total_vqs = vi->max_data_queues + 1; 63 64 /* Allocate space for find_vqs parameters */ 65 vqs = kcalloc(total_vqs, sizeof(*vqs), GFP_KERNEL); 66 if (!vqs) 67 goto err_vq; 68 callbacks = kcalloc(total_vqs, sizeof(*callbacks), GFP_KERNEL); 69 if (!callbacks) 70 goto err_callback; 71 names = kcalloc(total_vqs, sizeof(*names), GFP_KERNEL); 72 if (!names) 73 goto err_names; 74 75 /* Parameters for control virtqueue */ 76 callbacks[total_vqs - 1] = NULL; 77 names[total_vqs - 1] = "controlq"; 78 79 /* Allocate/initialize parameters for data virtqueues */ 80 for (i = 0; i < vi->max_data_queues; i++) { 81 callbacks[i] = virtcrypto_dataq_callback; 82 snprintf(vi->data_vq[i].name, sizeof(vi->data_vq[i].name), 83 "dataq.%d", i); 84 names[i] = vi->data_vq[i].name; 85 } 86 87 ret = virtio_find_vqs(vi->vdev, total_vqs, vqs, callbacks, names, NULL); 88 if (ret) 89 goto err_find; 90 91 vi->ctrl_vq = vqs[total_vqs - 1]; 92 93 for (i = 0; i < vi->max_data_queues; i++) { 94 spin_lock_init(&vi->data_vq[i].lock); 95 vi->data_vq[i].vq = vqs[i]; 96 /* Initialize crypto engine */ 97 vi->data_vq[i].engine = crypto_engine_alloc_init(dev, 1); 98 if (!vi->data_vq[i].engine) { 99 ret = -ENOMEM; 100 goto err_engine; 101 } 102 } 103 104 kfree(names); 105 kfree(callbacks); 106 kfree(vqs); 107 108 return 0; 109 110 err_engine: 111 err_find: 112 kfree(names); 113 err_names: 114 kfree(callbacks); 115 err_callback: 116 kfree(vqs); 117 err_vq: 118 return ret; 119 } 120 121 static int virtcrypto_alloc_queues(struct virtio_crypto *vi) 122 { 123 vi->data_vq = kcalloc(vi->max_data_queues, sizeof(*vi->data_vq), 124 GFP_KERNEL); 125 if (!vi->data_vq) 126 return -ENOMEM; 127 128 return 0; 129 } 130 131 static void virtcrypto_clean_affinity(struct virtio_crypto *vi, long hcpu) 132 { 133 int i; 134 135 if (vi->affinity_hint_set) { 136 for (i = 0; i < vi->max_data_queues; i++) 137 virtqueue_set_affinity(vi->data_vq[i].vq, NULL); 138 139 vi->affinity_hint_set = false; 140 } 141 } 142 143 static void virtcrypto_set_affinity(struct virtio_crypto *vcrypto) 144 { 145 int i = 0; 146 int cpu; 147 148 /* 149 * In single queue mode, we don't set the cpu affinity. 150 */ 151 if (vcrypto->curr_queue == 1 || vcrypto->max_data_queues == 1) { 152 virtcrypto_clean_affinity(vcrypto, -1); 153 return; 154 } 155 156 /* 157 * In multiqueue mode, we let the queue to be private to one cpu 158 * by setting the affinity hint to eliminate the contention. 159 * 160 * TODO: adds cpu hotplug support by register cpu notifier. 161 * 162 */ 163 for_each_online_cpu(cpu) { 164 virtqueue_set_affinity(vcrypto->data_vq[i].vq, cpumask_of(cpu)); 165 if (++i >= vcrypto->max_data_queues) 166 break; 167 } 168 169 vcrypto->affinity_hint_set = true; 170 } 171 172 static void virtcrypto_free_queues(struct virtio_crypto *vi) 173 { 174 kfree(vi->data_vq); 175 } 176 177 static int virtcrypto_init_vqs(struct virtio_crypto *vi) 178 { 179 int ret; 180 181 /* Allocate send & receive queues */ 182 ret = virtcrypto_alloc_queues(vi); 183 if (ret) 184 goto err; 185 186 ret = virtcrypto_find_vqs(vi); 187 if (ret) 188 goto err_free; 189 190 cpus_read_lock(); 191 virtcrypto_set_affinity(vi); 192 cpus_read_unlock(); 193 194 return 0; 195 196 err_free: 197 virtcrypto_free_queues(vi); 198 err: 199 return ret; 200 } 201 202 static int virtcrypto_update_status(struct virtio_crypto *vcrypto) 203 { 204 u32 status; 205 int err; 206 207 virtio_cread_le(vcrypto->vdev, 208 struct virtio_crypto_config, status, &status); 209 210 /* 211 * Unknown status bits would be a host error and the driver 212 * should consider the device to be broken. 213 */ 214 if (status & (~VIRTIO_CRYPTO_S_HW_READY)) { 215 dev_warn(&vcrypto->vdev->dev, 216 "Unknown status bits: 0x%x\n", status); 217 218 virtio_break_device(vcrypto->vdev); 219 return -EPERM; 220 } 221 222 if (vcrypto->status == status) 223 return 0; 224 225 vcrypto->status = status; 226 227 if (vcrypto->status & VIRTIO_CRYPTO_S_HW_READY) { 228 err = virtcrypto_dev_start(vcrypto); 229 if (err) { 230 dev_err(&vcrypto->vdev->dev, 231 "Failed to start virtio crypto device.\n"); 232 233 return -EPERM; 234 } 235 dev_info(&vcrypto->vdev->dev, "Accelerator device is ready\n"); 236 } else { 237 virtcrypto_dev_stop(vcrypto); 238 dev_info(&vcrypto->vdev->dev, "Accelerator is not ready\n"); 239 } 240 241 return 0; 242 } 243 244 static int virtcrypto_start_crypto_engines(struct virtio_crypto *vcrypto) 245 { 246 int32_t i; 247 int ret; 248 249 for (i = 0; i < vcrypto->max_data_queues; i++) { 250 if (vcrypto->data_vq[i].engine) { 251 ret = crypto_engine_start(vcrypto->data_vq[i].engine); 252 if (ret) 253 goto err; 254 } 255 } 256 257 return 0; 258 259 err: 260 while (--i >= 0) 261 if (vcrypto->data_vq[i].engine) 262 crypto_engine_exit(vcrypto->data_vq[i].engine); 263 264 return ret; 265 } 266 267 static void virtcrypto_clear_crypto_engines(struct virtio_crypto *vcrypto) 268 { 269 u32 i; 270 271 for (i = 0; i < vcrypto->max_data_queues; i++) 272 if (vcrypto->data_vq[i].engine) 273 crypto_engine_exit(vcrypto->data_vq[i].engine); 274 } 275 276 static void virtcrypto_del_vqs(struct virtio_crypto *vcrypto) 277 { 278 struct virtio_device *vdev = vcrypto->vdev; 279 280 virtcrypto_clean_affinity(vcrypto, -1); 281 282 vdev->config->del_vqs(vdev); 283 284 virtcrypto_free_queues(vcrypto); 285 } 286 287 static int virtcrypto_probe(struct virtio_device *vdev) 288 { 289 int err = -EFAULT; 290 struct virtio_crypto *vcrypto; 291 u32 max_data_queues = 0, max_cipher_key_len = 0; 292 u32 max_auth_key_len = 0; 293 u64 max_size = 0; 294 u32 cipher_algo_l = 0; 295 u32 cipher_algo_h = 0; 296 u32 hash_algo = 0; 297 u32 mac_algo_l = 0; 298 u32 mac_algo_h = 0; 299 u32 aead_algo = 0; 300 u32 crypto_services = 0; 301 302 if (!virtio_has_feature(vdev, VIRTIO_F_VERSION_1)) 303 return -ENODEV; 304 305 if (!vdev->config->get) { 306 dev_err(&vdev->dev, "%s failure: config access disabled\n", 307 __func__); 308 return -EINVAL; 309 } 310 311 if (num_possible_nodes() > 1 && dev_to_node(&vdev->dev) < 0) { 312 /* 313 * If the accelerator is connected to a node with no memory 314 * there is no point in using the accelerator since the remote 315 * memory transaction will be very slow. 316 */ 317 dev_err(&vdev->dev, "Invalid NUMA configuration.\n"); 318 return -EINVAL; 319 } 320 321 vcrypto = kzalloc_node(sizeof(*vcrypto), GFP_KERNEL, 322 dev_to_node(&vdev->dev)); 323 if (!vcrypto) 324 return -ENOMEM; 325 326 virtio_cread_le(vdev, struct virtio_crypto_config, 327 max_dataqueues, &max_data_queues); 328 if (max_data_queues < 1) 329 max_data_queues = 1; 330 331 virtio_cread_le(vdev, struct virtio_crypto_config, 332 max_cipher_key_len, &max_cipher_key_len); 333 virtio_cread_le(vdev, struct virtio_crypto_config, 334 max_auth_key_len, &max_auth_key_len); 335 virtio_cread_le(vdev, struct virtio_crypto_config, 336 max_size, &max_size); 337 virtio_cread_le(vdev, struct virtio_crypto_config, 338 crypto_services, &crypto_services); 339 virtio_cread_le(vdev, struct virtio_crypto_config, 340 cipher_algo_l, &cipher_algo_l); 341 virtio_cread_le(vdev, struct virtio_crypto_config, 342 cipher_algo_h, &cipher_algo_h); 343 virtio_cread_le(vdev, struct virtio_crypto_config, 344 hash_algo, &hash_algo); 345 virtio_cread_le(vdev, struct virtio_crypto_config, 346 mac_algo_l, &mac_algo_l); 347 virtio_cread_le(vdev, struct virtio_crypto_config, 348 mac_algo_h, &mac_algo_h); 349 virtio_cread_le(vdev, struct virtio_crypto_config, 350 aead_algo, &aead_algo); 351 352 /* Add virtio crypto device to global table */ 353 err = virtcrypto_devmgr_add_dev(vcrypto); 354 if (err) { 355 dev_err(&vdev->dev, "Failed to add new virtio crypto device.\n"); 356 goto free; 357 } 358 vcrypto->owner = THIS_MODULE; 359 vcrypto = vdev->priv = vcrypto; 360 vcrypto->vdev = vdev; 361 362 spin_lock_init(&vcrypto->ctrl_lock); 363 364 /* Use single data queue as default */ 365 vcrypto->curr_queue = 1; 366 vcrypto->max_data_queues = max_data_queues; 367 vcrypto->max_cipher_key_len = max_cipher_key_len; 368 vcrypto->max_auth_key_len = max_auth_key_len; 369 vcrypto->max_size = max_size; 370 vcrypto->crypto_services = crypto_services; 371 vcrypto->cipher_algo_l = cipher_algo_l; 372 vcrypto->cipher_algo_h = cipher_algo_h; 373 vcrypto->mac_algo_l = mac_algo_l; 374 vcrypto->mac_algo_h = mac_algo_h; 375 vcrypto->hash_algo = hash_algo; 376 vcrypto->aead_algo = aead_algo; 377 378 379 dev_info(&vdev->dev, 380 "max_queues: %u, max_cipher_key_len: %u, max_auth_key_len: %u, max_size 0x%llx\n", 381 vcrypto->max_data_queues, 382 vcrypto->max_cipher_key_len, 383 vcrypto->max_auth_key_len, 384 vcrypto->max_size); 385 386 err = virtcrypto_init_vqs(vcrypto); 387 if (err) { 388 dev_err(&vdev->dev, "Failed to initialize vqs.\n"); 389 goto free_dev; 390 } 391 392 err = virtcrypto_start_crypto_engines(vcrypto); 393 if (err) 394 goto free_vqs; 395 396 virtio_device_ready(vdev); 397 398 err = virtcrypto_update_status(vcrypto); 399 if (err) 400 goto free_engines; 401 402 return 0; 403 404 free_engines: 405 virtcrypto_clear_crypto_engines(vcrypto); 406 free_vqs: 407 virtio_reset_device(vdev); 408 virtcrypto_del_vqs(vcrypto); 409 free_dev: 410 virtcrypto_devmgr_rm_dev(vcrypto); 411 free: 412 kfree(vcrypto); 413 return err; 414 } 415 416 static void virtcrypto_free_unused_reqs(struct virtio_crypto *vcrypto) 417 { 418 struct virtio_crypto_request *vc_req; 419 int i; 420 struct virtqueue *vq; 421 422 for (i = 0; i < vcrypto->max_data_queues; i++) { 423 vq = vcrypto->data_vq[i].vq; 424 while ((vc_req = virtqueue_detach_unused_buf(vq)) != NULL) { 425 kfree(vc_req->req_data); 426 kfree(vc_req->sgs); 427 } 428 } 429 } 430 431 static void virtcrypto_remove(struct virtio_device *vdev) 432 { 433 struct virtio_crypto *vcrypto = vdev->priv; 434 435 dev_info(&vdev->dev, "Start virtcrypto_remove.\n"); 436 437 if (virtcrypto_dev_started(vcrypto)) 438 virtcrypto_dev_stop(vcrypto); 439 virtio_reset_device(vdev); 440 virtcrypto_free_unused_reqs(vcrypto); 441 virtcrypto_clear_crypto_engines(vcrypto); 442 virtcrypto_del_vqs(vcrypto); 443 virtcrypto_devmgr_rm_dev(vcrypto); 444 kfree(vcrypto); 445 } 446 447 static void virtcrypto_config_changed(struct virtio_device *vdev) 448 { 449 struct virtio_crypto *vcrypto = vdev->priv; 450 451 virtcrypto_update_status(vcrypto); 452 } 453 454 #ifdef CONFIG_PM_SLEEP 455 static int virtcrypto_freeze(struct virtio_device *vdev) 456 { 457 struct virtio_crypto *vcrypto = vdev->priv; 458 459 virtio_reset_device(vdev); 460 virtcrypto_free_unused_reqs(vcrypto); 461 if (virtcrypto_dev_started(vcrypto)) 462 virtcrypto_dev_stop(vcrypto); 463 464 virtcrypto_clear_crypto_engines(vcrypto); 465 virtcrypto_del_vqs(vcrypto); 466 return 0; 467 } 468 469 static int virtcrypto_restore(struct virtio_device *vdev) 470 { 471 struct virtio_crypto *vcrypto = vdev->priv; 472 int err; 473 474 err = virtcrypto_init_vqs(vcrypto); 475 if (err) 476 return err; 477 478 err = virtcrypto_start_crypto_engines(vcrypto); 479 if (err) 480 goto free_vqs; 481 482 virtio_device_ready(vdev); 483 484 err = virtcrypto_dev_start(vcrypto); 485 if (err) { 486 dev_err(&vdev->dev, "Failed to start virtio crypto device.\n"); 487 goto free_engines; 488 } 489 490 return 0; 491 492 free_engines: 493 virtcrypto_clear_crypto_engines(vcrypto); 494 free_vqs: 495 virtio_reset_device(vdev); 496 virtcrypto_del_vqs(vcrypto); 497 return err; 498 } 499 #endif 500 501 static const unsigned int features[] = { 502 /* none */ 503 }; 504 505 static const struct virtio_device_id id_table[] = { 506 { VIRTIO_ID_CRYPTO, VIRTIO_DEV_ANY_ID }, 507 { 0 }, 508 }; 509 510 static struct virtio_driver virtio_crypto_driver = { 511 .driver.name = KBUILD_MODNAME, 512 .driver.owner = THIS_MODULE, 513 .feature_table = features, 514 .feature_table_size = ARRAY_SIZE(features), 515 .id_table = id_table, 516 .probe = virtcrypto_probe, 517 .remove = virtcrypto_remove, 518 .config_changed = virtcrypto_config_changed, 519 #ifdef CONFIG_PM_SLEEP 520 .freeze = virtcrypto_freeze, 521 .restore = virtcrypto_restore, 522 #endif 523 }; 524 525 module_virtio_driver(virtio_crypto_driver); 526 527 MODULE_DEVICE_TABLE(virtio, id_table); 528 MODULE_DESCRIPTION("virtio crypto device driver"); 529 MODULE_LICENSE("GPL"); 530 MODULE_AUTHOR("Gonglei <arei.gonglei@huawei.com>"); 531