亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? keccaksponge.c

?? Keccak hash加密算法
?? C
字號:
/*Algorithm Name: KeccakAuthors: Guido Bertoni, Joan Daemen, Micha?l Peeters and Gilles Van AsscheDate: January 9, 2009This code, originally by Guido Bertoni, Joan Daemen, Micha?l Peeters andGilles Van Assche as a part of the SHA-3 submission, is hereby put in thepublic domain. It is given as is, without any guarantee.For more information, feedback or questions, please refer to our website:http://keccak.noekeon.org/*/#include <string.h>#include "KeccakNISTInterface.h"#include "KeccakPermutationInterface.h"#ifdef KeccakReference#include "displayIntermediateValues.h"#endifHashReturn Init(hashState *state, int hashbitlen){    KeccakInitialize();    switch(hashbitlen) {        case 0: // Arbitrary length output            state->capacity = 576;            break;        case 224:            state->capacity = 576;            break;        case 256:            state->capacity = 576;            break;        case 384:            state->capacity = 1088;            break;        case 512:            state->capacity = 1088;            break;        default:            return BAD_HASHLEN;    }    state->rate = KeccakPermutationSize - state->capacity;    state->diversifier = hashbitlen/8;    state->hashbitlen = hashbitlen;    KeccakInitializeState(state->state);    memset(state->dataQueue, 0, KeccakMaximumRateInBytes);    state->bitsInQueue = 0;    state->squeezing = 0;    state->bitsAvailableForSqueezing = 0;    return SUCCESS;}void AbsorbQueue(hashState *state){    #ifdef KeccakReference    displayBytes(1, "Data to be absorbed", state->dataQueue, state->bitsInQueue/8);    #endif    // state->bitsInQueue is assumed to be equal a multiple of 8    memset(state->dataQueue+state->bitsInQueue/8, 0, state->rate/8-state->bitsInQueue/8);    if (state->rate == 1024)        KeccakAbsorb1024bits(state->state, state->dataQueue);    else        KeccakAbsorb512bits(state->state, state->dataQueue);    state->bitsInQueue = 0;}HashReturn Update(hashState *state, const BitSequence *data, DataLength databitlen){    DataLength i, j;    DataLength partialBlock, partialByte, wholeBlocks;    BitSequence lastByte;    const BitSequence *curData;    if ((state->bitsInQueue % 8) != 0)        return FAIL; // Only the last call may contain a partial byte    if (state->squeezing)        return FAIL; // Too late for additional input    i = 0;    while(i < databitlen) {        if ((state->bitsInQueue == 0) && (databitlen >= state->rate) && (i <= (databitlen-state->rate))) {            wholeBlocks = (databitlen-i)/state->rate;            curData = data+i/8;            if (state->rate == 1024) {                for(j=0; j<wholeBlocks; j++, curData+=1024/8) {                    #ifdef KeccakReference                    displayBytes(1, "Data to be absorbed", curData, state->rate/8);                    #endif                    KeccakAbsorb1024bits(state->state, curData);                }            }            else {                for(j=0; j<wholeBlocks; j++, curData+=512/8) {                    #ifdef KeccakReference                    displayBytes(1, "Data to be absorbed", curData, state->rate/8);                    #endif                    KeccakAbsorb512bits(state->state, curData);                }            }            i += wholeBlocks*state->rate;        }        else {            partialBlock = databitlen - i;            if (partialBlock+state->bitsInQueue > state->rate)                partialBlock = state->rate-state->bitsInQueue;            partialByte = partialBlock % 8;            partialBlock -= partialByte;            memcpy(state->dataQueue+state->bitsInQueue/8, data+i/8, partialBlock/8);            state->bitsInQueue += partialBlock;            i += partialBlock;            if (state->bitsInQueue == state->rate)                AbsorbQueue(state);            if (partialByte > 0) {                // Align the last partial byte to the least significant bits                lastByte = data[i/8] >> (8-partialByte);                state->dataQueue[state->bitsInQueue/8] = lastByte;                state->bitsInQueue += partialByte;                i += partialByte;            }        }    }    return SUCCESS;}void PadAndSwitchToSqueezingPhase(hashState *state){    if ((state->bitsInQueue % 8) != 0) {        // The bits are numbered from 0=LSB to 7=MSB        unsigned char padByte = 1 << (state->bitsInQueue % 8);        state->dataQueue[state->bitsInQueue/8] |= padByte;        state->bitsInQueue += 8-(state->bitsInQueue % 8);    }    else {        state->dataQueue[state->bitsInQueue/8] = 0x01;        state->bitsInQueue += 8;    }    if (state->bitsInQueue == state->rate)        AbsorbQueue(state);    state->dataQueue[state->bitsInQueue/8] = state->diversifier;    state->bitsInQueue += 8;    if (state->bitsInQueue == state->rate)        AbsorbQueue(state);    state->dataQueue[state->bitsInQueue/8] = state->rate/8;    state->bitsInQueue += 8;    if (state->bitsInQueue == state->rate)        AbsorbQueue(state);    state->dataQueue[state->bitsInQueue/8] = 0x01;    state->bitsInQueue += 8;    if (state->bitsInQueue > 0)        AbsorbQueue(state);    if ((state->rate == 1024) && ((state->hashbitlen > 512) || (state->hashbitlen == 0))) {        KeccakExtract1024bits(state->state, state->dataQueue);        state->bitsAvailableForSqueezing = 1024;    }    else {        KeccakExtract512bits(state->state, state->dataQueue);        state->bitsAvailableForSqueezing = 512;    }    state->squeezing = 1;}HashReturn Final(hashState *state, BitSequence *hashval){    if (state->squeezing)        return FAIL; // Too late, we are already squeezing    PadAndSwitchToSqueezingPhase(state);    if (state->hashbitlen > 0)        memcpy(hashval, state->dataQueue, state->hashbitlen/8);    return SUCCESS;}HashReturn Squeeze(hashState *state, BitSequence *output, DataLength outputLength){    DataLength i;    DataLength partialBlock;    if (!state->squeezing)        return FAIL; // Too early, we are still absorbing    if (state->hashbitlen != 0)        return FAIL; // Arbitrary length output is not permitted in this case    if ((outputLength % 8) != 0)        return FAIL; // Only multiple of 8 bits are allowed, truncation can be done at user level    i = 0;    while(i < outputLength) {        if (state->bitsAvailableForSqueezing == 0) {            KeccakPermutation(state->state);            if (state->rate == 1024) {                KeccakExtract1024bits(state->state, state->dataQueue);                state->bitsAvailableForSqueezing = state->rate;            }            else                return FAIL; // Inconsistent rate        }        partialBlock = outputLength - i;        if (partialBlock > state->bitsAvailableForSqueezing)            partialBlock = state->bitsAvailableForSqueezing;        memcpy(output+i/8, state->dataQueue+(state->rate-state->bitsAvailableForSqueezing)/8, partialBlock/8);        state->bitsAvailableForSqueezing -= partialBlock;        i += partialBlock;    }    return SUCCESS;}HashReturn Hash(int hashbitlen, const BitSequence *data, DataLength databitlen, BitSequence *hashval){    hashState state;    HashReturn result;    if (hashbitlen == 0)        return BAD_HASHLEN; // Arbitrary length output not available through this API    result = Init(&state, hashbitlen);    if (result != SUCCESS)        return result;    result = Update(&state, data, databitlen);    if (result != SUCCESS)        return result;    result = Final(&state, hashval);    return result;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲主播在线播放| 国产精品资源网| 国产亚洲1区2区3区| 欧美在线观看一区二区| 国产麻豆日韩欧美久久| 亚洲第四色夜色| 国产精品麻豆一区二区 | 911国产精品| 成人国产免费视频| 久久99国产精品成人| 亚洲一级二级在线| 综合精品久久久| 欧美韩国一区二区| 久久亚洲精华国产精华液| 欧美日韩的一区二区| 99精品在线免费| 国产成人精品一区二区三区四区| 天天做天天摸天天爽国产一区| 国产精品久久久久久亚洲毛片| 欧美成人video| 91麻豆精品国产| 精品视频1区2区3区| 99国产麻豆精品| 成人a区在线观看| 顶级嫩模精品视频在线看| 国内精品国产成人国产三级粉色| 午夜精品久久久久久不卡8050| 亚洲女人的天堂| 亚洲丝袜另类动漫二区| 国产精品乱码久久久久久| 国产亚洲欧美一区在线观看| 欧美成人高清电影在线| 欧美不卡激情三级在线观看| 91精品午夜视频| 3atv在线一区二区三区| 欧美日本免费一区二区三区| 欧美性大战久久久久久久蜜臀 | 日韩电影在线免费看| 亚洲大片在线观看| 日韩在线卡一卡二| 日韩电影一区二区三区| 麻豆国产91在线播放| 久久9热精品视频| 免费成人结看片| 久久国产精品72免费观看| 精品一区二区三区香蕉蜜桃 | 九色|91porny| 国产综合成人久久大片91| 国产精品18久久久久久vr | 欧美精品少妇一区二区三区| 欧美私人免费视频| 9191久久久久久久久久久| 91精品婷婷国产综合久久性色 | 欧美日韩中文字幕一区| 欧美日韩一区二区三区免费看 | 亚洲三级视频在线观看| 一区二区日韩av| 日韩黄色免费网站| 激情小说欧美图片| 国产伦精品一区二区三区在线观看| 国产精品夜夜嗨| 色综合亚洲欧洲| 67194成人在线观看| 日韩欧美一区二区三区在线| 久久久久久毛片| 亚洲日本中文字幕区| 三级欧美韩日大片在线看| 久久精品国产一区二区| 成人精品视频一区二区三区 | 91精品国产免费久久综合| 久久伊人蜜桃av一区二区| 国产精品人妖ts系列视频| 亚洲国产色一区| 国产精品资源在线观看| 在线观看三级视频欧美| 日韩欧美一级二级三级| 中文字幕一区二区三区在线播放 | 欧美日本一区二区三区四区| 日韩免费观看高清完整版| 国产欧美一区在线| 亚洲成人一区二区在线观看| 国产一区二区三区国产| 一本色道久久综合亚洲91| 日韩一级高清毛片| 亚洲天堂网中文字| 美女国产一区二区三区| 99久久婷婷国产精品综合| 91精品国产全国免费观看| 国产精品家庭影院| 久久精品国产第一区二区三区| 成人av在线播放网址| 91精品国产综合久久精品| 国产精品久久久久久久久快鸭| 日韩精品亚洲一区| 91在线国内视频| 欧美精品一区二区在线播放| 亚洲亚洲人成综合网络| 成人三级在线视频| 欧美va在线播放| 午夜av一区二区三区| 成年人网站91| 国产亚洲精品超碰| 久久精品国产一区二区三区免费看 | 欧美激情资源网| 久久99最新地址| 欧美日韩免费视频| 国产精品成人一区二区艾草| 美女视频一区二区| 欧美亚洲丝袜传媒另类| 亚洲欧美在线另类| 国产成人精品免费看| 日韩欧美一区在线| 亚洲成人一二三| 在线观看中文字幕不卡| 国产精品青草久久| 高清成人免费视频| 久久九九全国免费| 国产在线精品一区二区三区不卡 | 国产精品亚洲专一区二区三区 | 1024成人网| 成人av网址在线| 国产无一区二区| 国产美女久久久久| 久久精品日韩一区二区三区| 精品影院一区二区久久久| 日韩精品一区二区三区在线观看 | 国内外精品视频| 精品久久国产字幕高潮| 日韩高清不卡一区二区三区| 欧美高清一级片在线| 亚洲高清免费观看| 欧美日韩国产精品成人| 亚洲va欧美va人人爽| 欧美色精品天天在线观看视频| 亚洲午夜久久久久久久久电影网| 91麻豆国产自产在线观看| 亚洲三级电影网站| 91官网在线观看| 亚洲大片免费看| 91精品啪在线观看国产60岁| 美女爽到高潮91| 精品成人佐山爱一区二区| 国产一区二区伦理片| 欧美韩国日本不卡| 91免费小视频| 亚洲综合在线第一页| 欧美日韩国产123区| 免费观看成人鲁鲁鲁鲁鲁视频| 精品捆绑美女sm三区| 高清久久久久久| 亚洲精品成人在线| 欧美男女性生活在线直播观看| 日韩国产欧美一区二区三区| 欧美xxxxx牲另类人与| 国产一区二区三区蝌蚪| 国产精品电影一区二区三区| 91免费看视频| 日本午夜一本久久久综合| 欧美精品一区二区三区四区 | 欧美高清在线视频| 91免费观看视频| 亚洲国产精品精华液网站| 欧美videossexotv100| 成人黄页在线观看| 亚洲成人你懂的| 久久久www免费人成精品| 91香蕉视频在线| 日韩主播视频在线| 亚洲国产精品成人综合| 欧美午夜精品理论片a级按摩| 麻豆精品新av中文字幕| 国产精品灌醉下药二区| 欧美午夜寂寞影院| 国产成人啪免费观看软件| 亚洲精品va在线观看| 日韩免费一区二区三区在线播放| 成人av综合在线| 日韩国产欧美三级| 国产欧美日韩精品在线| 欧美羞羞免费网站| 国产精品综合网| 亚洲成人tv网| 久久久久久9999| 欧美人体做爰大胆视频| 成人午夜免费视频| 奇米精品一区二区三区在线观看一| 国产精品理伦片| 日韩精品一区二区在线观看| 一道本成人在线| 国产乱码精品一区二区三区av| 亚洲一区二区在线视频| 国产视频911| 3d成人h动漫网站入口| 91在线观看一区二区| 麻豆视频观看网址久久| 亚洲综合一区在线| 亚洲欧洲日韩av| 精品国产一区a| 欧美一区二区三区在线观看| 91日韩一区二区三区|