将位图加载到 GPU 的内存很慢? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
BUappend
V2EX    前端开发

将位图加载到 GPU 的内存很慢?

  •  
  •   BUappend 2020-11-25 02:09:00 +08:00 2415 次点击
    这是一个创建于 1849 天前的主题,其中的信息可能已经有所发展或是发生改变。

    将位图加载到 GPU 的内存很慢?为啥?

  • GPU
  • 将位图
  • 位图
  • 内存
    8 条回复    2020-11-25 18:28:13 +08:00
    MCVector
        1
    MCVector  
       2020-11-25 06:05:53 +08:00 via Android
    需要更多信息。用的是什么 API ?是上传到显存的阶段慢还是磁盘的 io 慢?
    northisland
        2
    northisland  
       2020-11-25 08:17:21 +08:00 via Android
    老哥,给的信息太少了吧,用的是 cudamemcpy api,还是 clEnqueueRead,还是其他乱七八糟的 api,gpu3 种内存都可以放图片。。。

    交换数据瓶颈是总线,gpu 用的是 pcie 总线,可以算一下。
    happinessnch
        3
    happinessnch  
       2020-11-25 09:30:22 +08:00
    我印象里从内存拷贝到 GPU 缓存过程是一处性能瓶颈( 13 年左右得到的结论),
    所以 AMD 才弄了个 APU 共享 GPU 和 CPU 存储空间。

    位图为啥慢?所谓快慢至少要有一个比较对象吧,你要比较的对象是什么?是方法、还是不同格式?
    BUappend
        4
    BUappend  
    OP
       2020-11-25 10:34:23 +08:00
    @MCVector @happinessnch @northisland 我在看前端的动画优化的时候看到了这句话,对于动画来说,每次的重排都会生成新的位图,然后说 “ 将位图加载到 GPU 的内存是很慢的操作 ” ,所以尽量减少动画的重排。
    bojue
        5
    bojue  
       2020-11-25 15:23:03 +08:00
    css 性能优化为了减少重绘和重排,可以使用 transfrom 或者 opacity 合成层属性实现动画,这样整个 css 绘制流程只涉及到 composite 。

    Composited Layer 都需要 CPU 处理位图,需要考虑 CPU 的带宽问题和内存的管理,所以需要避免过度使用 Composited Layer 。
    BUappend
        6
    BUappend  
    OP
       2020-11-25 17:31:29 +08:00
    @bojue CPU 的带宽问题和内存的管理,能详细说说吗
    bojue
        7
    bojue  
       2020-11-25 18:26:20 +08:00
    @bojue 细节记不住了,不过可以查一下,随手找到一篇 https://zhuanlan.zhihu.com/p/39880024
    bojue
        8
    bojue  
       2020-11-25 18:28:13 +08:00
    @BUappend 链接还发错了你看一下我回复的,大概意思就是减少绘制区域,尽可能的减少对内存的消耗
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     5015 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 44ms UTC 05:45 PVG 13:45 LAX 21:45 JFK 00:45
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86