Khái quát giao diện I2C

Một phần của tài liệu THiết kế lịch vạn niên điện tử (Trang 38 - 41)

II. ĐỒNG HỒ THỜI GIAN THỰC

2. Khái quát giao diện I2C

I2C là viết tắc của từ Inter - Integrated Circuit là một chuẩn truyền thơng nối tiếp đồng bộ do hãng điện tử Philips Semiconductor sáng lập và xây dựng thành chuẩn năm 1990.

Các khái niệm cơ bản trong giao diện I2C:

Master (chip chủ): là chip khởi động quá trình truyền nhận, phát đi địa chỉ của thiết bị cần giao tiếp và tạo xung giữ nhịp trên đường SCL.

Slave (chip tớ): là chip cĩ một địa chỉ cố định, được gọi bởi Master và phục vụ yêu cầu từ Master.

SDA (Serial Data): là đường dữ liệu nối tiếp, tất cả các thơng tin về địa chỉ hay dữ liệu đều được truyền trên đường này theo thứ tự từng bit một. Chú ý là trong chuẩn I2C, bit cĩ trọng số lớn nhất (MSB) được truyền đi trước nhất.

SCL (Serial Clock): là đường xung giữ nhịp nối tiếp. I2C là chuần truyền thơng nối tiếp đồng bộ, cần cĩ 1 đường tạo xung giữ nhịp cho quá trình truyền/nhận, cứ mỗi xung trên đường giữ nhịp SCL, một bit dữ liệu trên đường SDA sẽ được lấy mẫu (sample). Dữ liệu nối tiếp trên đường SDA được lấy mẫu khi đường SCL ở mức cao trong một chu kỳ giữ nhịp, vì thế đường SDA khơng được đổi trạng thái khi SCL ở mức cao (trừ điều kiện START và STOP). Chân SDA cĩ thể được đổi trạng thái khi SCL ở mức thấp.

Một giao tiếp I2C gồm cĩ 2 dây: Serial Data (SDA) và Serial Clock (SCL). SDA là đường truyền dữ liệu theo 2 hướng (từ master đến slave và ngược lại), cịn SCL là đường truyền xung đồng hồ chỉ truyền theo một hướng (từ master đến slave).

Trong một giao diện I2C thì cĩ một thiết bị là chủ (master) và một thiết bị là tớ (slave). Tại sao lại cĩ sự phân biệt này? Đĩ là vì trên một giao diện I2C thì quyền điều khiển thuộc về thiết bị chủ. Thiết bị chủ nắm vai trị tạo xung đồng bộ cho tồn hệ thống, khi giữa 2 thiết bị chủ/tớ giao tiếp thì thiết bị chủ cĩ nhiệm vụ tạo ra xung đồng bộ và quản lý đến thiết bị tớ trong suốt quá trình giao tiếp. Thiết bị chủ giữ vai trị chủ động, cịn thiết bị tớ giữ vai trị bị động trong quá trình giao tiếp.

Một giao diện I2C cĩ thể hoạt động ở nhiều chế độ khác nhau: - Một chủ một tớ (one master – one slave)

- Một chủ nhiều tớ (one master – multi slave) - Nhiều chủ nhiều tớ (Multi master – multi slave)

Vài điều kiện cần biết khi thiết lập một giao tiếp I2C:

- Điều kiện START (gọi tắt là S): điều kiện START được thiết lập khi cĩ một sự chuyển đổi trạng thái từ cao xuống thấp tại SDA, khi SCL đang ở mức cao (mức cao là 1, mức thấp là 0).

- Điều kiện STOP (gọi tắt là P): điều kiện STOP được thiết lập khi cĩ một sự chuyển đổi trạng thái từ thấp lên cao tại SDA, khi SCL đang ở mức cao.

- Điều kiện REPEAT START (bắt đầu lặp lại): khoảng giữa điều kiện START và STOP là khoảng bận của đường truyền, các master khác khơng tác động được vào đường truyền trong khoảng này. Trường hợp sau khi kết thúc quá trình truyền/nhận mà master khơng gởi điều kiện STOP lại gởi thêm 1 điều kiện START gọi là REPEAT START. Khả năng này thường được dùng khi master muốn lấy dữ liệu liên tiếp từ các Slaves.

- Bit ACK: dùng để báo hiệu dữ liệu đã được nhận, bit ACK được tạo ra tại thời điểm xung clock thứ 9 bằng cách kéo chân SDA xuống mức thấp.

- Bit NACK: dùng để báo hiệu dữ liệu đã bị lỗi hoặc byte truyền cuối cùng, bit NACK cũng được tạo ra tại thời điểm xung clock thứ 9 bằng cách kéo chân SDA lên mức cao.

Bit ACK/NACK trong giao din I2C

Định dạng dữ liệu truyền:

Dữ liệu được truyền trên bus I2C theo từng bit, bit dữ liệu được truyền đi tại mỗi sườn lên của xung đồng hồ trên đường dây SCL, quá trình thay đổi bit dữ liệu xảy ra khi SCL đang ở mức thấp.

Quá trình truyn nhn 1 bit d liu

Mỗi byte dữ liệu được truyền cĩ độ dài là 8 bit. Số byte cĩ thể truyền trong một lần là khơng hạn chế. Mỗi byte được truyền đi theo sau là một bit ACK, bit cĩ trong số lớn nhất (MSB) sẽ được truyền đi đầu tiên, các bit kế tiếp sẽ được truyền đi lần lượt. Sau 8 xung clock thì dữ liệu đã được truyền đi, ở xung clock thứ 9 thì bit ACK được truyền đi báo hiệu đã nhận đủ 8 bits. Thiết bị truyền sau khi nhận được bit ACK sẽ tiếp tục thực hiện quá trình truyền hoặc kết thúc.

D liu được truyn trên giao din I2C

Một byte truyền đi cĩ kèm theo bit ACK là điều kiện bắt buộc, nhằm đảm bảo cho quá trình truyền nhận được chính xác. Khi khơng nhận được đúng địa chỉ hay muốn kết thúc quá trình giao tiếp, thiết bị nhận sẽ gởi một xung Not_ACK (NACK) để báo cho thiết bị chủ biết. Thiết bị chủ sẽ tạo ra xung STOP để kết thúc hay lặp lại một xung START để bắt đấu quá trình mới.

Một phần của tài liệu THiết kế lịch vạn niên điện tử (Trang 38 - 41)

Tải bản đầy đủ (PDF)

(106 trang)