Lưu ý
Mục đích của file này là để độc giả tiếng Việt có thể đọc và hiểu tài liệu nhân kernel dễ dàng hơn, không phải để tạo ra một nhánh tài liệu riêng. Nếu bạn có bất kỳ nhận xét hoặc cập nhật nào cho file này, vui lòng thử cập nhật file tiếng Anh gốc trước. Nếu bạn thấy có sự khác biệt giữa bản dịch và bản gốc, hoặc có vấn đề về bản dịch, vui lòng gửi góp ý hoặc patch cho người dịch của file này, hoặc nhờ người bảo trì và người review tài liệu tiếng Việt giúp đỡ.
- Bản gốc:
- Người dịch:
Google Translate (machine translation)
- Phiên bản gốc:
8541d8f725c6
Cảnh báo
Tài liệu này được dịch tự động bằng máy và chưa được review bởi người dịch. Nội dung có thể không chính xác hoặc khó hiểu ở một số chỗ. Khi có sự khác biệt với bản gốc, bản gốc luôn là chuẩn. Bản dịch chất lượng cao (được review) được đặt trong thư mục vi_VN/.
7.10. ioctl VIDIOC_ENCODER_CMD, VIDIOC_TRY_ENCODER_CMD¶
7.10.1. Tên¶
VIDIOC_ENCODER_CMD - VIDIOC_TRY_ENCODER_CMD - Thực thi lệnh mã hóa
7.10.2. Tóm tắt¶
-
VIDIOC_ENCODER_CMD¶
ZZ0000ZZ
-
VIDIOC_TRY_ENCODER_CMD¶
ZZ0000ZZ
7.10.3. Đối số¶
- ZZ0001ZZ
Bộ mô tả tệp được trả về bởi ZZ0000ZZ.
- ZZ0001ZZ
Con trỏ tới cấu trúc ZZ0000ZZ.
7.10.4. Sự miêu tả¶
Các ioctls này điều khiển bộ mã hóa âm thanh/video (thường là MPEG-). ZZ0000ZZ gửi lệnh đến bộ mã hóa, ZZ0001ZZ có thể được sử dụng để thử lệnh mà không cần thực sự thực hiện nó.
Để gửi lệnh, ứng dụng phải khởi tạo tất cả các trường của cấu trúc ZZ0000ZZ và gọi ZZ0001ZZ hoặc ZZ0002ZZ với con trỏ tới cấu trúc này.
Trường ZZ0000ZZ phải chứa mã lệnh. Một số lệnh sử dụng Trường ZZ0001ZZ để biết thêm thông tin.
Sau lệnh STOP, các cuộc gọi ZZ0000ZZ sẽ đọc dữ liệu còn lại được đệm bởi trình điều khiển. Khi bộ đệm trống, ZZ0001ZZ sẽ trả về số 0 và ZZ0002ZZ tiếp theo cuộc gọi sẽ khởi động lại bộ mã hóa.
ZZ0000ZZ hoặc ZZ0001ZZ cuộc gọi sẽ gửi lệnh START ngầm đến bộ mã hóa nếu nó chưa được thực hiện đã bắt đầu chưa. Áp dụng cho cả hai hàng đợi của bộ mã hóa mem2mem.
ZZ0000ZZ hoặc ZZ0001ZZ lệnh gọi của bộ mô tả tệp truyền trực tuyến sẽ gửi STOP ngay lập tức tới bộ mã hóa và tất cả dữ liệu được lưu vào bộ đệm sẽ bị loại bỏ. Áp dụng cho cả hai hàng đợi của bộ mã hóa mem2mem.
Các ioctls này là tùy chọn, không phải tất cả trình điều khiển đều có thể hỗ trợ chúng. Họ đã được giới thiệu trong Linux 2.6.21. Tuy nhiên, chúng bắt buộc đối với mem2mem có trạng thái bộ mã hóa (như được ghi thêm trong ZZ0000ZZ).
-
type v4l2_encoder_cmd¶
__u32 |
|
The encoder command, see Encoder Commands. |
__u32 |
|
Flags to go with the command, see Encoder Command Flags. If no flags are defined for this command, drivers and applications must set this field to zero. |
__u32 |
|
Reserved for future extensions. Drivers and applications must set the array to zero. |
|
0 |
Start the encoder. When the encoder is already running or paused, this command does nothing. No flags are defined for this command. For a device implementing the Memory-to-Memory Stateful Video Encoder Interface, once the drain sequence
is initiated with the |
|
1 |
Stop the encoder. When the For a device implementing the Memory-to-Memory Stateful Video Encoder Interface, the command will initiate
the drain sequence as documented in Memory-to-Memory Stateful Video Encoder Interface. No flags or other
arguments are accepted in this case. Any attempt to invoke the command
again before the sequence completes will trigger an |
|
2 |
Pause the encoder. When the encoder has not been started yet, the
driver will return an |
|
3 |
Resume encoding after a PAUSE command. When the encoder has not
been started yet, the driver will return an |
|
0x0001 |
Stop encoding at the end of the current Group Of Pictures, rather than immediately. Does not apply to Memory-to-Memory Stateful Video Encoder Interface. |
7.10.5. Giá trị trả về¶
Khi thành công, trả về 0, lỗi -1 và biến ZZ0001ZZ được đặt một cách thích hợp. Các mã lỗi chung được mô tả tại Chương ZZ0000ZZ.
- EBUSY
Trình tự thoát của thiết bị triển khai ZZ0000ZZ vẫn đang ở trạng thái tiến bộ. Không được phép đưa ra lệnh bộ mã hóa khác cho đến khi nó hoàn thành.
- EINVAL
Trường ZZ0000ZZ không hợp lệ.
- EPERM
Ứng dụng đã gửi lệnh PAUSE hoặc RESUME khi bộ mã hóa được không chạy.