http://uos-embedded.googlecode.com/svn/trunk/sources/runtime/memset-fast.c
/*
FUNCTION
<<memset>>---set an area of memory
INDEX
memset
ANSI_SYNOPSIS
#include <string.h>
void *memset(const void *<[dst]>, int <[c]>, size_t <[length]>);
TRAD_SYNOPSIS
#include <string.h>
void *memset(<[dst]>, <[c]>, <[length]>)
void *<[dst]>;
int <[c]>;
size_t <[length]>;
DESCRIPTION
This function converts the argument <[c]> into an unsigned
char and fills the first <[length]> characters of the array
pointed to by <[dst]> to the value.
RETURNS
<<memset>> returns the value of <[m]>.
PORTABILITY
<<memset>> is ANSI C.
<<memset>> requires no supporting OS subroutines.
QUICKREF
memset ansi pure
*/
#include <runtime/lib.h>
#undef memset
#define LBLOCKSIZE (sizeof(long))
#define UNALIGNED(X) ((long)X & (LBLOCKSIZE - 1))
#define TOO_SMALL(LEN) ((LEN) < LBLOCKSIZE)
void *
memset(void *m, unsigned char c, size_t n)
{
unsigned char *s;
unsigned long buffer;
if (n == 0)
return m;
s = (unsigned char*) m;
while (UNALIGNED (s))
{
*s++ = c;
if (--n == 0)
return m;
}
if (! TOO_SMALL (n))
{
/* If we get this far, we know that n is large and s is word-aligned. */
/* Store D into each char sized location in BUFFER so that
we can set large blocks quickly. */
buffer = c;
buffer |= (buffer << 8);
buffer |= (buffer << 16);
if (LBLOCKSIZE > 4)
buffer |= (buffer << 16) << 16;
while (n >= LBLOCKSIZE*4)
{
*((unsigned long*) s) = buffer; s += LBLOCKSIZE;
*((unsigned long*) s) = buffer; s += LBLOCKSIZE;
*((unsigned long*) s) = buffer; s += LBLOCKSIZE;
*((unsigned long*) s) = buffer; s += LBLOCKSIZE;
n -= 4*LBLOCKSIZE;
}
while (n >= LBLOCKSIZE)
{
*((unsigned long*) s) = buffer; s += LBLOCKSIZE;
n -= LBLOCKSIZE;
}
}
/* Pick up the remainder with a bytewise loop. */
while (n--)
{
*s++ = c;
}
return m;
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.