PIC Vietnam

Go Back   PIC Vietnam > Microchip PIC > Cơ bản về vi điều khiển và PIC

Tài trợ cho PIC Vietnam
Trang chủ Đăng Kí Hỏi/Ðáp Thành Viên Lịch Bài Trong Ngày Vi điều khiển

Cơ bản về vi điều khiển và PIC Những bài hướng dẫn cơ bản nhất để làm quen với vi điều khiển PIC

Trả lời
 
Ðiều Chỉnh Xếp Bài
Old 12-12-2006, 07:43 PM   #16
hanspkt
Đệ tử 3 túi
 
Tham gia ngày: Aug 2006
Bài gửi: 55
:
Các anh cho em hỏi, sao bộ tiny bootloader em tự làm nó đã hoạt động sau một thời gian rồi ngưng luôn. Em đã kiểm tra phần cứng thì không có gặp vấn đề gì. Em sử dụng file hex có sẵn kèm theo phần mềm và em cũng đã làm theo hướng dẫn của các anh rồi mà nó cũng không hoạt động (em đang sử dụng ngon lành thì gặp vấn đề).
File Kèm Theo
File Type: rar tinybld191.rar (634.9 KB, 32 lần tải)
hanspkt vẫn chưa có mặt trong diễn đàn   Trả Lời Với Trích Dẫn
Old 13-12-2006, 12:24 AM   #17
namqn
Trưởng lão PIC bang
 
Tham gia ngày: Feb 2006
Nơi Cư Ngụ: Tp. HCM, Việt Nam
Bài gửi: 3,025
:
Send a message via Yahoo to namqn
Trích:
Nguyên văn bởi hanspkt View Post
Các anh cho em hỏi, sao bộ tiny bootloader em tự làm nó đã hoạt động sau một thời gian rồi ngưng luôn. Em đã kiểm tra phần cứng thì không có gặp vấn đề gì. Em sử dụng file hex có sẵn kèm theo phần mềm và em cũng đã làm theo hướng dẫn của các anh rồi mà nó cũng không hoạt động (em đang sử dụng ngon lành thì gặp vấn đề).
Trong khoảng thời gian mà nó đã hoạt động, bạn nạp chương trình vào chip được mấy lần? Cấu hình của chương trình ứng dụng có giống với cấu hình của bootloader không?

Thân,
__________________
Biển học mênh mông, sức người có hạn.

Đang gặp vấn đề cần được giúp đỡ? Hãy dành ra vài phút đọc luồng sau:
http://www.picvietnam.com/forum/showthread.php?t=1263
namqn vẫn chưa có mặt trong diễn đàn   Trả Lời Với Trích Dẫn
Old 13-12-2006, 12:13 PM   #18
phamthaihoa
Đệ tử 3 túi
 
Tham gia ngày: Jun 2005
Bài gửi: 56
:
Trích:
Nguyên văn bởi hanspkt View Post
Các anh cho em hỏi, sao bộ tiny bootloader em tự làm nó đã hoạt động sau một thời gian rồi ngưng luôn. Em đã kiểm tra phần cứng thì không có gặp vấn đề gì. Em sử dụng file hex có sẵn kèm theo phần mềm và em cũng đã làm theo hướng dẫn của các anh rồi mà nó cũng không hoạt động (em đang sử dụng ngon lành thì gặp vấn đề).
Bạn kiểm tra một số điểm sau:
- Nguồn trên mạch của bạn, nếu nguồn không ổn định thì PIC reset liên tục, có giời mới chạy nổi , bạn thử nạp một chương trình thông qua ICSP xem PIC có chạy không đã.
- Kiểm tra hoạt động Reset, nếu bạn làm nút reset cứng trên mạch thì không sao, nếu Reset qua chân 9 của MAX232 hay từ chân 7 cổng COM thì nên kiểm tra cho chắc. Kiểm tra tín hiệu Reset trên Tiny luôn
- Kiểm tra cổng COM, đúng cổng chưa, baud rate thế nào. Có xung động gì không, bạn vào Task Manager tắt thử file xcommsvr.exe, tắt các chương trình tường lửa rồi thử lại.
- Bạn nạp lại file boot vào PIC, file chuẩn của nó ấy, 876A_20Mhz_115200, đừng nạp bất cứ file đã được modified nào khác.
-Nếu chương trình của bạn có sử dụng USART thì nên thử lại vài lần.

