Minh mới bắt đầu chuyển qua dung C cho AVR nen chua biết Nên dùng CodeVision hay AVR-GCC.. nhờ các anh em đã dung rồi cho biết nên dung cai nao cho tiện Cam on AE!
Thông báo
Collapse
No announcement yet.
Dung C cho AVR
Collapse
X
-
Mình cũng chưa dùng AVR-GCC bao giờ, mình thì chỉ dùng codevision thôi. Vì thế mình không dám so sánh. Nhưng mình đã dùng codevision khá nhiều. Thấy nó rất tiện lợi, dễ dàng, và giao diện cũng thân thiện. Và mình thấy đa số anh em đều dùng codevision. Nếu ai đã từng dùng AVR-GCC rồi thì cho một vài nhận xét xem sao.Kel'Thuzads
Mail:minhnguyen.ac@gmail.com
-
AVR GCC là trình dich miễn phí => không dể dùng. Mấy tay viết nên cái trình dịch này đa số là đại cao thủ, công phu lập trình của mấy chả thì chắc không cần phải nói cho nên các bác chân ướt chân ráo thì tốt hơn là xài CV cho nó khỏe
Tuy nhiên tất cả đều là ngôn ngữ C do đó cũng chẳng khác nhau là bao nhiêu ! Trong quá trình sữ dụng, NVT2 nhận thấy CV có nhiều thư viên hơn, cách sữ dụng bộ nhớ có quy tắc dể hiểu hơn và mức độ tối ưu code để tiết kiệm bộ nhớ nhiều hơn...tuy nhiên đó cũng là nhược điểm của CV vì nó hạn chế người dùng ở mức độ lập trình ứng dụng và điều khiển cơ bản.
Còn đối với AVR-GCC thì chẳng ai cho không thư viên cả(trừ thư viện cơ bản), phải tự viết thôi. Tuy nhiên dùng AVR GCC thì hầu như có thể làm đươc mọi thứ, tùy vào công phu của bạn thôi. Và quan trọng hơn cả là hầu hết các open source project đều viết trên AVR GCC.
Còn nhiều trình dịch C khác nhưng tại không có tiền mua licence nên không biết và không bàn
NVT2Tín đồ AVR giáo.
Comment
-
Dùng bản ***** thôi. Hí hí. VN mà.
Nhưng tôi đang dùng thấy CV không được thông minh lắm. Hay tại mình kém nữa không biết.AVR đã quay trở lại: ATMEGA32: 66k, ATMEGA8A: 30k, ATMEGA48: 30k.
Xem thêm tại Online Store ---> Click here
Mob: 0982.083.106
Comment
-
Dùng CV là ổn rồi bạn a',mình thấy CV đáp ứng được cho các ứng dụng của chúng ta,thân thiện và dễ sử dụng debug cũng thuận lợi.Bạn có thể chuyển đến dùng AVRstudio xem sao,dùng cái này thi bạn có thể hiểu ngọn ngành hơn về chương trình.(thiển ý của em).goodluck
Comment
-
So sánh thì về tính chuyên nghiệp nhìn Avrstudio khá là pro.
Cũng okie lập trình nó thì hiểu nhiều hơn và thư viện trên thế giới người ta viết cho nó cũng khá là nhiều.
Còn CV thì hay ở chỗ là có template code cho mình.
Nhưng cũng hổng an toàn.
Theo mình người lập trình phần nhúng mà dùng template quá nhiều không ổn vì dùng template sẽ không hiểu cấu trúc của con chip bạn đang dùng.
Điều thứ 2 nữa là CV dịch ra tốt hơn Winavr (Winavr Avrstudio là 1 đều là GCC ) ở 1 số chỗ.
Ví dụ trong datasheet ở đoạn đọc epprom của họ atmega (mình chưa xài họ khác) nếu bạn dùng code ghi của nó thì chỉ chạy bên CV còn avrstudio không hoạt động vì cách dịch của GCC không tối ưu mã nên nó không đúng thời gian đáp ứng trong datasheet.
ví dụ:
Đây là code trong datasheet:
Đây là code mình mod lại cho chạy dc với AVRStudio:Code:void EEPROM_write(unsigned int uiAddress, unsigned char ucData) { /* Wait for completion of previous write */ while(EECR & (1<<EEWE)) ; /* Set up address and data registers */ EEAR = uiAddress; EEDR = ucData; /* Write logical one to EEMWE */ EECR |= (1<<EEMWE); /* Start eeprom write by setting EEWE */ EECR |= (1<<EEWE); }
Chỗ (1<<EEWE) GCC không hiểu là hằng số không tính trước mà lại thành lện h tính toán trong AVR làm tốn chu kì.Code:void EEPROM_write(unsigned int uiAddress, unsigned char ucData) { /* Wait for completion of previous write */ while(EECR & (1<<EEWE)) ; /* Set up address and data registers */ EEAR = uiAddress; EEDR = ucData; /* Write logical one to EEMWE */ EECR |= (1<<EEMWE); //EECR |= (1<<EEWE); /* Start eeprom write by setting EEWE */ asm("sbi 0x1C,1"); }
Nên nếu làm với GCC thì cẩn thận nên coi nó dịch mã ASM ra như thế nào đảm bảo an tâm chút
.
Sông dài, Thuyền lớn, Biển rộng bao la.
Tháo neo ngôn ngữ, lèo lái con thuyền kiến thức nhân loại.
Comment
-
Mình chưa thử debug với CV. Không hiểu nó debug thế nào?Nguyên văn bởi VanKimCo Xem bài viếtDùng CV là ổn rồi bạn a',mình thấy CV đáp ứng được cho các ứng dụng của chúng ta,thân thiện và dễ sử dụng debug cũng thuận lợi.Bạn có thể chuyển đến dùng AVRstudio xem sao,dùng cái này thi bạn có thể hiểu ngọn ngành hơn về chương trình.(thiển ý của em).goodluckAVR đã quay trở lại: ATMEGA32: 66k, ATMEGA8A: 30k, ATMEGA48: 30k.
Xem thêm tại Online Store ---> Click here
Mob: 0982.083.106
Comment
-
Mình đang viết bằng Winavr gặp đoạn lỗi này chả biết sử lý sao cả, mọi người giúp mình nhé
:
#include <avr/interrupt.h> // các header khác mình có khai báo đủ luôn rồi
ISR(INT1_vect)
{
}
//
sau khi biên dịch nó báo lỗi như thế này:
1.c:229: error: static declaration of '__vector_2' follows non-static declaration
1.c:228: error: previous declaration of '__vector_2' was here
//
mình có thử dùng hàm SIGNAL(SIG_INTERRUPT1) {}
nhưng kết quả cũng ra y chang vậy a. Ko biết nó bị lỗi ở chỗ nào nhỉ?:-B
Comment
-
//
#include "lcd_lib.h"
#include <inttypes.h>
#include <avr/io.h>
#include <avr/pgmspace.h>
#include <avr/interrupt.h>
#include <avr/iom8535.h>
#include <util/delay.h>
/*
RS = PORTA0
R/W = PORTA1
EN = PORTA2
PB 4..7 = PORTA 4..7
KEYBOARD = PORCT C
*/
void LCDsendChar(uint8_t ch) //Sends Char to LCD
{
LDP=(ch&0b11110000);
LCP|=1<<LCD_RS;
LCP|=1<<LCD_E;
_delay_ms(1);
LCP&=~(1<<LCD_E);
LCP&=~(1<<LCD_RS);
_delay_ms(1);
LDP
ch&0b00001111)<<4);
LCP|=1<<LCD_RS;
LCP|=1<<LCD_E;
_delay_ms(1);
LCP&=~(1<<LCD_E);
LCP&=~(1<<LCD_RS);
_delay_ms(1);
}
void LCDsendCommand(uint8_t cmd) //Sends Command to LCD
{
LDP=(cmd&0b11110000);
LCP|=1<<LCD_E;
_delay_ms(1);
LCP&=~(1<<LCD_E);
_delay_ms(1);
LDP
cmd&0b00001111)<<4);
LCP|=1<<LCD_E;
_delay_ms(1);
LCP&=~(1<<LCD_E);
_delay_ms(1);
}
void LCDinit(void)//Initializes LCD
{
_delay_ms(15);
LDP=0x00;
LCP=0x00;
LDDR|=1<<LCD_D7|1<<LCD_D6|1<<LCD_D5|1<<LCD_D4;
LCDR|=1<<LCD_E|1<<LCD_RW|1<<LCD_RS;
//---------one------
LDP=0<<LCD_D7|0<<LCD_D6|1<<LCD_D5|1<<LCD_D4; //4 bit mode
LCP|=1<<LCD_E|0<<LCD_RW|0<<LCD_RS;
_delay_ms(1);
LCP&=~(1<<LCD_E);
_delay_ms(1);
//-----------two-----------
LDP=0<<LCD_D7|0<<LCD_D6|1<<LCD_D5|1<<LCD_D4; //4 bit mode
LCP|=1<<LCD_E|0<<LCD_RW|0<<LCD_RS;
_delay_ms(1);
LCP&=~(1<<LCD_E);
_delay_ms(1);
//-------three-------------
LDP=0<<LCD_D7|0<<LCD_D6|1<<LCD_D5|0<<LCD_D4; //4 bit mode
LCP|=1<<LCD_E|0<<LCD_RW|0<<LCD_RS;
_delay_ms(1);
LCP&=~(1<<LCD_E);
_delay_ms(1);
//--------4 bit--dual line---------------
LCDsendCommand(0b00101000);
//-----increment address, cursor shift------
LCDsendCommand(0b00001110);
}
void LCDclr(void) //Clears LCD
{
LCDsendCommand(1<<LCD_CLR);
}
void LCDhome(void) //LCD cursor home
{
LCDsendCommand(1<<LCD_HOME);
}
void LCDstring(uint8_t* data, uint8_t nBytes) //Outputs string to LCD
{
register uint8_t i;
// check to make sure we have a good pointer
if (!data) return;
// print data
for(i=0; i<nBytes; i++)
{
LCDsendChar(data[i]);
}
}
void LCDGotoXY(uint8_t x, uint8_t y) //Cursor to X Y position
{
register uint8_t DDRAMAddr;
switch(y)
{
case 0: DDRAMAddr = LCD_LINE0_DDRAMADDR+x; break;
case 1: DDRAMAddr = LCD_LINE1_DDRAMADDR+x; break;
case 2: DDRAMAddr = LCD_LINE2_DDRAMADDR+x; break;
case 3: DDRAMAddr = LCD_LINE3_DDRAMADDR+x; break;
default: DDRAMAddr = LCD_LINE0_DDRAMADDR+x;
}
// set data address
LCDsendCommand(1<<LCD_DDRAM | DDRAMAddr);
}
void CopyStringtoLCD(const uint8_t *FlashLoc, uint8_t x, uint8_t y)
{
uint8_t i;
LCDGotoXY(x,y);
for(i=0;(uint8_t)pgm_read_byte(&FlashLoc[i]);i++)
{
LCDsendChar((uint8_t)pgm_read_byte(&FlashLoc[i]));
}
}
void LCDdefinechar(const uint8_t *pc,uint8_t char_code){
uint8_t a, pcc;
uint16_t i;
a=(char_code<<3)|0x40;
for (i=0; i<8; i++){
pcc=pgm_read_byte(&pc[i]);
LCDsendCommand(a++);
LCDsendChar(pcc);
}
}
void LCDshiftLeft(uint8_t n) //Scrol n of characters Right
{
for (uint8_t i=0;i<n;i++)
{
LCDsendCommand(0x1E);
}
}
void LCDshiftRight(uint8_t n) //Scrol n of characters Left
{
for (uint8_t i=0;i<n;i++)
{
LCDsendCommand(0x18);
}
}
void LCDcursorOn(void) //displays LCD cursor
{
LCDsendCommand(0x0E);
}
void LCDcursorOnBlink(void) //displays LCD blinking cursor
{
LCDsendCommand(0x0F);
}
void LCDcursorOFF(void) //turns OFF cursor
{
LCDsendCommand(0x0C);
}
void LCDblank(void) //blanks LCD
{
LCDsendCommand(0x08);
}
void LCDvisible(void) //Shows LCD
{
LCDsendCommand(0x0C);
}
void LCDcursorLeft(uint8_t n) //Moves cursor by n poisitions left
{
for (uint8_t i=0;i<n;i++)
{
LCDsendCommand(0x10);
}
}
void LCDcursorRight(uint8_t n) //Moves cursor by n poisitions left
{
for (uint8_t i=0;i<n;i++)
{
LCDsendCommand(0x14);
}
}
int main(void)
{ int temp;
int result;
DDRB = 0XFF;
// Blink Led
for (int i = 0; i<5; i++)
{
_delay_ms(10);
PORTB ^= 1;
_delay_ms(10);
PORTB ^= 1;
}
LCDinit();
LCDcursorOnBlink();
LCDGotoXY(2,0);
LCDstring("Test",4);
GICR |=0X80; //ext. IR1 aktivated
SREG |=0X80; //Global IR enable
ISR(INT1_vect)
{
DDRC = 0xF0;
PORTC = 0xF0;
_delay_us(100);
switch PINC
{
case 1:
temp = 0;
break;
case 2:
temp = 1;
break;
case 4:
temp = 2;
break;
case 8:
temp = 3;
break;
}
//swap portc
DDRC = 0X0F;
PORTC = 0X0F;
_delay_us(100);
switch PINC
{
case 16:
temp += 0;
break;
case 32:
temp += 4;
break;
case 64:
temp += 8;
break;
case 128:
temp += 12;
break;
}
result = temp;
LCDinit();
LCDsendChar(result);
}
return 0;
}
//
mình sử dụng quét phím và hiển thị lên LCD, hoi dài một chút, mọi người giúp mình nhé!
:-B
Comment
-
Mình không xem code của cậu nhưng nhìn chung thì có thể là vấn đề nằm ở 1 số lib mà cậu include nó có thể không có code macro hạn chế việc định nghĩa lại.
Có thể cậu xem xem lcd_lib của cậu
có thê vấn đề ở đó vì các thư việc của WINAVR thường đã có macro hạn chế rồi.
Sông dài, Thuyền lớn, Biển rộng bao la.
Tháo neo ngôn ngữ, lèo lái con thuyền kiến thức nhân loại.
Comment
Bài viết mới nhất
Collapse
-
Trả lời cho Xin hỏi về mạch thu FM/AM trong catsettebởi nguyendinhvanTheo tôi, nó chỉ là cái Tuy- ê - nơ, hoặc là khối Trung Văn Tần, nó một phần trong cái Da đì ô thôi. Vì có thấy một chỗ có ba chân hàn, giiống như chân Cờ rít sờ tăng 455 ki nô hẹc. Còn khối Tuy ê nơ thì không nhìn thây cái Di ốt Va di cáp...
-
Channel: Điện thanh
hôm nay, 19:59 -
-
Trả lời cho Đấu tắt điện cho máy tính bảngbởi afrendlyCó vẻ ngoài hiểu biết của mình rồi. Cuối cùng mình quyết định tìm mua 2 pin trên Shopee, giá 200K thay vào. Tuy nhận pin được 1%, sạc mãi không vào nhưng cũng mở được máy lên. Vậy cũng tạm. Cảm ơn bạn đã hỗ trợ nhé....
-
Channel: Thiết bị điện tử cá nhân
Hôm qua, 01:27 -
-
Trả lời cho Máy điện châm ?bởi nick22Đúng như bạn nói, máy điện châm hiện nay trên thị trường đã khá đa dạng về mẫu mã, chức năng và giá thành.
-
Channel: Điện tử y sinh
01-12-2025, 13:23 -
-
Trả lời cho Làm thế nào để check IC LM358bởi thetungĐể check IC sống hay chết thì đơn giản : bạn lắp cái mạch ( khuếch đại hoặc dao động ) chạy bằng con IC đó ,nhưng vị trí IC thì lắp cái đế .... thế là cứ cắm rút thì biết . Còn không thì kiếm cái này : https://shopee.vn/Xu-M%C3%A1y-ki%E1%...di-%C4%91%E1%B...
-
Channel: Hướng dẫn tìm thông tin linh kiện
28-11-2025, 14:34 -
-
bởi ngochung90Tình hình là em có mua mạch 3s về để hàn vào khối pin 12v, hàn xong em đo tại các chân từ B-, B1, B2, B+ thì điện áp pin vẫn đủ 12,6v, nhưng tại 2 chân ra P- P+ thì đo chỉ được 6,3v là bị sao các bác, và chân P- P + này đồng thời là chân sạc xả thì mình cắm sạc xả cùng lúc được ko ạ
...-
Channel: Điện tử dành cho người mới bắt đầu
28-11-2025, 10:32 -
-
Trả lời cho Làm thế nào để check IC LM358bởi nguyendinhvanViệc đó tùy thuộc trình độ khoa học kỹ thuật công nghệ ứng dụng hiện tại thôi.
Trong datasheet,họ đưa ra nhiều thông số. Tùy theo khả năng , và những thông số họ cần, họ sẽ kiểm tra casc số đo có khớp với số liệu trong datasheet...-
Channel: Hướng dẫn tìm thông tin linh kiện
27-11-2025, 18:00 -
-
bởi kqbn9091Em có mạch AT89s8253 đang cần sửa số serial no của CHIP mà giờ lâu quá rồi không dùng keil nên không biết phải làm sao, trong khi chỉ còn file hex. Mạch nạp thì progris khi viết không sửa được số serial của IC. Rất cần bác nào còn làm về 89...
-
Channel: Vi điều khiển họ 8051
27-11-2025, 11:13 -
-
bởi Thần ChếtChào các chuyên gia.
có cách nào để kiểm tra IC op-amp như LM324, 358, 393 sống hay đã chết không các bác?. Tìm mãi trên mạng mà không có thoing tin nào.
rất mong các chuyên gia chia sẻ ạ-
Channel: Hướng dẫn tìm thông tin linh kiện
26-11-2025, 03:30 -

Comment