Tested with the following devices (not exhaustive): - Dell Latitude E7240 - Dell Precision M6800 and M4800 - Asrock Z87E-ITX - Asrock Z87M OC Formula - Asrock Fatal1ty Z87 Professional Change-Id: I4f6e8c97b5122101de2f36bba8ba9f8ddd5b813a Signed-off-by: Iru Cai <mytbk920423@gmail.com> Signed-off-by: Nicholas Chin <nic.c3.14@gmail.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/30890 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Angel Pons <th3fanbus@gmail.com> Reviewed-by: Nico Huber <nico.h@gmx.de>
		
			
				
	
	
		
			68 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			1.3 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{})
 | |
| 	/* Lynx Point */
 | |
| 	RegisterPCI(0x8086, 0x8c20, azalia{})
 | |
| 	RegisterPCI(0x8086, 0x9c20, azalia{})
 | |
| }
 |