Thông thường rất khó do lỗi phần mềm, trừ trường hợp bạn tự ghi vào Flash. Còn Bootloader không chạy chủ yếu do phần cứng thôi.
phamthaihoa vẫn chưa có mặt trong diễn đàn   Trả Lời Với Trích Dẫn
Old 14-12-2006, 08:47 PM   #19
hanspkt
Đệ tử 3 túi
 
Tham gia ngày: Aug 2006
Bài gửi: 55
:
Em đã làm các bước như trên rồi mà vẫn không hoạt động. Phần cứng em kiểm tra rồi, nó bình thường. Trước khi nó ngưng hoạt động, bạn của em có đem con pic của bạn ấy qua thử không được rồi từ đó nó ngừng luôn. Nhưng em mới phát hiện là hình như con PIC nó hư hay sao ấy, em nạp chương trình em viết hồi trước đã hoạt động bây giờ thì nín luôn, không có chương trình nào hoạt động. À, lâu lâu khi em đụng vào dây bus thì nó hoạt động một tí rồi ngưng. Mong các anh chỉ dẫn (Có phải em đã nạp nhiều lần quá không ạ ?)
Cám ơn các anh nhiều!
hanspkt vẫn chưa có mặt trong diễn đàn   Trả Lời Với Trích Dẫn
Old 14-12-2006, 09:43 PM   #20
namqn
Trưởng lão PIC bang
 
Tham gia ngày: Feb 2006
Nơi Cư Ngụ: Tp. HCM, Việt Nam
Bài gửi: 3,025
:
Send a message via Yahoo to namqn
Tôi không tin là phần cứng không có vấn đề gì. Bạn chịu khó post sơ đồ phần cứng của bạn lên đây. Tôi nghĩ phần mạch nối với chân MCLR có vấn đề.

Thân,
__________________
Biển học mênh mông, sức người có hạn.

Đang gặp vấn đề cần được giúp đỡ? Hãy dành ra vài phút đọc luồng sau:
http://www.picvietnam.com/forum/showthread.php?t=1263
namqn vẫn chưa có mặt trong diễn đàn   Trả Lời Với Trích Dẫn
Old 20-12-2006, 02:37 PM   #21
hanspkt
Đệ tử 3 túi
 
Tham gia ngày: Aug 2006
Bài gửi: 55
:
Em phát hiện ra do bạn em đổi con PIC của em. Mà nó lạ lắm, nạp vào ào ào mà không có chương trình nào chạy, chương trình nạp vẫn nhận dạng được con PIC, lúc nạp không báo lỗi mà lại .....
hanspkt vẫn chưa có mặt trong diễn đàn   Trả Lời Với Trích Dẫn
Old 20-12-2006, 06:52 PM   #22
namqn
Trưởng lão PIC bang
 
Tham gia ngày: Feb 2006
Nơi Cư Ngụ: Tp. HCM, Việt Nam
Bài gửi: 3,025
:
Send a message via Yahoo to namqn
Trích:
Nguyên văn bởi hanspkt View Post
Em phát hiện ra do bạn em đổi con PIC của em. Mà nó lạ lắm, nạp vào ào ào mà không có chương trình nào chạy, chương trình nạp vẫn nhận dạng được con PIC, lúc nạp không báo lỗi mà lại .....
Vậy có lẽ chương trình ứng dụng được viết không tương thích với tiny bootloader (cần có một lệnh nhảy đến chương trình chính trong 4 word đầu tiên của Flash), hoặc chương trình ứng dụng có lỗi.

Thân,
__________________
Biển học mênh mông, sức người có hạn.

Đang gặp vấn đề cần được giúp đỡ? Hãy dành ra vài phút đọc luồng sau:
http://www.picvietnam.com/forum/showthread.php?t=1263
namqn vẫn chưa có mặt trong diễn đàn   Trả Lời Với Trích Dẫn
Old 17-06-2007, 03:11 PM   #23
mgdaubo
Đệ tử 1 túi
 
Tham gia ngày: Oct 2006
Bài gửi: 19
:
Cho em hỏi: khi ta compline ra file hex thì kích thước của file hex đó nhìn thấy trong máy vi tính đó (tính bằng byte) có phải là kích thước thật khi ta nạp vào pic ko?
trong datasheet của 16f84 có ghi là flash = 1K words, vậy file hex tối đa có thể là bao nhiêu byte ?
dùng C viết chương trình thì hình như kích thước lớn hơn so với dùng ASM khá nhiều ?
mgdaubo vẫn chưa có mặt trong diễn đàn   Trả Lời Với Trích Dẫn
Old 17-06-2007, 09:17 PM   #24
namqn
Trưởng lão PIC bang
 
