blob: 3a456181fbbde6c5da4141d5271c408fac9829ad [file] [log] [blame]
/*
* Copyright 2023 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include "test_vector.h"
#include <springbok.h>
#define MSTATUS_VS 0x00000600
#define enable_vec() \
do { \
__asm__ volatile("csrs mstatus, %[bits];" ::[bits] "r"( \
MSTATUS_VS & (MSTATUS_VS >> 1))); \
} while (0);
uint32_t get_vtype(uint8_t vsew, uint8_t vlmul, bool tail_agnostic,
bool mask_agnostic) {
return (vlmul & 0x7) | (vsew & 0x7) << 3 | (tail_agnostic & 0x1) << 6 |
(mask_agnostic & 0x1) << 7;
}
uint32_t get_vtype_e8(uint8_t vlmul, bool tail_agnostic, bool mask_agnostic) {
uint8_t vsew = 0;
return get_vtype(vsew, vlmul, tail_agnostic, mask_agnostic);
}
uint32_t get_vtype_e16(uint8_t vlmul, bool tail_agnostic, bool mask_agnostic) {
uint8_t vsew = 1;
return get_vtype(vsew, vlmul, tail_agnostic, mask_agnostic);
}
uint32_t get_vtype_e32(uint8_t vlmul, bool tail_agnostic, bool mask_agnostic) {
uint8_t vsew = 2;
return get_vtype(vsew, vlmul, tail_agnostic, mask_agnostic);
}
uint32_t get_vtype_e64(uint8_t vlmul, bool tail_agnostic, bool mask_agnostic) {
uint8_t vsew = 3;
return get_vtype(vsew, vlmul, tail_agnostic, mask_agnostic);
}
int main(void) {
LOG_INFO("Hello test_vector.c");
LOG_INFO("Built at: " __DATE__ ", " __TIME__);
uint32_t misa;
__asm__ volatile("csrr %0, misa" : "=r"(misa));
LOG_INFO("MISA: 0x%08x", (unsigned int)misa);
uint32_t mstatus;
__asm__ volatile("csrr %0, mstatus" : "=r"(mstatus));
LOG_INFO("BEFORE MSTATUS: 0x%08x", (unsigned int)mstatus);
enable_vec();
__asm__ volatile("csrr %0, mstatus" : "=r"(mstatus));
LOG_INFO("AFTER MSTATUS: 0x%08x", (unsigned int)mstatus);
uint32_t vlenb;
__asm__ volatile("csrr %0, vlenb" : "=r"(vlenb));
LOG_INFO("VLENB: 0x%08x, VLEN: %u", (unsigned int)vlenb, vlenb << 3);
assert(test_vector());
LOG_INFO("test_main done.");
return 0;
}