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:
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); }
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
-
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);
LDPch&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);
LDPcmd&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
-
bởi bqvietServo cuối cùng vẫn chỉ là điều chỉnh tốc độ và đọc phản hồi vị trí
Qua cổng song song LPT cổ
https://www.electronicsforu.com/elec...eed-controller
Qua cổng USB - xem thêm đám FT232RL-
Channel: Điện tử công nghiệp
22-11-2024, 15:56 -
-
bởi thiennam0703Em đang tìm hiểu cách xây dựng chương trình điều khiển động cơ Servo Yaskawa bằng máy tính tuy nhiên khi tìm kiếm trên mạng các hướng dẫn thì thường là điều khiển bằng vi điều khiển hoặc điều khiển bằng PLC hay điều khiển động cơ...
-
Channel: Điện tử công nghiệp
22-11-2024, 15:32 -
-
Trả lời cho Tổng hợp các thông tin về mạch nạp cho AVRbởi bacthoMình cũng bị như vậy mà chưa biết ở đâu
-
Channel: Vi điều khiển AVR
21-11-2024, 21:00 -
-
Trả lời cho Xin hỏi về màn hình laptopbởi nhathung1101Câu trả lời là không dùng được.
Hai lớp dán mặt trước và mặt sau, gọi là film phân cực. Muốn hiểu rõ về nó thì chịu khó search nhé. Ở đây có rất nhiều chó cứ ngửi thấy phân là sủa nhặng, nên không giải thích nhiều....-
Channel: Thiết bị điện tử cá nhân
21-11-2024, 16:20 -
-
Comment on Tổng hợp các thông tin về mạch nạp cho AVRbởi Memem
-
Channel: Vi điều khiển AVR
21-11-2024, 15:10 -
-
Trả lời cho Tổng hợp các thông tin về mạch nạp cho AVRbởi MememMọi người ơi cho em hỏi cái này ạ, hiện tại em đang làm btl về hiển thị giá trị nhiệt độ trên led 7 thanh sử dụng atmega16, code em chạy trên mô phỏng rất oke nhưng khi lắp qua mạch thực thì bị lỗi ở led đầu tiên bị lỗi như thế này...
-
Channel: Vi điều khiển AVR
21-11-2024, 15:10 -
-
bởi mantruongepuNhờ cả nhà tìm giúp mình thông tin IC này với, thấy ghi 943B W58BAL mà mình tìm mấy ngày nay không được, nó được đóng gói dạng TSSOP 8. Cám ơn cả nhà....
-
Channel: Điện tử dành cho người mới bắt đầu
20-11-2024, 14:40 -
-
bởi TherulCảm ơn bạn đã chia sẻ câu chuyện và quá trình phát triển sản phẩm của mình. Trước tiên, thật may mắn khi bạn vượt qua tai nạn và vẫn giữ được niềm đam mê cũng như khả năng sáng tạo trong lĩnh vực kỹ thuật. Việc bạn tiếp tục...
-
Channel: từ PIC tới dsPIC
20-11-2024, 07:20 -
-
Trả lời cho Em muốn hỏi mọi người về nguyên lý hoạt động, tần số của mạch công suất trong máy rửa siêu âm ạ.bởi nguyendinhvanBạn nên nghiên cứu cái chấn lưu đèn ống Compact fluorescent lamp hay đèn compact trước đã. Nó rẻ đỡ tốn kém.
Sau khi hiểu rõ rồi thì chuyển sang cái mạch này.
Ở cái chấn lưu, tần số của nó linh tinh lắm, tùy điện áp nguồn, tùy...-
Channel: Hỗ trợ học tập
19-11-2024, 22:44 -
Comment