Tham gia ngày: Feb 2006
Nơi Cư Ngụ: Tp. HCM, Việt Nam
Bài gửi: 3,025
:
Send a message via Yahoo to namqn
Trích:
Nguyên văn bởi mgdaubo View Post
Cho em hỏi: khi ta compline ra file hex thì kích thước của file hex đó nhìn thấy trong máy vi tính đó (tính bằng byte) có phải là kích thước thật khi ta nạp vào pic ko?
trong datasheet của 16f84 có ghi là flash = 1K words, vậy file hex tối đa có thể là bao nhiêu byte ?
dùng C viết chương trình thì hình như kích thước lớn hơn so với dùng ASM khá nhiều ?
Bạn có 3 câu hỏi, tôi trả lời lần lượt như sau:
- Kích thước của file .hex khi nhìn trong máy tính không phải là kích thước thật của chương trình khi nạp vào PIC

- Bạn xem giải thích của tôi ở tutorial ngắn trong post #38 của luồng này: http://www.picvietnam.com/forum/showthread.php?t=5

- Thông thường các chương trỉnh viết trong C có thực hiện liên kết với một số thư viện, cũng như gọi một số chương trình con khởi tạo, do đó kích thước của chương trình được dịch ra thường lớn hơn so với khi viết chương trình bằng asm

Thân,
__________________
Biển học mênh mông, sức người có hạn.

Đang gặp vấn đề cần được giúp đỡ? Hãy dành ra vài phút đọc luồng sau:
http://www.picvietnam.com/forum/showthread.php?t=1263
namqn vẫn chưa có mặt trong diễn đàn   Trả Lời Với Trích Dẫn
Old 18-06-2007, 09:07 PM   #25
mgdaubo
Đệ tử 1 túi
 
Tham gia ngày: Oct 2006
Bài gửi: 19
:
em mới mò mẫm mấy cái datasheet và nhận ra là hình như 1 word = 14 bit?

trong tut ngắn đó anh namqn có viết: "Các chip PIC16 với bộ nhớ 8 kword, chẳng hạn như 16F877A, có 4 trang bộ nhớ Flash, mỗi trang là 2 kword. Nếu chương trình tràn khỏi biên của một trang thì người viết chương trình phải tự đảm bảo là các lệnh nhảy có thể thực hiện thành công, do đó trình biên dịch thường có thông báo nhắc nhở." Vậy ngươi lập trình phải làm thế nào để đảm bảo?

qua tut đó, ta có thể ước lượng được kích thước file hex qua số dòng lệnh, nhưng nếu dùng C thì làm sao biết được số dòng lệnh hả anh? có cách nào tính nhanh kích thước thực sự của file hex nạp vào pic ko? vấn đề kích thước chương trình là rất quan trọng
mgdaubo vẫn chưa có mặt trong diễn đàn   Trả Lời Với Trích Dẫn
Old 18-06-2007, 11:38 PM   #26
namqn
Trưởng lão PIC bang
 
Tham gia ngày: Feb 2006
Nơi Cư Ngụ: Tp. HCM, Việt Nam
Bài gửi: 3,025
:
Send a message via Yahoo to namqn
Trích:
Nguyên văn bởi mgdaubo View Post
em mới mò mẫm mấy cái datasheet và nhận ra là hình như 1 word = 14 bit?

trong tut ngắn đó anh namqn có viết: "Các chip PIC16 với bộ nhớ 8 kword, chẳng hạn như 16F877A, có 4 trang bộ nhớ Flash, mỗi trang là 2 kword. Nếu chương trình tràn khỏi biên của một trang thì người viết chương trình phải tự đảm bảo là các lệnh nhảy có thể thực hiện thành công, do đó trình biên dịch thường có thông báo nhắc nhở." Vậy ngươi lập trình phải làm thế nào để đảm bảo?

qua tut đó, ta có thể ước lượng được kích thước file hex qua số dòng lệnh, nhưng nếu dùng C thì làm sao biết được số dòng lệnh hả anh? có cách nào tính nhanh kích thước thực sự của file hex nạp vào pic ko? vấn đề kích thước chương trình là rất quan trọng
Đa số PIC16 và một số PIC12 có 1 word = 14 bit, một số PIC16, PIC12, và các PIC10 có 1 word = 12 bit, và tất cả PIC18 có 1 word = 16 bit. Trong tất cả các trường hợp trên, một word của bộ nhớ chương trình trong PIC cần được lưu bằng 2 byte trong tập tin .hex.

