10d163575Sopenharmony_ci/*
20d163575Sopenharmony_ci * Copyright (c) 2021-2021 Huawei Device Co., Ltd. All rights reserved.
30d163575Sopenharmony_ci *
40d163575Sopenharmony_ci * Redistribution and use in source and binary forms, with or without modification,
50d163575Sopenharmony_ci * are permitted provided that the following conditions are met:
60d163575Sopenharmony_ci *
70d163575Sopenharmony_ci * 1. Redistributions of source code must retain the above copyright notice, this list of
80d163575Sopenharmony_ci *    conditions and the following disclaimer.
90d163575Sopenharmony_ci *
100d163575Sopenharmony_ci * 2. Redistributions in binary form must reproduce the above copyright notice, this list
110d163575Sopenharmony_ci *    of conditions and the following disclaimer in the documentation and/or other materials
120d163575Sopenharmony_ci *    provided with the distribution.
130d163575Sopenharmony_ci *
140d163575Sopenharmony_ci * 3. Neither the name of the copyright holder nor the names of its contributors may be used
150d163575Sopenharmony_ci *    to endorse or promote products derived from this software without specific prior written
160d163575Sopenharmony_ci *    permission.
170d163575Sopenharmony_ci *
180d163575Sopenharmony_ci * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
190d163575Sopenharmony_ci * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
200d163575Sopenharmony_ci * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
210d163575Sopenharmony_ci * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
220d163575Sopenharmony_ci * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
230d163575Sopenharmony_ci * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
240d163575Sopenharmony_ci * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
250d163575Sopenharmony_ci * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
260d163575Sopenharmony_ci * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
270d163575Sopenharmony_ci * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
280d163575Sopenharmony_ci * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
290d163575Sopenharmony_ci */
300d163575Sopenharmony_ci
310d163575Sopenharmony_ci#include <stdio.h>
320d163575Sopenharmony_ci#include <string.h>
330d163575Sopenharmony_ci#include <stdlib.h>
340d163575Sopenharmony_ci#include <stdint.h>
350d163575Sopenharmony_ci
360d163575Sopenharmony_civoid *memset(void *dest, int c, size_t n)
370d163575Sopenharmony_ci{
380d163575Sopenharmony_ci    char *pos = dest;
390d163575Sopenharmony_ci    uint32_t c32 = 0;
400d163575Sopenharmony_ci    uint64_t c64 = 0;
410d163575Sopenharmony_ci    size_t num = n;
420d163575Sopenharmony_ci
430d163575Sopenharmony_ci    if (num == 0) {
440d163575Sopenharmony_ci        return dest;
450d163575Sopenharmony_ci    }
460d163575Sopenharmony_ci
470d163575Sopenharmony_ci    c = c & 0xFF;
480d163575Sopenharmony_ci    if (c) {
490d163575Sopenharmony_ci        c32 = c;
500d163575Sopenharmony_ci        c32 |= c32 << 8; /* 8, Processed bits */
510d163575Sopenharmony_ci        c32 |= c32 << 16; /* 16, Processed bits */
520d163575Sopenharmony_ci        c64 = c32;
530d163575Sopenharmony_ci        c64 |= c64 << 32; /* 32, Processed bits */
540d163575Sopenharmony_ci    }
550d163575Sopenharmony_ci
560d163575Sopenharmony_ci    if (((uintptr_t)(pos) & 7) != 0) { /* 7, Processed align */
570d163575Sopenharmony_ci        int unalignedCnt = 8 - ((uintptr_t)(pos) & 7); /* 7, 8, for calculate addr bits align */
580d163575Sopenharmony_ci        if (num >= unalignedCnt) {
590d163575Sopenharmony_ci            num = num - unalignedCnt;
600d163575Sopenharmony_ci        } else {
610d163575Sopenharmony_ci            unalignedCnt = num;
620d163575Sopenharmony_ci            num = 0;
630d163575Sopenharmony_ci        }
640d163575Sopenharmony_ci        for (int loop = 1; loop <= unalignedCnt; ++loop) {
650d163575Sopenharmony_ci            *pos = (char)c;
660d163575Sopenharmony_ci            pos++;
670d163575Sopenharmony_ci        }
680d163575Sopenharmony_ci    }
690d163575Sopenharmony_ci
700d163575Sopenharmony_ci    /* L32_byte_aligned */
710d163575Sopenharmony_ci    while (num >= 32) { /* 32, byte aligned */
720d163575Sopenharmony_ci        *(uint64_t *)(pos) = c64;
730d163575Sopenharmony_ci        *(uint64_t *)(pos + 8) = c64; /* 8, size of uint64_t */
740d163575Sopenharmony_ci        *(uint64_t *)(pos + 16) = c64; /* 16, size of two uint64_t data */
750d163575Sopenharmony_ci        *(uint64_t *)(pos + 24) = c64; /* 24, size of three uint64_t data */
760d163575Sopenharmony_ci        num -= 32; /* 32, size of four uint64_t data */
770d163575Sopenharmony_ci        pos += 32; /* 32, size of four uint64_t data */
780d163575Sopenharmony_ci    }
790d163575Sopenharmony_ci    if (num == 0) {
800d163575Sopenharmony_ci        return dest;
810d163575Sopenharmony_ci    }
820d163575Sopenharmony_ci
830d163575Sopenharmony_ci    /* L16_byte_aligned */
840d163575Sopenharmony_ci    if (num >= 16) { /* 16, byte aligned */
850d163575Sopenharmony_ci        *(uint64_t *)(pos) = c64;
860d163575Sopenharmony_ci        *(uint64_t *)(pos + 8) = c64; /* 8, size of uint64_t */
870d163575Sopenharmony_ci        num -= 16; /* 16, size of two uint64_t data */
880d163575Sopenharmony_ci        pos += 16; /* 16, size of two uint64_t data */
890d163575Sopenharmony_ci        if (num == 0) {
900d163575Sopenharmony_ci            return dest;
910d163575Sopenharmony_ci        }
920d163575Sopenharmony_ci    }
930d163575Sopenharmony_ci
940d163575Sopenharmony_ci    /* L8_byte_aligned */
950d163575Sopenharmony_ci    if (num >= 8) { /* 8, byte aligned */
960d163575Sopenharmony_ci        *(uint64_t *)(pos) = c64;
970d163575Sopenharmony_ci        num -= 8; /* 8, size of uint64_t */
980d163575Sopenharmony_ci        pos += 8; /* 8, size of uint64_t */
990d163575Sopenharmony_ci        if (num == 0) {
1000d163575Sopenharmony_ci            return dest;
1010d163575Sopenharmony_ci        }
1020d163575Sopenharmony_ci    }
1030d163575Sopenharmony_ci
1040d163575Sopenharmony_ci    /* L4_byte_aligned */
1050d163575Sopenharmony_ci    if (num >= 4) { /* 4, byte aligned */
1060d163575Sopenharmony_ci        *(uint32_t *)(pos) = c32;
1070d163575Sopenharmony_ci        num -= 4; /* 4, size of uint32_t */
1080d163575Sopenharmony_ci        pos += 4; /* 4, size of uint32_t */
1090d163575Sopenharmony_ci        if (num == 0) {
1100d163575Sopenharmony_ci            return dest;
1110d163575Sopenharmony_ci        }
1120d163575Sopenharmony_ci    }
1130d163575Sopenharmony_ci    while (num--) {
1140d163575Sopenharmony_ci        *pos++ = c;
1150d163575Sopenharmony_ci    }
1160d163575Sopenharmony_ci
1170d163575Sopenharmony_ci    return dest;
1180d163575Sopenharmony_ci}