]> git.sesse.net Git - casparcg/blob - common/memory/memclr.h
Subtree merge of old SVN "dependencies" folder into the "master" git branch. You...
[casparcg] / common / memory / memclr.h
1 /*\r
2 * Copyright (c) 2011 Sveriges Television AB <info@casparcg.com>\r
3 *\r
4 * This file is part of CasparCG (www.casparcg.com).\r
5 *\r
6 * CasparCG is free software: you can redistribute it and/or modify\r
7 * it under the terms of the GNU General Public License as published by\r
8 * the Free Software Foundation, either version 3 of the License, or\r
9 * (at your option) any later version.\r
10 *\r
11 * CasparCG is distributed in the hope that it will be useful,\r
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of\r
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
14 * GNU General Public License for more details.\r
15 *\r
16 * You should have received a copy of the GNU General Public License\r
17 * along with CasparCG. If not, see <http://www.gnu.org/licenses/>.\r
18 *\r
19 * Author: Robert Nagy, ronag89@gmail.com\r
20 */\r
21 \r
22 #pragma once\r
23 \r
24 #include <assert.h>\r
25 \r
26 #include <cstring>\r
27 \r
28 namespace caspar {\r
29 \r
30 static void* fast_memclr(void* dest, size_t count)\r
31 {\r
32         if(count < 2048)\r
33                 return memset(dest, 0, count);\r
34 \r
35         assert(dest != nullptr);\r
36         \r
37         size_t rest = count % 128;\r
38         count -= rest;\r
39 \r
40         __asm   \r
41         {              \r
42                 mov edi, dest;    \r
43                 mov ebx, count;     \r
44                 shr ebx, 7;\r
45                 pxor xmm0, xmm0; \r
46 \r
47                 clr:             \r
48                         movntdq [edi+00h], xmm0;\r
49                         movntdq [edi+10h], xmm0;\r
50                         movntdq [edi+20h], xmm0;    \r
51                         movntdq [edi+30h], xmm0;\r
52                         \r
53                         movntdq [edi+40h], xmm0; \r
54                         movntdq [edi+50h], xmm0;      \r
55                         movntdq [edi+60h], xmm0;    \r
56                         movntdq [edi+70h], xmm0;    \r
57 \r
58                         lea edi, [edi+80h];         \r
59 \r
60                         dec ebx;      \r
61                 jnz clr;  \r
62         }   \r
63         return memset(reinterpret_cast<char*>(dest)+count, 0, rest);\r
64 }\r
65 \r
66 }