Để đảm bảo việc chuyển điều khiển trong các PIC có từ 2 trang bộ nhớ chương trình trở lên, người lập trình chủ động đặt các chương trình con có liên quan nằm ở 1 trang nhất định, và những lệnh chuyển điều khiển có khả năng thay đổi trang thì phải có thao tác xử lý PCLATH thích hợp ngay trước những lệnh đó.

Đa số các phần mềm biên dịch ngôn ngữ cấp cao cho biết kích thước của chương trình đã được biên dịch, sau khi biên dịch xong. Điều quan trọng nhất là chương trình được dịch ra có nằm lọt trong không gian bộ nhớ chương trình của PIC hay không, chứ không phải chương trình hay tập tin hex có kích thước lớn hay nhỏ.

Thân,
__________________
Biển học mênh mông, sức người có hạn.

Đang gặp vấn đề cần được giúp đỡ? Hãy dành ra vài phút đọc luồng sau:
http://www.picvietnam.com/forum/showthread.php?t=1263
namqn vẫn chưa có mặt trong diễn đàn   Trả Lời Với Trích Dẫn
Old 19-06-2007, 12:25 AM   #27
falleaf
PIC Bang chủ
 
falleaf's Avatar
 
Tham gia ngày: May 2005
Bài gửi: 2,631
:
Send a message via Yahoo to falleaf
Cách tính ước lượng bằng số dòng lệnh đã có từ lâu khi lập trình bằng 8051.

Bạn cứ hình dung rằng, cứ một dòng lệnh thì nó lưu vào 1 word. Khi đó, từ số dòng lệnh (nhìn ngay trên phần code của bạn), bạn có thể ước lượng được rằng chương trình của bạn chiếm bao nhiêu % dung lượng nhớ. Chúng ta có thể tính sơ bộ với 8KWord thì có thể viết được khoảng 7 - 8000 dòng lệnh.

Đó là cách ước lượng đơn giản nhất của người lập trình ASM.

Chúc vui
falleaf vẫn chưa có mặt trong diễn đàn   Trả Lời Với Trích Dẫn
Old 19-06-2007, 11:51 AM   #28
mgdaubo
Đệ tử 1 túi
 
Tham gia ngày: Oct 2006
Bài gửi: 19
:
em chưa hiểu lắm về bộ nhớ trong PIC:
Bộ nhớ Flash: bộ nhớ chương trình ?
Data memories: có phải là Ram lưu các biến sử dụng trong chương trình?
EEPROM dùng để làm gì?
mgdaubo vẫn chưa có mặt trong diễn đàn   Trả Lời Với Trích Dẫn
Old 19-06-2007, 06:04 PM   #29
namqn
Trưởng lão PIC bang
 
Tham gia ngày: Feb 2006
Nơi Cư Ngụ: Tp. HCM, Việt Nam
Bài gửi: 3,025
:
Send a message via Yahoo to namqn
Trích:
Nguyên văn bởi mgdaubo View Post
em chưa hiểu lắm về bộ nhớ trong PIC:
Bộ nhớ Flash: bộ nhớ chương trình ?
Data memories: có phải là Ram lưu các biến sử dụng trong chương trình?
EEPROM dùng để làm gì?
Bộ nhớ flash chính là bộ nhớ chương trình, flash là công nghệ hiện thực bộ nhớ. Vì bộ nhớ này cần phải lưu thông tin ngay cả khi chip mất nguồn, nên nó là một loại ROM (Read Only Memory).

Data memory (bộ nhớ dữ liệu) chính là các ô nhớ đọc/ghi ngẫu nhiên, viết tắt là RAM (Random Access Memory), thường dùng làm biến, các thanh ghi đặc biệt trong chip.

