223a30ce11
There is no need to use hexadecimal values in azalia codec IDs, nor need to print a redundant "LPC bridge PCI-LPC bridge" comment. Change-Id: I6658051c7a3d5b65a86ccca8bab7834bf4628a16 Signed-off-by: Angel Pons <th3fanbus@gmail.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/38901 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: HAOUAS Elyes <ehaouas@noos.fr>
64 lines
1.2 KiB
Go
64 lines
1.2 KiB
Go
package main
|
|
|
|
import (
|
|
"fmt"
|
|
"sort"
|
|
)
|
|
|
|
type azalia struct {
|
|
}
|
|
|
|
func (i azalia) Scan(ctx Context, addr PCIDevData) {
|
|
az := Create(ctx, "hda_verb.c")
|
|
defer az.Close()
|
|
|
|
Add_gpl(az)
|
|
az.WriteString(
|
|
`#include <device/azalia_device.h>
|
|
|
|
const u32 cim_verb_data[] = {
|
|
`)
|
|
|
|
for _, codec := range ctx.InfoSource.GetAzaliaCodecs() {
|
|
fmt.Fprintf(az, "\t0x%08x,\t/* Codec Vendor / Device ID: %s */\n",
|
|
codec.VendorID, codec.Name)
|
|
fmt.Fprintf(az, "\t0x%08x,\t/* Subsystem ID */\n",
|
|
codec.SubsystemID)
|
|
fmt.Fprintf(az, "\t%d,\t\t/* Number of 4 dword sets */\n",
|
|
len(codec.PinConfig)+1)
|
|
fmt.Fprintf(az, "\tAZALIA_SUBVENDOR(%d, 0x%08x),\n",
|
|
codec.CodecNo, codec.SubsystemID)
|
|
|
|
keys := []int{}
|
|
for nid, _ := range codec.PinConfig {
|
|
keys = append(keys, nid)
|
|
}
|
|
|
|
sort.Ints(keys)
|
|
|
|
for _, nid := range keys {
|
|
fmt.Fprintf(az, "\tAZALIA_PIN_CFG(%d, 0x%02x, 0x%08x),\n",
|
|
codec.CodecNo, nid, codec.PinConfig[nid])
|
|
}
|
|
az.WriteString("\n");
|
|
}
|
|
|
|
az.WriteString(
|
|
`};
|
|
|
|
const u32 pc_beep_verbs[0] = {};
|
|
|
|
AZALIA_ARRAY_SIZES;
|
|
`)
|
|
|
|
PutPCIDev(addr, "")
|
|
}
|
|
|
|
func init() {
|
|
/* I82801GX/I945 */
|
|
RegisterPCI(0x8086, 0x27d8, azalia{})
|
|
/* BD82X6X/sandybridge */
|
|
RegisterPCI(0x8086, 0x1c20, azalia{})
|
|
/* C216/ivybridge */
|
|
RegisterPCI(0x8086, 0x1e20, azalia{})
|
|
}
|