Received: by 10.192.165.148 with SMTP id m20csp3776977imm; Mon, 7 May 2018 19:37:00 -0700 (PDT) X-Google-Smtp-Source: AB8JxZoTAPxwRuUVCJY83T1O2XY2Qd/DBFsmpOE7clNJn9zzlb6hzZ8L+Q+DC7wf3t3LcKXLFecs X-Received: by 2002:a17:902:595e:: with SMTP id e30-v6mr39294198plj.233.1525747020469; Mon, 07 May 2018 19:37:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525747020; cv=none; d=google.com; s=arc-20160816; b=Xlv9QQA8yvV/YuM4Ku0gx4+O+TUPWyv62ft6H+VRNDGmbp8vKsvxUOV7ohv+OD1vDI gNU/AUaSz2MFJlQc5JYcso4AbwWiTDONW6A2MtmgEB9IsvMrIAqRsf0/nqUHyqqTxOSX laT3rJHDYtz8JQKAAJfqu0oUIwJKYKyYrrTG9p3T8YyZBFRrOr5LeN4kcJQO/2yUhIF3 q7QQI4BQBRhLeIFRaZOP0EDm4KQLA+bOmbAPTstL4rS6AmugFuxX1O1B7Ratza7VKZT+ W9NoMew9+rHFkaFl+WQTcNcuoCdITFOyMyxSc7FcOaUwndYqdzuhskMFwKawoFEiaZk6 a+Wg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:to:message-id:date:subject:cc:from :dkim-signature:arc-authentication-results; bh=ca3aHlg3r+E1liRxnBIiHuk97ByKQCG0t4CnkJ1qDnc=; b=XQbAFydrPUYS/3hcfD0iINzK9v9RgITD9XjyPHq812aWLpKjdFVC080MguTd0brdsB yVsriOSkNva4YrDPqgehraRvwbhCBAq/NVoVT3Pbd5T+LUBfAHNfnuY7FOlQmm1Etn41 ve/NspP8M0zZE6Op3ezoHiiFXP8+/E2876x1EnhUgj+rCstokrd8/HyOZJOUYzs5CMas KdcR2iIf8ODTfx1z8pZIYvNZ2hShv8LfsK2gnES1XpioHz23LBnnJMAavgDpbIgu6wMu 9bFKY7NVWyrFqVEuzPXi0VStu1I1yMSqwqR69Pjab5TRjfMywSMmcwkWodOzwh0V0KUm 1JdA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@gmail.com header.s=20161025 header.b=djk3JWK2; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b6-v6si18573719pgc.166.2018.05.07.19.36.46; Mon, 07 May 2018 19:37:00 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=fail header.i=@gmail.com header.s=20161025 header.b=djk3JWK2; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753938AbeEHCcG (ORCPT + 99 others); Mon, 7 May 2018 22:32:06 -0400 Received: from mail-it0-f46.google.com ([209.85.214.46]:35651 "EHLO mail-it0-f46.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753782AbeEHCcC (ORCPT ); Mon, 7 May 2018 22:32:02 -0400 Received: by mail-it0-f46.google.com with SMTP id q72-v6so4347949itc.0 for ; Mon, 07 May 2018 19:32:02 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id; bh=ca3aHlg3r+E1liRxnBIiHuk97ByKQCG0t4CnkJ1qDnc=; b=djk3JWK2YM+G6lhueVwGO4fIkH+Gh3e1E4IVHrsHWCjuhZH09ersZBGauiHopB1Rkd SOygWOdt1FA0DnO33VQJisgpW1qpgXriSuDl+hjIQCuqswfnqjfxWHKreOqyjwnFG1U1 Jt2QIkqsPBdwOspbD92RMfADH/WtQRr9rxza3a67+0a+uhdvu6YNjYesL1jnHHTazv1J UquIOChRVKaxIhBeYNcRJDGLKWSn09djED1YX8qm3W8F1Qau95/UX3/8KNu73eJjUqmX snmzjUc9+schqIXKBepVXfKOeprwcVDstuJPmwU8s60lgOsz75ziDCrZK1DVNWaDqzvD 0Now== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=ca3aHlg3r+E1liRxnBIiHuk97ByKQCG0t4CnkJ1qDnc=; b=tn6YhTwEdLxCiKteffgKgutalbnisxMlt6u8jhBP3y81EM9FILA+Fl4J+C0FbeaGQr OQ8Hc6gs3ZPKmTIlfTD1bZCwurdi+vCPhlmWEajw2D2eGUeLWM0QixCnloSMLQAlEpj/ 8fKYUKnq4d15n+OzNfAEYX1roVKnhvYsYyepVJPxgxw/DUTM8XLNcnTEewKHfEC4BgDQ NCnxspyrLbCPYSvgHXm9qRGfvAvzghL9FQIxSQ8Pj7JFCoOgfEtDDuKp6dTDesnjdsr3 384Buz0BfXD0OA1seS9YrqJCoKIPl3GvVG2DgBpBJU+2sxtHaGPLkysDQoN0C/2Pt8b/ GuXA== X-Gm-Message-State: ALKqPwd5iDOmbp01ktrgti5xEJXPBTRzIokAnuu8xk1lXjVqSmbic3+i DJd+zXUAb1OVyMIWe20tT0o= X-Received: by 2002:a24:ddcc:: with SMTP id t195-v6mr4138897itf.77.1525746721835; Mon, 07 May 2018 19:32:01 -0700 (PDT) Received: from localhost.localdomain ([2605:a000:1316:4462:d951:8657:56b7:4002]) by smtp.googlemail.com with ESMTPSA id l22-v6sm4947954ita.8.2018.05.07.19.32.00 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Mon, 07 May 2018 19:32:01 -0700 (PDT) From: Connor McAdams Cc: o-takashi@sakamocchi.jp, Connor McAdams , Jaroslav Kysela , Takashi Iwai , =?UTF-8?q?J=C3=A9r=C3=A9my=20Lefaure?= , alsa-devel@alsa-project.org, linux-kernel@vger.kernel.org Subject: [PATCH v4 00/13] ALSA: hda/ca0132: Patch Series for Recon3Di and Sound Blaster Z Support Date: Mon, 7 May 2018 22:31:08 -0400 Message-Id: <1525746683-18535-1-git-send-email-conmanx360@gmail.com> X-Mailer: git-send-email 2.7.4 To: unlisted-recipients:; (no To-header on input) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patchset adds support for the Sound Blaster Z and the Recon3Di. In order to figure out how to get these cards to work, I made a program called QemuHDADump[1], which uses the trace function of qemu to see interactions with the memory mapped pci BAR space of the card being used in the virtual machine. With this, I obtain the CORB buffer location to get the command verbs, and then dump them each time the buffer rolls over. This program may be useful for fixing other HDA related driver issues where there is no documentation for the device. So far, I have been able to get all features supported on the Sound Blaster Z and the Recon3Di. All output and input effects work, all inputs and outputs work, and just about anything else I can think of. I have also added new controls in order to select the new inputs and outputs, as well as controls to change the effect levels and presets. I have also added the ability to use firmware taken from the Windows drivers of both the Sound Blaster Z and Recon3Di. I am trying to get into contact with Creative to get permission to redistribute these along with the current file included with the Chromebook, but they have not been very responsive. Luckily, the cards work with the Chromebook firmware just fine, although I believe there has to be a reason they have different firmware in Windows. I will not link to the firmwares here, but if you look up my thread on Creative Labs forums, you will find the link to download the firmwares there. I am willing to help get the other non-working cards such as the ZxR and the newer AE-5 working too, but I will need someone willing to run QemuHDADump in a virtual machine in order to get the commands. So, in summary: -This patchset makes the cards work better than they did before (they really didn't work before) -This patchset leaves the original chromebook related stuff alone. Thanks. [1] https://github.com/Conmanx360/QemuHDADump Bugs: ------------------------------------------------------------------------------- Recon3Di: (Reported by Mariusz Ceier) ******************* -Occasionally switching between rear and front mic breaks the input until computer is shutdown or put to sleep. -Surround Sound works, but is inconsistent. Sometimes, just updating the volume fixes it, and sometimes, it requires a restart. Sound Blaster Z: ******************* -none that I'm aware of. Version changes: ------------------------------------------------------------------------------- v1: ******************* -Massive patch formatting failure, please ignore v1. v2: ******************* -Fixed patch formatting failure. v3: ******************* -Fixed mem_base unmap, instead of checking for QUIRK_SBZ on exit, have it check if the area is mapped, and if it is, unmap it. Also make it unmap after all other commands are finished. -Change notification of failure to map mem_base from codec_dbg to codec_warn, and use codec_info to tell the user that their card might have been incorrectly identified as a Sound Blaster Z. -Remove commented out commands in sbz_exit_chip function, only reintroduce them when their functions are defined. v4: ******************* -Split patch into smaller pieces. -Added const to alt_out_presets array. -Fixed command that was commented out and only put it in when it was actually used. Connor McAdams (13): ALSA: hda/ca0132: R3Di and SBZ quirk entires + alt firmware loading ALSA: hda/ca0132: Add pincfg for SBZ + R3Di, add fp hp auto-detect ALSA: hda/ca0132: Add PCI region2 iomap for SBZ ALSA: hda/ca0132: Add extra exit functions for R3Di and SBZ ALSA: hda/ca0132: add extra init functions for r3di + sbz ALSA: hda/ca0132: update core functions for sbz + r3di ALSA: hda/ca0132: add dsp setup related commands for the sbz ALSA: hda/ca0132: Add dsp setup + gpio functions for r3di ALSA: hda/ca0132: add the ability to set src_id on scp commands ALSA: hda/ca0132: add alt_select_in/out for R3Di + SBZ ALSA: hda/ca0132: Add DSP Volume set and New mixers for SBZ + R3Di ALSA: hda/ca0132: add ca0132_alt_set_vipsource ALSA: hda/ca0132: Add new control changes for SBZ + R3Di sound/pci/hda/patch_ca0132.c | 3057 ++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 2941 insertions(+), 116 deletions(-) -- 2.7.4