计算机架构与编程优化相关知识解析
1. Itanium架构特点
Itanium(IA64)架构虽然在市场上近乎失败,但它有着独特的设计。与乱序执行(OOE)CPU自行决定指令重排和并行执行不同,显式并行指令计算(EPIC)尝试将这些决策交给编译器,让编译器在编译阶段对指令进行分组。不过,这导致编译器变得极为复杂。
以下是Linux内核中一个简单加密算法的IA64代码示例:
#define TEA_ROUNDS 32
#define TEA_DELTA 0x9e3779b9
static void tea_encrypt(struct crypto_tfm *tfm, u8 *dst, const u8 *src)
{
u32 y, z, n, sum = 0;
u32 k0, k1, k2, k3;
struct tea_ctx *ctx = crypto_tfm_ctx(tfm);
const __le32 *in = (const __le32 *)src;
__le32 *out = (__le32 *)dst;
y = le32_to_cpu(in[0]);
z = le32_to_cpu(in[1]);
k0 = ctx->KEY[0];
k1 = ctx->KEY[1];
k2 = ctx->KEY[2];
k3 = ctx->KEY[3];
n = TEA_ROUNDS;
while (n-- > 0) {
sum += TEA_DELTA;
y +=
超级会员免费看
订阅专栏 解锁全文

被折叠的 条评论
为什么被折叠?



