Piranha有三层结构:设备层,协议层,应用层。下文将对三层的功能做具体介绍。
设备层
设备层通过提供当前通用GPU库缺失的基于整数的内核可以进行独立的加速密钥共享协议。
设备层有三个模块分别是:数据管理(data managemnet),基于迭代器的操作以及整数内核。
数据管理
文章提出了一个:DeviceData buffer的概念。为什么要有DeviceData buffer?将数据存放在GPU上而不是CPU上可以避免GPU内核计算时的数据传输开销。
如何提高协议性能?对秘密共享值的集合进行逐元素操作是一种常见的操作。由于这些操作常常涉及大量的计算,因此将它们并行化加速,利用 GPU(图形处理单元)的性能,可以自然而然地提高协议性能。独立于特定协议,秘密共享数据上的MPC功能分解为一组通用的局部算术运算,这样就可以适配大部分的MPC协议。
基于迭代器的操作
由于GPU的空间有限,所以需要提高存储效率。Piranha的迭代器允许开发者通过程序定义的顺序遍历数据向量,同时在一个与实际物理数据布局无关的视图上执行操作。可以在原地进行逐元素操作,并将计算结果存储在现有内存中从而节省内存。
整数内核
MPC协议需要32位或64位类型的数据类型进行加密共享。目前研究仅仅针对于浮点数据类型,所以作者提出了自己的解决方法:直接在整数数据类型上面实现内核。Piranha直接在设备层提供了所有大小的整数矩阵乘法和卷积内核(CUTLASS)。
协议层
Piranha实现任何一个协议需要指定两件事:1.密钥共享基础(包括攻击模型)。2.在此之上的操作。
下图展示了一个简单的三方协商的实现。
高效存储的开发
上文提到了高效存储的开发:普通的加法进位器需要分别存储共享密钥的每一位增加了内存占用。
其次使用连续的分配去隔离成对的位会导致额外的内存使用和数据复制。下图(a)展示了标准的加法进位器的内存使用情况。
相反在(b)中Piranha使用了基于迭代器的视图按照一定的步幅访问非连续的数据元素,并将结果存储在相同位置,提高了内存的使用效率。
可重用协议组件
Piranha的结构支持重用协议实现,因此协议可以构建在其它应用上。作者实现了几种可重复使用的模型包括:安全比较, 近似计算等
MPC协议
文章实现了三个不同的MPC协议以便展示Piranha的通用性包括:P-SecureML,P-Falcon,P-FantasticFour。
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数网络安全工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年网络安全全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上网络安全知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加VX:vip204888 (备注网络安全获取)
给大家的福利
零基础入门
对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。
同时每个成长路线对应的板块都有配套的视频提供:
因篇幅有限,仅展示部分资料
网络安全面试题
绿盟护网行动
还有大家最喜欢的黑客技术
网络安全源码合集+工具包
所有资料共282G,朋友们如果有需要全套《网络安全入门+黑客进阶学习资源包》,可以扫描下方二维码领取(如遇扫码问题,可以在评论区留言领取哦)~
一个人可以走的很快,但一群人才能走的更远。如果你从事以下工作或对以下感兴趣,欢迎戳这里加入程序员的圈子,让我们一起学习成长!
AI人工智能、Android移动开发、AIGC大模型、C C#、Go语言、Java、Linux运维、云计算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算
ython爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算**