0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018
0019
0020
0021
0022
0023
0024
0025 #ifndef __RADEON_AUDIO_H__
0026 #define __RADEON_AUDIO_H__
0027
0028 #include <linux/types.h>
0029
0030 #define RREG32_ENDPOINT(block, reg) \
0031 radeon_audio_endpoint_rreg(rdev, (block), (reg))
0032 #define WREG32_ENDPOINT(block, reg, v) \
0033 radeon_audio_endpoint_wreg(rdev, (block), (reg), (v))
0034
0035 struct radeon_audio_basic_funcs
0036 {
0037 u32 (*endpoint_rreg)(struct radeon_device *rdev, u32 offset, u32 reg);
0038 void (*endpoint_wreg)(struct radeon_device *rdev,
0039 u32 offset, u32 reg, u32 v);
0040 void (*enable)(struct radeon_device *rdev,
0041 struct r600_audio_pin *pin, u8 enable_mask);
0042 };
0043
0044 struct radeon_audio_funcs
0045 {
0046 void (*select_pin)(struct drm_encoder *encoder);
0047 struct r600_audio_pin* (*get_pin)(struct radeon_device *rdev);
0048 void (*write_latency_fields)(struct drm_encoder *encoder,
0049 struct drm_connector *connector, struct drm_display_mode *mode);
0050 void (*write_sad_regs)(struct drm_encoder *encoder,
0051 struct cea_sad *sads, int sad_count);
0052 void (*write_speaker_allocation)(struct drm_encoder *encoder,
0053 u8 *sadb, int sad_count);
0054 void (*set_dto)(struct radeon_device *rdev,
0055 struct radeon_crtc *crtc, unsigned int clock);
0056 void (*update_acr)(struct drm_encoder *encoder, long offset,
0057 const struct radeon_hdmi_acr *acr);
0058 void (*set_vbi_packet)(struct drm_encoder *encoder, u32 offset);
0059 void (*set_color_depth)(struct drm_encoder *encoder, u32 offset, int bpc);
0060 void (*set_avi_packet)(struct radeon_device *rdev, u32 offset,
0061 unsigned char *buffer, size_t size);
0062 void (*set_audio_packet)(struct drm_encoder *encoder, u32 offset);
0063 void (*set_mute)(struct drm_encoder *encoder, u32 offset, bool mute);
0064 void (*mode_set)(struct drm_encoder *encoder,
0065 struct drm_display_mode *mode);
0066 void (*dpms)(struct drm_encoder *encoder, bool mode);
0067 };
0068
0069 int radeon_audio_init(struct radeon_device *rdev);
0070 void radeon_audio_detect(struct drm_connector *connector,
0071 struct drm_encoder *encoder,
0072 enum drm_connector_status status);
0073 u32 radeon_audio_endpoint_rreg(struct radeon_device *rdev,
0074 u32 offset, u32 reg);
0075 void radeon_audio_endpoint_wreg(struct radeon_device *rdev,
0076 u32 offset, u32 reg, u32 v);
0077 struct r600_audio_pin *radeon_audio_get_pin(struct drm_encoder *encoder);
0078 void radeon_audio_fini(struct radeon_device *rdev);
0079 void radeon_audio_mode_set(struct drm_encoder *encoder,
0080 struct drm_display_mode *mode);
0081 void radeon_audio_dpms(struct drm_encoder *encoder, int mode);
0082 unsigned int radeon_audio_decode_dfs_div(unsigned int div);
0083
0084 void dce3_2_afmt_write_sad_regs(struct drm_encoder *encoder,
0085 struct cea_sad *sads, int sad_count);
0086 void dce3_2_afmt_hdmi_write_speaker_allocation(struct drm_encoder *encoder,
0087 u8 *sadb, int sad_count);
0088 void dce3_2_afmt_dp_write_speaker_allocation(struct drm_encoder *encoder,
0089 u8 *sadb, int sad_count);
0090 void dce3_2_audio_set_dto(struct radeon_device *rdev,
0091 struct radeon_crtc *crtc, unsigned int clock);
0092 void dce3_2_hdmi_update_acr(struct drm_encoder *encoder, long offset,
0093 const struct radeon_hdmi_acr *acr);
0094 void dce3_2_set_audio_packet(struct drm_encoder *encoder, u32 offset);
0095 void dce3_2_set_mute(struct drm_encoder *encoder, u32 offset, bool mute);
0096 #endif