18d818c10SHoria Geantăconfig CRYPTO_DEV_FSL_CAAM_COMMON 28d818c10SHoria Geantă tristate 38d818c10SHoria Geantă 48e8ec596SKim Phillipsconfig CRYPTO_DEV_FSL_CAAM 58d818c10SHoria Geantă tristate "Freescale CAAM-Multicore platform driver backend" 69e217795SHoria Geantă depends on FSL_SOC || ARCH_MXC || ARCH_LAYERSCAPE 7c056d910SHoria Geantă select SOC_BUS 88d818c10SHoria Geantă select CRYPTO_DEV_FSL_CAAM_COMMON 98e8ec596SKim Phillips help 108e8ec596SKim Phillips Enables the driver module for Freescale's Cryptographic Accelerator 118e8ec596SKim Phillips and Assurance Module (CAAM), also known as the SEC version 4 (SEC4). 12313ea293SRuchika Gupta This module creates job ring devices, and configures h/w 138e8ec596SKim Phillips to operate as a DPAA component automatically, depending 148e8ec596SKim Phillips on h/w feature availability. 158e8ec596SKim Phillips 168e8ec596SKim Phillips To compile this driver as a module, choose M here: the module 178e8ec596SKim Phillips will be called caam. 188e8ec596SKim Phillips 198d818c10SHoria Geantăif CRYPTO_DEV_FSL_CAAM 208d818c10SHoria Geantă 218d818c10SHoria Geantăconfig CRYPTO_DEV_FSL_CAAM_DEBUG 228d818c10SHoria Geantă bool "Enable debug output in CAAM driver" 238d818c10SHoria Geantă help 248d818c10SHoria Geantă Selecting this will enable printing of various debug 258d818c10SHoria Geantă information in the CAAM driver. 268d818c10SHoria Geantă 27313ea293SRuchika Guptaconfig CRYPTO_DEV_FSL_CAAM_JR 28313ea293SRuchika Gupta tristate "Freescale CAAM Job Ring driver backend" 29313ea293SRuchika Gupta default y 30313ea293SRuchika Gupta help 31313ea293SRuchika Gupta Enables the driver module for Job Rings which are part of 32313ea293SRuchika Gupta Freescale's Cryptographic Accelerator 33313ea293SRuchika Gupta and Assurance Module (CAAM). This module adds a job ring operation 34313ea293SRuchika Gupta interface. 35313ea293SRuchika Gupta 36313ea293SRuchika Gupta To compile this driver as a module, choose M here: the module 37313ea293SRuchika Gupta will be called caam_jr. 38313ea293SRuchika Gupta 398d818c10SHoria Geantăif CRYPTO_DEV_FSL_CAAM_JR 408d818c10SHoria Geantă 418e8ec596SKim Phillipsconfig CRYPTO_DEV_FSL_CAAM_RINGSIZE 428e8ec596SKim Phillips int "Job Ring size" 438e8ec596SKim Phillips range 2 9 448e8ec596SKim Phillips default "9" 458e8ec596SKim Phillips help 468e8ec596SKim Phillips Select size of Job Rings as a power of 2, within the 478e8ec596SKim Phillips range 2-9 (ring size 4-512). 488e8ec596SKim Phillips Examples: 498e8ec596SKim Phillips 2 => 4 508e8ec596SKim Phillips 3 => 8 518e8ec596SKim Phillips 4 => 16 528e8ec596SKim Phillips 5 => 32 538e8ec596SKim Phillips 6 => 64 548e8ec596SKim Phillips 7 => 128 558e8ec596SKim Phillips 8 => 256 568e8ec596SKim Phillips 9 => 512 578e8ec596SKim Phillips 588e8ec596SKim Phillipsconfig CRYPTO_DEV_FSL_CAAM_INTC 598e8ec596SKim Phillips bool "Job Ring interrupt coalescing" 608e8ec596SKim Phillips help 618e8ec596SKim Phillips Enable the Job Ring's interrupt coalescing feature. 628e8ec596SKim Phillips 631a076689SKim Phillips Note: the driver already provides adequate 641a076689SKim Phillips interrupt coalescing in software. 651a076689SKim Phillips 668e8ec596SKim Phillipsconfig CRYPTO_DEV_FSL_CAAM_INTC_COUNT_THLD 678e8ec596SKim Phillips int "Job Ring interrupt coalescing count threshold" 688e8ec596SKim Phillips depends on CRYPTO_DEV_FSL_CAAM_INTC 698e8ec596SKim Phillips range 1 255 708e8ec596SKim Phillips default 255 718e8ec596SKim Phillips help 728e8ec596SKim Phillips Select number of descriptor completions to queue before 738e8ec596SKim Phillips raising an interrupt, in the range 1-255. Note that a selection 748e8ec596SKim Phillips of 1 functionally defeats the coalescing feature, and a selection 758e8ec596SKim Phillips equal or greater than the job ring size will force timeouts. 768e8ec596SKim Phillips 778e8ec596SKim Phillipsconfig CRYPTO_DEV_FSL_CAAM_INTC_TIME_THLD 788e8ec596SKim Phillips int "Job Ring interrupt coalescing timer threshold" 798e8ec596SKim Phillips depends on CRYPTO_DEV_FSL_CAAM_INTC 808e8ec596SKim Phillips range 1 65535 818e8ec596SKim Phillips default 2048 828e8ec596SKim Phillips help 838e8ec596SKim Phillips Select number of bus clocks/64 to timeout in the case that one or 848e8ec596SKim Phillips more descriptor completions are queued without reaching the count 858e8ec596SKim Phillips threshold. Range is 1-65535. 868e8ec596SKim Phillips 878e8ec596SKim Phillipsconfig CRYPTO_DEV_FSL_CAAM_CRYPTO_API 888e8ec596SKim Phillips tristate "Register algorithm implementations with the Crypto API" 898e8ec596SKim Phillips default y 90596103cfSHerbert Xu select CRYPTO_AEAD 918e8ec596SKim Phillips select CRYPTO_AUTHENC 92596103cfSHerbert Xu select CRYPTO_BLKCIPHER 938e8ec596SKim Phillips help 948e8ec596SKim Phillips Selecting this will offload crypto for users of the 958e8ec596SKim Phillips scatterlist crypto API (such as the linux native IPSec 968e8ec596SKim Phillips stack) to the SEC4 via job ring. 978e8ec596SKim Phillips 988e8ec596SKim Phillips To compile this as a module, choose M here: the module 998e8ec596SKim Phillips will be called caamalg. 100045e3678SYuan Kang 101b189817cSHoria Geantăconfig CRYPTO_DEV_FSL_CAAM_CRYPTO_API_QI 102b189817cSHoria Geantă tristate "Queue Interface as Crypto API backend" 1038d818c10SHoria Geantă depends on FSL_DPAA && NET 104b189817cSHoria Geantă default y 105b189817cSHoria Geantă select CRYPTO_AUTHENC 106b189817cSHoria Geantă select CRYPTO_BLKCIPHER 107b189817cSHoria Geantă help 108b189817cSHoria Geantă Selecting this will use CAAM Queue Interface (QI) for sending 109b189817cSHoria Geantă & receiving crypto jobs to/from CAAM. This gives better performance 110b189817cSHoria Geantă than job ring interface when the number of cores are more than the 111b189817cSHoria Geantă number of job rings assigned to the kernel. The number of portals 112b189817cSHoria Geantă assigned to the kernel should also be more than the number of 113b189817cSHoria Geantă job rings. 114b189817cSHoria Geantă 115b189817cSHoria Geantă To compile this as a module, choose M here: the module 116b189817cSHoria Geantă will be called caamalg_qi. 117b189817cSHoria Geantă 118045e3678SYuan Kangconfig CRYPTO_DEV_FSL_CAAM_AHASH_API 119045e3678SYuan Kang tristate "Register hash algorithm implementations with Crypto API" 120045e3678SYuan Kang default y 121ae8488a5SPaul Bolle select CRYPTO_HASH 122045e3678SYuan Kang help 123045e3678SYuan Kang Selecting this will offload ahash for users of the 124045e3678SYuan Kang scatterlist crypto API to the SEC4 via job ring. 125045e3678SYuan Kang 126045e3678SYuan Kang To compile this as a module, choose M here: the module 127045e3678SYuan Kang will be called caamhash. 128e24f7c9eSYuan Kang 1298c419778STudor Ambarusconfig CRYPTO_DEV_FSL_CAAM_PKC_API 1308c419778STudor Ambarus tristate "Register public key cryptography implementations with Crypto API" 1318c419778STudor Ambarus default y 1328c419778STudor Ambarus select CRYPTO_RSA 1338c419778STudor Ambarus help 1348c419778STudor Ambarus Selecting this will allow SEC Public key support for RSA. 1358c419778STudor Ambarus Supported cryptographic primitives: encryption, decryption, 1368c419778STudor Ambarus signature and verification. 1378c419778STudor Ambarus To compile this as a module, choose M here: the module 1388c419778STudor Ambarus will be called caam_pkc. 1398c419778STudor Ambarus 140e24f7c9eSYuan Kangconfig CRYPTO_DEV_FSL_CAAM_RNG_API 141e24f7c9eSYuan Kang tristate "Register caam device for hwrng API" 142e24f7c9eSYuan Kang default y 143e24f7c9eSYuan Kang select CRYPTO_RNG 144e24f7c9eSYuan Kang select HW_RANDOM 145e24f7c9eSYuan Kang help 146e24f7c9eSYuan Kang Selecting this will register the SEC4 hardware rng to 147e24f7c9eSYuan Kang the hw_random API for suppying the kernel entropy pool. 148e24f7c9eSYuan Kang 149e24f7c9eSYuan Kang To compile this as a module, choose M here: the module 150e24f7c9eSYuan Kang will be called caamrng. 151d4d8edf8SAlex Porosanu 1528d818c10SHoria Geantăendif # CRYPTO_DEV_FSL_CAAM_JR 1538d818c10SHoria Geantă 1548d818c10SHoria Geantăendif # CRYPTO_DEV_FSL_CAAM 1558d818c10SHoria Geantă 1568d818c10SHoria Geantăconfig CRYPTO_DEV_FSL_DPAA2_CAAM 1578d818c10SHoria Geantă tristate "QorIQ DPAA2 CAAM (DPSECI) driver" 1588d818c10SHoria Geantă depends on FSL_MC_DPIO 1598d818c10SHoria Geantă select CRYPTO_DEV_FSL_CAAM_COMMON 160*226853acSHoria Geantă select CRYPTO_BLKCIPHER 1618d818c10SHoria Geantă select CRYPTO_AUTHENC 1628d818c10SHoria Geantă select CRYPTO_AEAD 163d4d8edf8SAlex Porosanu help 1648d818c10SHoria Geantă CAAM driver for QorIQ Data Path Acceleration Architecture 2. 1658d818c10SHoria Geantă It handles DPSECI DPAA2 objects that sit on the Management Complex 1668d818c10SHoria Geantă (MC) fsl-mc bus. 1678d818c10SHoria Geantă 1688d818c10SHoria Geantă To compile this as a module, choose M here: the module 1698d818c10SHoria Geantă will be called dpaa2_caam. 1708cea7b66SHoria Geantă 1718cea7b66SHoria Geantăconfig CRYPTO_DEV_FSL_CAAM_CRYPTO_API_DESC 172b189817cSHoria Geantă def_tristate (CRYPTO_DEV_FSL_CAAM_CRYPTO_API || \ 1738d818c10SHoria Geantă CRYPTO_DEV_FSL_CAAM_CRYPTO_API_QI || \ 1748d818c10SHoria Geantă CRYPTO_DEV_FSL_DPAA2_CAAM) 175