]> git.sesse.net Git - casparcg/blob - common/memory/memclr.h
git-svn-id: https://casparcg.svn.sourceforge.net/svnroot/casparcg/server/branches...
[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         return memset(dest, 0, count);\r
33         //if(count < 2048)\r
34         //      return memset(dest, 0, count);\r
35 \r
36         //assert(dest != nullptr);\r
37         //\r
38         //size_t rest = count % 128;\r
39         //count -= rest;\r
40 \r
41         //__asm   \r
42         //{              \r
43         //      mov edi, dest;    \r
44         //      mov ebx, count;     \r
45         //      shr ebx, 7;\r
46         //      pxor xmm0, xmm0; \r
47 \r
48         //      clr:             \r
49         //              movntdq [edi+00h], xmm0;\r
50         //              movntdq [edi+10h], xmm0;\r
51         //              movntdq [edi+20h], xmm0;    \r
52         //              movntdq [edi+30h], xmm0;\r
53         //              \r
54         //              movntdq [edi+40h], xmm0; \r
55         //              movntdq [edi+50h], xmm0;      \r
56         //              movntdq [edi+60h], xmm0;    \r
57         //              movntdq [edi+70h], xmm0;    \r
58 \r
59         //              lea edi, [edi+80h];         \r
60 \r
61         //              dec ebx;      \r
62         //      jnz clr;  \r
63         //}   \r
64         //return memset(reinterpret_cast<char*>(dest)+count, 0, rest);\r
65 }\r
66 \r
67 }