On Mon, Jan 27, 2020 at 8:24 PM Anoob Joseph <ano...@marvell.com> wrote:
>
> Hi Jerin, Akhil,
>
> Let me summarize the design changes from the discussions below.
>
> Currently, drivers/crypto/octeontx2/otx2_security.c defines all security ctx 
> ops for the ethdev (idea was to add all crypto security ctx for lookaside 
> also there). That will be moved to drivers/net/octeontx2 as is. The routines 
> which are doing qp_add & qp_remove would be moved to common (discussed 
> below). Otherwise, the rest should remain as is. If Jerin/Akhil wants further 
> isolation, please do share specifics. Almost all functions in otx2_security.c 
> is dereferencing 'rte_eth_dev'. So having (void *) will not help.
>
> The functions in otx2_security.c is calling inline functions in 
> otx2_ipsec_fp.h (which has lower level implementations of session create 
> etc). This will remain as is in drivers/crypto/octeontx2 but would be called 
> from drivers/net/octeontx2/otx2_security.c.
>
> We will need to include otx2_cryptodev_qp.h (internal header in 
> drivers/crypto/octeontx2) since the crypto queue pair is required for 
> outbound processing. Since otx2_cryptodev_qp.h has dependency on 
> rte_cryptodev.h, the ethdev file will have dependency on rte_cryptodev.h.
>
> I want all the maintainers (Akhil, Jerin & Ferruh) to ack the above behavior 
> so that I can proceed with the restructuring. (Currently issue is 
> rte_ethdev.h getting included in a cryptodev PMD file. The case we are 
> proposing is the exact mirror of that)

I think, Following rework would be required.

1) Don't access rte_eth_dev symbols in driver/crypto/octeontx2
2) Don't access rte_crypto_dev symbols in drier/net/octeontx2
3) Communication between both drivers should both through "custom
structure"(say struct otx2_eth_sec or so for inline, otx2_crypto_sec
for look side)
defined in driver/common/octeonxt2 which holds data.
Processing function through "function pointer" registration provided
through in driver/common/octeonx2 as idev framework to avoid build
dependency.

I am not sure anything else can be done beyond the above.

Reply via email to