[发明专利]渲染三维图形的方法及装置有效
申请号: | 201610930629.5 | 申请日: | 2016-10-31 |
公开(公告)号: | CN108022281B | 公开(公告)日: | 2021-02-23 |
发明(设计)人: | 高翔;朱琛;王洪虎 | 申请(专利权)人: | 龙芯中科技术股份有限公司 |
主分类号: | G06T15/00 | 分类号: | G06T15/00;G06F9/30;G06F9/38 |
代理公司: | 北京兰亭信通知识产权代理有限公司 11667 | 代理人: | 赵永刚 |
地址: | 100095 北京市海淀*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 渲染 三维 图形 方法 装置 | ||
1.一种渲染三维图形的方法,其特征在于,应用于中央处理器CPU,所述CPU包括单指令流多数据流SIMD向量运算单元、与所述SIMD向量运算单元对应的专用取指模块、专用译码模块和专用访存模块,所述方法包括:
在运行包含三维渲染任务的进程之前,将CPU中的SIMD向量运算单元对CPU进行屏蔽,以使CPU不会调用所述SIMD向量运算单元;
根据所述三维渲染任务构建当前帧的向量指令和向量数据,并将所述向量指令和向量数据存储在内存的指定区域;
使能所述专用取指模块、所述专用访存模块,以使得所述SIMD向量运算单元、所述专用取指模块、所述专用译码模块和所述专用访存模块,根据所述内存的指定区域中的向量指令和向量数据执行相应的SIMD向量运算,完成当前帧的三维渲染任务。
2.根据权利要求1所述的方法,其特征在于,所述以使得所述SIMD向量运算单元、所述专用取指模块、所述专用译码模块和所述专用访存模块,根据所述内存的指定区域中的向量指令和向量数据执行相应的SIMD向量运算包括:
所述专用取指模块从所述内存的指定区域读取所述向量指令;
所述专用译码模块对所述向量指令进行译码,并将译码后的向量指令发送至所述SIMD向量运算单元;
所述专用访存模块从所述内存的指定区域读取所述向量数据,并发送给所述SIMD向量运算单元;
所述SIMD向量运算单元根据所述译码后的向量指令以及所述向量数据进行SIMD向量运算,并将SIMD向量运算结果返回至所述专用访存模块。
3.根据权利要求1或2所述的方法,其特征在于,在所述使能所述专用取指模块、所述专用访存模块之后,还包括:
在内存的指定区域接收所述专用访存模块写回的所述SIMD向量运算结果。
4.根据权利要求1或2所述的方法,其特征在于,所述方法还包括:
在完成当前帧的三维渲染任务过程中,控制所述包含三维渲染任务的进程执行除当前帧的三维渲染任务以外的其他任务,或者将所述包含三维渲染任务的进程挂起。
5.根据权利要求3所述的方法,其特征在于,在所述在内存的指定区域接收所述专用访存模块写回的所述SIMD向量运算结果之后,所述方法还包括:
恢复所述包含三维渲染任务的进程,从所述内存的指定区域读取所述SIMD向量运算结果。
6.根据权利要求1或2所述的方法,其特征在于,所述使能所述专用取指模块、所述专用访存模块包括:
在所述专用取指模块对应的配置寄存器中存入待取指地址的首地址以及长度;
在所述专用访存模块对应的配置寄存器中存入待读取向量数据的首地址以及长度,待存入向量数据的首地址以及长度;
通过专用配置寄存器中设置的使能位对所述专用取指模块、所述专用访存模块进行使能。
7.一种渲染三维图形的装置,其特征在于,所述装置位于CPU,所述CPU包括SIMD向量运算单元、与所述SIMD向量运算单元对应的专用取指模块、专用译码模块和专用访存模块,所述装置包括:
屏蔽控制模块,用于在运行包含三维渲染任务的进程之前,将CPU中的SIMD向量运算单元对CPU进行屏蔽,以使CPU不会调用所述SIMD向量运算单元;
构建模块,用于根据所述三维渲染任务构建当前帧的向量指令和向量数据,并将所述向量指令和向量数据存储在内存的指定区域;
使能模块,用于使能所述专用取指模块、所述专用访存模块,以使得所述SIMD向量运算单元、所述专用取指模块、所述专用译码模块和所述专用访存模块,根据所述内存的指定区域中的向量指令和向量数据执行相应的SIMD向量运算,完成当前帧的三维渲染任务。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于龙芯中科技术股份有限公司,未经龙芯中科技术股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201610930629.5/1.html,转载请声明来源钻瓜专利网。
- 上一篇:一种便于连接的清洗杆体
- 下一篇:一种通风窗及控制方法