- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在开发一种有点棘手的硬件......例如,它的 32 位寄存器看起来像这样(高 16 位全部为零)
#define MASK_DBG_CTRL_FIFO_SPLIT 0b0000000000000001
#define MASK_DBG_CTRL_FIFO_ENABLE 0b0000000000000010
#define MASK_DBG_CTRL_ADC_SPLIT 0b0000000000000100
#define MASK_DBG_CTRL_ADC_ENABLE 0b0000000000001000
#define MASK_DBG_CTRL_MAX_COUNTER 0b1111111111110000
#define NO_SPLIT 0
#define WITH_SPLIT 1
#define DISABLE 0
#define ENABLE 1
我的问题是,如何生成需要写入该寄存器的数字。例如。我将有一个函数从用户处获取数字并返回准备写入寄存器的值。
这似乎是一个非常痛苦的过程...我有十几个类似的寄存器,它们具有不同的位宽和内容...我怎样才能使这个过程变得更容易?
例如,如何在 MASK_DBG_CTRL_MAX_COUNTER
位写入所需的值?
uint32_t generateDebugRegister(uint8_t fifoSplit, uint8_t fifoEnable,
uint8_t adcSplit, uint8_t adcEnable,
uint16_t counter) {
uint32_t output = 0;
switch(fifoSplit) {
case NO_SPLIT:
//do nothing;
break;
case WITH_SPLIT:
output = 1UL >> 1; //set bit 0 to 1
break;
}
switch(fifoEnable) {
case DISABLE:
//do nothing;
break;
case ENABLE:
output = 1UL >> 2; //set bit 2 to 1
break;
}
switch(adcSplit) {
case NO_SPLIT:
//do nothing;
break;
case WITH_SPLIT:
output = 1UL >> 3; //set bit 3 to 1
break;
}
switch(adcEnable) {
case DISABLE:
//do nothing;
break;
case ENABLE:
output = 1UL >> 4; //set bit 4 to 1
break;
}
//how to evenset the counter value???
return output;
}
调用函数示例:
void setDebugRegister(uint32_t value) { /*write to reg*/ };
uint32_t toWrite = generateDebugRegister(NO_SPLIT, DISABLE, WITH_SPLIT, ENABLE, 4256);
setDebugRegister( toWrite);
这是另一组寄存器掩码...这里我需要将低10位拼接成两个5位:
#define MASK_DAD_NUM_ADDR 0b0000000000011111
#define MASK_DAD_NUM_DECI 0b0000001111100000
这里,高 8 位和低 8 位:
#define MASK_DBG_REG_ID 0b1111111100000000;
#define MASK_DBG_REG_CNTR 0b0000000011111111;
最佳答案
How to generate a value using pre defined mask (?)
解决OP的第一部分:
考虑重写函数签名。其他建议的更改如下作为注释代码。
// uint32_t generateDebugRegister(uint8_t fifoSplit, uint8_t fifoEnable,
// uint8_t adcSplit, uint8_t adcEnable, uint16_t counter) { ...
// use bool for simple T/F values
uint32_t generateDebugRegister(bool fifoSplit, bool fifoEnable, bool adcSplit,
bool adcEnable, uint16_t counter) {
uint32_t output = 0;
if (fifoSplit == WITH_SPLIT) { // use an `if()`
output |= MASK_DBG_CTRL_FIFO_SPLIT; // use an 'or' of the mask
}
if (fifoEnable == ENABLE) {
output |= MASK_DBG_CTRL_FIFO_ENABLE;
}
.... // like-wise with adcSplit, adcEnable
// add an `offset` to simplify shifting needs
#define MASK_DBG_CTRL_MAX_BIT_OFFSET 4
#define MASK_DBG_CTRL_MAX_MAX (MASK_DBG_CTRL_MAX_COUNTER >> MASK_DBG_CTRL_MAX_BIT_OFFSET)
// test, since 16 bits do not fit in 12
if (counter > MASK_DBG_CTRL_MAX_MAX) {
Handle_error_with_TBD_Code();
}
else {
output |= (uint32_t)counter << MASK_DBG_CTRL_MAX_BIT_OFFSET;
}
return out;
}
I have a dozen of similar registers that have different bit-width and stuff...How can I make this easier?
需要查看其中一些以获得良好的一般答案。
关于c - 如何使用预定义掩码生成值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47680794/
我对我接管的项目有疑问。我正在转换其他人编写的 MS Access 应用程序并将其转换为 MySQL/PHP Web 应用程序。其中大部分已经完成,但是,当涉及到此应用程序的调度部分时,我处于停滞状态
我有一个带有 @Scheduled 注释的方法。此方法包含长时间运行、昂贵的操作。我担心当计划的方法开始运行时应用程序会变慢。有什么办法可以为预定方法分配优先级吗?在 Spring 中启动低优先级后台
我的大学有一个预订项目房间的网站;但除非你很幸运或者半夜醒着,否则要订到房间并不容易。因此,我编写了一个 JS 片段来填写所有必要的字段并提交表单。 但是我如何自动化这个过程呢? 我的目的基本上是加载
我正在评估处理大量排队消息的可能解决方案,这些消息必须在特定日期和时间交付给工作人员。执行它们的结果主要是对存储数据的更新,它们最初可能是也可能不是由用户操作触发的。 例如,想想你在一个假设的大型星际
@Scheduled documentation here声明 fixedRateString值可以是 the delay in milliseconds as a String value, e.g
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 4年前关闭。 Improve t
我有一个有趣的情况。我解析了几个新闻发布网站,想通过调度程序将它们保存到数据库中。但是保存时出现错误。由于交易后写条件 described here . 我的模型类是 @Entity @Table(n
我正在阅读 Java Concurrency in Practice 并遇到以下代码片段。 public static void timedRun(final Runnable r,
使用 Azure 数据工厂,是否可以对驻留在 Azure SQL 数据库中的多个(不是全部)表中的所有行执行预定的 1:1 复制/克隆到另一个 Azure SQL 数据库(在本例中为 Azure SQ
我是一名优秀的程序员,十分优秀!