共2条
1/1 1 跳转至页
winavr winavr指针奇怪问题
问
用mega8的twi写max518。函数是参照winAVR的例子写的,基本没变。
奇怪的是我用数组赋值给buf就可以,可是用普通的指针就不行
uint8_t i, *p; /* 这样不行 */
p = &i;
*p = 0x00;
*(p+1) = 0xff;
uint8_t data[2]; /* 这样就行 */
data[0] = 0x00;
data[1] = 0xff;
下面是程序
int twi_write_bytes(uint8_t addr, int len, uint8_t *buf)
{
uint8_t n = 0;
int st = 0;
restart:
if (n++ >= MAX_ITER)
{
return -1;
}
begin:
TWCR = _BV(TWINT) | _BV(TWSTA) | _BV(TWEN); /* send start condition */
while ((TWCR & _BV(TWINT)) == 0)
{
}; /* wait for transmission */
switch ((twst = TW_STATUS))
{
case TW_REP_START: /* OK, but should not happen */
case TW_START:
break;
case TW_MT_ARB_LOST:
goto begin;
default:
return -1; /* error: not in start condition */
/* NB: do /not/ send stop condition */
}
/* send ADDR+W */
TWDR = addr | TW_WRITE;
TWCR = _BV(TWINT) | _BV(TWEN); /* clear interrupt to start transmission */
while ((TWCR & _BV(TWINT)) == 0)
{
}; /* wait for transmission */
switch ((twst = TW_STATUS))
{
case TW_MT_SLA_ACK:
break;
case TW_MT_SLA_NACK: /* nack during select: device busy writing */
goto restart;
case TW_MT_ARB_LOST: /* re-arbitrate */
goto begin;
default:
goto error; /* must send stop condition */
}
for (; len > 0; len--)
{
TWDR = *buf++;
TWCR = _BV(TWINT) | _BV(TWEN); /* start transmission */
while ((TWCR & _BV(TWINT)) == 0)
{
}; /* wait for transmission */
switch ((twst = TW_STATUS))
{
case TW_MT_DATA_NACK:
goto error; /* device write protected -- Note [14] */
case TW_MT_DATA_ACK:
st++;
break;
default:
goto error;
}
}
quit:
TWCR = _BV(TWINT) | _BV(TWSTO) | _BV(TWEN); /* send stop condition */
return st;
error:
st = -1;
goto quit;
}
答 1: 你写越界了uint8_t i, *p; /* 这样不行 */
p = &i;
*p = 0x00;
*(p+1) = 0xff;
*(p+1)超过了i的范围。
uint8_t i[2], *p;
p=i;
*p = 0x00;
*(p+1) = 0xff;
这样就可以了。
奇怪的是我用数组赋值给buf就可以,可是用普通的指针就不行
uint8_t i, *p; /* 这样不行 */
p = &i;
*p = 0x00;
*(p+1) = 0xff;
uint8_t data[2]; /* 这样就行 */
data[0] = 0x00;
data[1] = 0xff;
下面是程序
int twi_write_bytes(uint8_t addr, int len, uint8_t *buf)
{
uint8_t n = 0;
int st = 0;
restart:
if (n++ >= MAX_ITER)
{
return -1;
}
begin:
TWCR = _BV(TWINT) | _BV(TWSTA) | _BV(TWEN); /* send start condition */
while ((TWCR & _BV(TWINT)) == 0)
{
}; /* wait for transmission */
switch ((twst = TW_STATUS))
{
case TW_REP_START: /* OK, but should not happen */
case TW_START:
break;
case TW_MT_ARB_LOST:
goto begin;
default:
return -1; /* error: not in start condition */
/* NB: do /not/ send stop condition */
}
/* send ADDR+W */
TWDR = addr | TW_WRITE;
TWCR = _BV(TWINT) | _BV(TWEN); /* clear interrupt to start transmission */
while ((TWCR & _BV(TWINT)) == 0)
{
}; /* wait for transmission */
switch ((twst = TW_STATUS))
{
case TW_MT_SLA_ACK:
break;
case TW_MT_SLA_NACK: /* nack during select: device busy writing */
goto restart;
case TW_MT_ARB_LOST: /* re-arbitrate */
goto begin;
default:
goto error; /* must send stop condition */
}
for (; len > 0; len--)
{
TWDR = *buf++;
TWCR = _BV(TWINT) | _BV(TWEN); /* start transmission */
while ((TWCR & _BV(TWINT)) == 0)
{
}; /* wait for transmission */
switch ((twst = TW_STATUS))
{
case TW_MT_DATA_NACK:
goto error; /* device write protected -- Note [14] */
case TW_MT_DATA_ACK:
st++;
break;
default:
goto error;
}
}
quit:
TWCR = _BV(TWINT) | _BV(TWSTO) | _BV(TWEN); /* send stop condition */
return st;
error:
st = -1;
goto quit;
}
答 1: 你写越界了uint8_t i, *p; /* 这样不行 */
p = &i;
*p = 0x00;
*(p+1) = 0xff;
*(p+1)超过了i的范围。
uint8_t i[2], *p;
p=i;
*p = 0x00;
*(p+1) = 0xff;
这样就可以了。
共2条
1/1 1 跳转至页
回复
我要赚赏金打赏帖 |
|
|---|---|
| 基于ArduinoUNO开发板的AT24C02读写测试被打赏¥16元 | |
| TCS3472S传感器及其色彩检测被打赏¥19元 | |
| 【S32DS】S32K3 RTD7.0.1 HSE 组件配置报错问题解决被打赏¥27元 | |
| 【S32K3XX】MCME 启动 CORE1被打赏¥23元 | |
| AG32VH407下温度大气压传感器及其检测被打赏¥20元 | |
| AG32VH407下光照强度传感器BH1750及其检测被打赏¥22元 | |
| AT32VH407下使用温湿度传感器DHT22进行检测被打赏¥20元 | |
| DIY一个婴儿澡盆温度计被打赏¥34元 | |
| 【FreeRtos】FreeRtos+MPU region 配置规则被打赏¥23元 | |
| 【分享开发笔记,赚取电动螺丝刀】三分钟快速上手驱动墨水屏(ArduinoIDE)被打赏¥28元 | |
我要赚赏金
