Trích:
|
giúp mình cái hàm nhận xâu ký tự
bên phát mình thực hiện như sau: Code:
itoa(x,10,s);//chuyển số nguyên x thành xâu ký tự Code:
#INT_RDA mình cảm ơn. |
Theo như đoạn code trên, hàm lcd_display_str nhận đối số là một chuỗi do đó chắc chắn nó yêu cầu chuỗi của bạn phải kết thúc = ký tự NULL, chuỗi s1 như trên chưa có ký tự kết thúc.
Bạn nên post cả code của phần phát |
bên phát mình chỉ có hai dòng lệnh vậy thôi vì mình ghép nó vào một chương trình con khác.
Code:
void tonghop_so() hàm lcd_display_str(); là hàm hiển thị một mảng ký tự. Code:
void lcd_display_str(int line, int8 posc, char str[]) |
Trích:
#include <16F877A.h> #byte portb = 0x06 #byte portc = 0x07 #use delay (clock = 20000000) int count=1; #INT_EXT void EXT_LED() { portc=count; count=count+1; delay_us(100); bit_clear(portb,0); } void main() { ext_int_edge(L_TO_H); enable_interrupts(INT_EXT); enable_interrupts(global); set_tris_b(0xff); set_tris_c(0x00); portc=0; bit_set(portb,0); while(1) { } } |
Bác F co CCS 4.038 không post lên cho mọi người nữa. Không biết nó có gì mới+tốt hơn không?
|
cám ơn các bạn rất nhiều
|
giúp mình về cái timer với!!
trong chương trình của mình có sử dụng cả timer và ngắt. Đây là hàm phục vụ ngắt của mình: Code:
#int_RB mình đã thử độc lập riêng timer thì hoàn toàn đúng. mong được mọi người giúp đỡ. mình cảm ơn nhiều. |
CCS C không hỗ trợ reentrant, do đó khi 1 chuơng trình con được gọi đồng thời trong chương trình chính và trong trình phục vụ ngắt thì CCS sẽ sinh mã để tự động che ngắt khi vào chương trình con đó để tránh reentrant.
Với trường hợp của bạn có 2 hiệu ứng làm trễ ngắt timer: Thứ 1: khi vào chương trình con được gọi chung, CCS sẽ che ngắt global, do đó ngắt timer ko đc xảy ra, làm ngắt timer đến trễ so với thực tế. Thứ 2: Trình phục vụ ngắt thay đổi mức trên PORTB của bạn quá dài, vì trong thời gian đang thực thi trình này thì ngắt nói chung và ngắt timer nói riêng ko thể xảy ra, nên làm trễ ngắt timer. Về khái niệm reentrant (vào lại). Bạn có thể tưởng tượng một chương trình con A đang được chạy trong chương trình chính, ngắt xảy ra và A lại đc gọi bởi trình phục vụ ngắt. Lúc này sẽ có một số vấn đề phát sinh: 1 - Không gian bộ nhớ cấp cho các biến của A: nếu linker cấp phát tĩnh các biến này thì coi như tiêu. Với pic16F, cấp phát động bộ nhớ (dùng stack) là điều phức tạp vì hardware ko hỗ trợ nhiều cho truy xuất bộ nhớ gián tiếp, mình ko có thời gian disassembly nhưng tin chắc là CCS ko làm điều này (CCS ko hỗ trợ đệ quy). 2 - Các tác vụ về IO hoặc về biến tốn nhiều chu kỳ máy khi bị ngắt giữa chừng cũng coi như tiêu. |
thanks!!! rat bo ich!
|
thanks anh nhiều!!
nhưng em vẫn chưa hiểu lắm về reentrant. anh có tài liệu j nói về vấn đề này không? vấn đề nữa là trình phục vụ ngắt trên port B của em có lẽ là không rút ngắn được bao nhiêu.vậy có cách nào để tính thời gian ngắt của timer không? |
cho em hỏi một vấn đề nữa nhé.
hiện tại chương trình của em cần thêm một số modul nữa, nhưng khi thêm vào và dịch thì nó thông báo là hết RAM mặc dù trước đó ctrinh mới dùng hết khoảng hơn 60% RAM. có ai biết về vấn đề này xin giúp em với, làm sao để có thể dịch được nhiều hơn? |
Trích:
Về timer, mình nghĩ bạn nên đưa phần quét phím ra chương trình chính, khi có ngắt INT_RB, bạn set cờ báo cho chuơng trình chính kiểm tra phím bấm, lúc này ngắt timer vẫn xảy ra được Trích:
|
mời tìm hiểu về pic cho mình hỏi có cách tạo ra cấu trúc truy nhập kiểu bảng (db ....)như đối với 8051 không .và tổ chức như thế nào/Mong trả lời của các bạn và các tiền bối
|
Trích:
Câu hỏi của bạn nên được post ở luồng cơ bản về PIC và vi điều khiển, và sử dụng hợp ngữ. Bạn có thể đọc tài liệu hướng dẫn của MPASM để thấy có thể dùng DT, DB, và DW để định nghĩa các bảng dữ liệu. Thân, |
Múi giờ GMT. Hiện tại là 04:22 PM. |
Tên diễn đàn: vBulletin Version 3.8.11
Được sáng lập bởi Đoàn Hiệp.
Copyright © PIC Vietnam