EEPROM là bộ nhớ dữ liệu nhưng có khả năng lưu thông tin ngay cả khi chip mất nguồn. Vì chương trình thực hiện đọc/ghi trên ô nhớ của vùng này nên nó phải thuộc loại ghi/xóa bằng điện (Electrically Erasable Programmable Read Only Memory. EEPROM thường dùng để lưu các hằng số, các hệ số hiệu chỉnh cho từng bộ điều khiển. Ví dụ, một bộ điều khiển PID sau khi tự động cân chỉnh với một đối tượng cụ thể có thể lưu các hệ số kp, ki, kd vào EEPROM, như vậy ngay cả khi bộ vi điều khiển bị ngắt nguồn thì các hệ số này vẫn không bị mất, và bộ điều khiển có thể dùng ngay các hệ số này mà không cần phải cân chỉnh khi khởi động ở những lần sau.

EEPROM khó hiện thực và đắt tiền hơn Flash, do đó chỉ được hiện thực với dung lượng nhỏ trong chip, tất nhiên nó có lợi thế là số lần ghi/xóa thường cao hơn khoảng 10 lần so với flash. Một khác biệt chính là flash cần phải xóa theo khối (vài chục byte) và cũng thường ghi theo khối, còn EEPROM thì có thể xóa/ghi từng ô độc lập.

Thân,
__________________
Biển học mênh mông, sức người có hạn.

Đang gặp vấn đề cần được giúp đỡ? Hãy dành ra vài phút đọc luồng sau:
http://www.picvietnam.com/forum/showthread.php?t=1263
namqn vẫn chưa có mặt trong diễn đàn   Trả Lời Với Trích Dẫn
Old 24-06-2007, 12:01 PM   #30
mgdaubo
Đệ tử 1 túi
 
Tham gia ngày: Oct 2006
Bài gửi: 19
:
Em đang thử làm 1 mạch nháy led khoảng 0,5s bằng ngắt timer1 của 16f88, chỉ mò trong datasheet rồi tự làm nên gặp lỗi này mà ko biết phải khắc phục sao:
mã nguồn trong file gửi kèm, em thắc mắc chỗ này:

Code:
	ORG 0x0000
	GOTO start
	ORG 0x0004

interrupt
	COMF	PORTA,F 	;dao trang thai portA de kiem tra xem ngat co duoc goi?
	BTFSS	PORTB,0
	BSF	PORTB,0
	BTFSC	PORTB,0
	BCF	PORTB,0
	RETFIE

start
	BCF	STATUS,RP1
	BSF	STATUS,RP0
	BSF	INTCON,7
	BSF	INTCON,6
	BSF	PIE1,0		;TMR1 Overflow Interrupt Enable bit
	CLRF	TRISA
	CLRF	TRISB
	BCF	STATUS,RP0
	CLRF	PORTB
	MOVLW	b'00110101'
	MOVWF	T1CON
	BCF	PIR1,0		; = 1: The TMR1 register overflowed(must be cleared in software)

loop
	BSF	PORTB,7
	CALL	delay1ms
	BCF	PORTB,7
	CALL	delay1ms
	goto	loop
khi dùng debug thì thấy:
1/ Em dùng Xtal 4MHz, prescaler = 1:8 , vậy với timer 16bit này nó phải tràn sau khoảng hơn 500ms chứ, vậy mà nó lại tràn sau khoảng 320ms
2/ nếu để "BCF PIR1,0" trong start thì ở vòng đếm đầu thì bình thường, nhưng sau khi gọi ngắt lần đầu thì hình như những lần ngắt sau ko phải được gọi khi timer tràn mà ngay mỗi khi timer tăng lên 1 (!!! ???)
3/ nếu cut "BCF PIR1,0" paste vào interrupt thì ngắt vẫn được gọi "mỗi khi timer tăng lên 1" nhưng khi gọi ngắt thì chỉ thực hiện có lệnh đầu tiên của ngắt thôi, các lệnh sau ko đc thực hiện!

- sau khi gọi ngắt thì bit INTCON<7> = 0, ta phải tự set lại bít này?
- datasheet ghi: bit RIR1<0> = 1: The TMR1 register overflowed(must be cleared in software); =0: The TMR1 register did not overflow. Vậy mà em để nó =0 hay 1 thì vẫn tràn như thường ?
- "Must be cleared in software" là sao, ta phải tự clear TMR1 register hả?

Anh nào viết lại dùm em 1 mã chương trình hoàn chỉnh để em tham khảo nha, chỉ cần dùng ngắt tràn của timer1 để led nháy 500ms/lần thôi

file nguồn
File Kèm Theo
File Type: zip test p16f88 timer.zip (48.3 KB, 23 lần tải)

thay đổi nội dung bởi: namqn, 24-06-2007 lúc 07:32 PM.
mgdaubo vẫn chưa có mặt trong diễn đàn   Trả Lời Với Trích Dẫn
Trả lời


Quyền Sử Dụng Ở Diễn Ðàn
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is Mở
Smilies đang Mở
[IMG] đang Mở
HTML đang Tắt

Chuyển đến


Múi giờ GMT. Hiện tại là 04:58 AM.


Được sáng lập bởi Đoàn Hiệp
Powered by vBulletin®
Page copy protected against web site content infringement by Copyscape
Copyright © PIC Vietnam