コグノスケ


link 未来から過去へ表示(*)  link 過去から未来へ表示

link もっと前
2018年11月28日 >>> 2018年11月15日
link もっと後

2018年11月28日

ROCK64のアナログオーディオ - その4 - I2S1が動かない問題解決

目次: ROCK64/ROCKPro64

先日(2018年11月11日の日記参照)の続きです。linux-nextでROCK64のI2S1が動きました。残る問題は2つでした。

  • I2S1はなぜか動かない
  • I2S2はSPDIFと資源が衝突して認識しない → 2018年11月11日に解決
  • ACODECはTRMに何も情報が載っていない

1番目の「I2S1はなぜか動かない」の原因が判明しました。

I2S1だけ死んでいた原因は、日記のコメントでT4さんに指摘いただいていた通り、RK3328のクロックゲートの定義がバグっていたことでした。linuxの開発MLに修正パッチをブン投げておきました。先週のどこかで取り込まれたっぽいです。良かった。

RK3328のクロック分周器はかなり対応範囲が広いので、単純にシステムクロック=fs * 256とすれば、44.1kHz系を再生するときシステムクロックが11.2896MHzになり、48kHz系を再生するときシステムクロックが12.288MHzになって、うまく再生されるだろうと考えました。

やってみると48kHz系は正常に動作しますが、44.1kHz系を流すとEINVALを返してきて、なぜかACODECまでおかしくなり、リセットするまで一切音が出なくなります。イケてないです。

クロックのレジスタはGPLL * 147 / 6400 = 11.2896MHzに正しく設定されているのに、なぜかクロックドライバは11.289599MHzだと報告してくるので、サウンドドライバが44.1kHzの整数倍じゃないと判定してEINVALを返しています。

良く見るとGPLLの周波数も491.519999MHzという変な値になっています。なぜ491.52MHzじゃないのか?491.52MHzなら先ほどの割り算は割り切れるはずなんですけどね。

あと44.1kHz系を再生するとACODECがおかしくなる仕組みも謎です。ACODECとクロックに何か関係があるのだろうか?また今度追ってみますか。

メモ: 技術系の話はFacebookから転記しておくことにした。少し加筆。

編集者:すずき(2020/10/30 01:33)

コメント一覧

  • T4さん(2018/12/04 10:00)
    まずは、おめでとうございます。

    いきなりですが、本題にはいります
    https://kernel.googlesource.com/pub/scm/linux/kernel/git/next/linux-next/+log/master/include/dt-bindings/clock/rk3328-cru.h
    https://github.com/rockchip-linux/kernel/commits/release-4.4/include/dt-bindings/clock/rk3328-cru.h

    上の二つを見比べてみて下さいな
    (上のには、如何にも日本人ぽい人がいるが 貴方かな?)

    ---

    オイオイ、一年も前に解ってた話じゃないか
    私は、これみてムッときたね。
    *) 前回の11日時点では既に解かってたけど、敢えて書かなかった
     あまりネタばらしが過ぎると、貴方の楽しみを奪うことになるからね

    以前、Torvalds が、"メンテも碌にしないくせにツリーにだけは入れたがる" って中指立てて怒ってた
    その気持ちが、私にもよくわかるよ。

    ---

    > 11.289599MHz だと報告してくるので…
    律儀に端数まで返してくるので、こんなの↓使って誤魔化してるみたいよ
    sound/soc/rockchip/rockchip_i2s.c
     div_bclk = DIV_ROUND_CLOSEST(mclk_rate, bclk_rate);
    うろ覚えなので、もしかしたらハズレかもしれない…
  • すずきさん(2018/12/05 02:04)
    ありがとうございます。Linux のコミットログに出ている名前は私ですね。

    クロック周りではありませんが RK3228 がデグレしたというメールも貰っているので、私のような素人がいじるより Rockchip の人たちが linux-next に入れてくれれば良いんですけども…。

    DIV_ROUND_CLOSEST は rockchip-linux を見ているときに発見しましたが、まだ試していないです。こんなんで動くならもうそれでいいかとも思っています。。。
  • すずきさん(2018/12/05 02:19)
    RK3228 じゃなくて RK3288 だった。
  • T4さん(2018/12/05 09:20)
    やっぱり貴方でしたか、ご苦労さまでした。

    > クロック周りではありませんが RK3228 がデグレしたというメールも貰っているので…
    > Rockchip の人たちが linux-next に入れてくれれば良いんですけども…。
    望み薄だと思うな
    ビジネス上必要だから仕方なくやってるだけで、貢献しようとか言う気持など 更々無いようにしかみえない。

    ----

    > 整数倍じゃないと判定して EINVAL を返しています。

    DIV_ROUND_CLOSEST で効果あるのは↑部分だけだね、次に進めるようになるだけで↓には効果なしです

    > なぜか ACODEC までおかしくなり、リセットするまで一切音が出なくなります

    そもそも詳細仕様が不明だから、対処方法は人夫々になるだろうね
    コレが正解というのは無いと思う。

    私も、該当の症状が消えた時点で その対処方法で良し として、
    もうそれ以上は追ってない。
  • すずきさん(2018/12/10 12:33)
    Linux に contribute するかどうかは、
    企業の判断によるので、仕方ないですね…。

    rockchip-linux があるだけマシなのかもしれません。

    ACODEC はまだ追っていませんが、TRM に仕様も何もないので、
    ご指摘の通り、正解は不明ですね。Rockchip の方々が登場するまでは、
    とりあえず動けば良いんじゃないかと思っています。
open/close この記事にコメントする



2018年11月24日

電車広告

山手線の新型車両の車内広告は、横並びの3つの液晶ディスプレイを使いますが、各社で広告の見せ方が違って面白いです。

左から並べたとき、

  • 動画A、B、C(日テレ、日産)
  • 動画A、A、A(シスコ、モビット)

動画、静止画の混在パターンもありました。

  • 静止画a、動画A、静止画a(Google、JR)
  • 動画A、静止画a、動画A

静止画のみのパターンもあります。

  • 静止画a、b、c(シースリー)
  • 静止画a、a、a(官公庁)

不思議なもので、3画面全て動画じゃなくても見栄えはします。しかし同じ静止画にされると、映っているものに関わらず、手抜き感を強く感じます。

メモ: 技術系の話はFacebookから転記しておくことにした。

編集者:すずき(2018/11/27 23:42)

コメント一覧

  • コメントはありません。
open/close この記事にコメントする



2018年11月18日

ゲーミングスマホ

ASUS、ゲーミングスマホ「ROG Phone」を11月23日に発売 - ケータイWatch を読んで。

ゲーミングスマホを見ていると、割と高い(11万円)し、ゲーム画面が小さいし、これ売れるのかな?と思いますけど、スマホに吸収された機能って、何だかんだ言われつつ最後には駆逐されているし、いずれゲーム機もスマホに吸収されるんですかね?

スマホは「独自」と「最高性能」が売りで、ゲーム機は「均一」と「最低性能を保証」が売りで、設計の方向性の違いがあるので、個人的にはしばらくはゲーム機の置き換えは難しいだろうと踏んでいますけども。

PCの代わり?

FacebookでゲーミングPCの延長線ではないかというコメントを貰いました。言われてみればゲーム機というより、PCに近い設計思想だなと思いました。

スマホが当たり前の世代だと、PCを触ったことのない人も多いと聞くので、ゲーミングPCがそのうちスマホに喰われるかもしれませんね。

メモ: 技術系の話はFacebookから転記しておくことにした。一部加筆した。

編集者:すずき(2018/11/27 23:37)

コメント一覧

  • コメントはありません。
open/close この記事にコメントする



2018年11月17日

挙動のおかしいKindle Fire HD

目次: Kindle

Kindle Fireがおかしいのは今に始まったことではないのですが、いくつかのタイトルのマンガがダウンロードできません。困りました。

Kindle Fireで本をダウンロードする方法は、私の知る限り4つありますが、うまくいったりいかなかったり変な挙動です。

  • ライブラリの作品名クリック: NG
  • Kindleストアの「ダウンロード」(オレンジ色): NG
  • シリーズページの「今すぐ読む」(緑色): OK
  • サンプル版の最後のページから「製品版を購入」: エラー

ちなみにPCとAndroidにもKindleのアプリはありますが、どちらも正常にダウンロードできます。

  • PC版Kindle: OK
  • Android版Kindle: OK

Kindle Fireは安さが魅力的ですが、非常にイマイチな出来です。初代Kindle Fire HDも100冊くらいでハング連発したり起動不能になったり挙動不審でしたし、今使っている第七世代Kindle Fire HDもハングこそしませんが、上記のような変な挙動をします。

Kindleストアで買った本なのに「この書籍はDRMで保護されているので表示できません」エラーが出たこともありました。はあ?何言ってるの??と思って、もう一回表示させたら何事もなかったかのように表示されます。本当に意味不明です。

DRM掛かってる本なんてAmazonの本しかないよ!

Kindle Fire HD復活

最近は、新しく買ったマンガまでダウンロードできなくなってしまい、せっかく買ったのに読めなくて困っています。これはいよいよファクトリリセットか?マンガもアカウント設定も何もかも消えるから、再設定が面倒くさいんだよなーなどと考えていたのですが。

謎の「コンテンツ管理サービス」というアプリのデータを消去したら、ダウンロードできない病が直った気がします。

とりあえずこの状態でしばらく運用してみようと思います。

Kindle Fire HDの代わりは?

Kindleはもう嫌になったので、次は買わないと思います。しかし、困ったことに代わりになりそうなタブレットがありません。

Androidタブレット市場は、Kindleが利益度外視の安値攻勢で全て焼き払ってしまいました。特にマンガを読むのに適した10インチ級のタブレットは、新製品がほとんど発売されません。困ったね……。

メモ: 技術系の話はFacebookから転記しておくことにした。一部加筆。

編集者:すずき(2021/12/08 03:49)

コメント一覧

  • コメントはありません。
open/close この記事にコメントする



2018年11月16日

OSSと仕様書

オープンソース製品の「仕様」 - 赤帽エンジニアブログを読んで。

前職ではLinuxに限らずOSSの仕様について質問されたことは何度かありますが、今同じことを聞かれたら、この記事を紹介したいですね。仕様が〜!と質問してくる人に対して感じていた、モヤモヤ感をスッキリ説明してくれるとても良い内容です。

今は自動車関連の会社に在籍している訳ですが、自動車の考え方と、OSSの考え方は合わなさそうな気がしました。

とはいえ今の時代、ソフトウェア開発において、OSSを完全に無視することはできませんし、OSSの劣化コピーなんて素人が作っても品質悪いだけで、金と時間の無駄なので、どこかうまく折り合いをつける必要があるでしょうね。

メモ: 技術系の話はFacebookから転記しておくことにした。11/11の投稿が元、一部加筆。

編集者:すずき(2018/11/27 23:01)

コメント一覧

  • コメントはありません。
open/close この記事にコメントする



2018年11月15日

Windows 10とSamba

WindowsからアクセスするファイルサーバにはSambaを入れていますが、なぜかWindows 10から接続できるマシンと、接続できないマシンがあって、ずっと理由が分からずほったらかしにしていました。

結論から言えば、Sambaで無効なユーザでログインを試みた際に、ゲストにフォールバックする機能を有効にしていることが原因で、Windows 10がサーバへの接続を拒否していました。

これはSambaのmap to guest = bad userに設定されていると発生します。大抵のディストリビューションでSambaをインストールすると、この設定になっていると思います。設定の意味ですがWindows 10側のユーザ名がAAAAだとして、Samba側のユーザ名にAAAAが存在しない場合、Sambaは不明なユーザをゲストユーザとしてログインさせようとするそうです。

この動きに対してWindows 10は拒否反応を示して、接続を切ってしまいます。不明なユーザなら、ログイン確認画面を開いてユーザ名から確認すれば良いのに、何も出さずに「接続できませんでした」と言ってくる始末です。

問題を解決するにはSambaのmap to guest = neverに設定すれば直りました。Windows 10がユーザ名とパスワードを聞いてくるようになります。

なお、現象の見分け方は、イベントビューア(eventvwr.msc /s)の
[アプリケーションとサービスログ] - [Microsort] - [Windows] - [SMBClient] - [Security]
を見たときに、エラー、イベントID 31017が記録されていて、

Windowsのエラーイベント

安全でないゲスト ログオンを拒否しました。

ユーザー名: 
サーバー名: (サーバのIPアドレス、コンピュータ名などが入る)

ガイダンス:
このイベントは、サーバーがユーザーを未認証のゲストとしてログオンさせようとした結果、
クライアントによって拒否されたことを示します。ゲスト ログオンでは、署名と暗号化などの
標準のセキュリティ機能はサポートされません。このため、ゲスト ログオンは、重要な
データをネットワーク上に漏えいさせる可能性のあるman-in-the-middle攻撃に対して脆弱
です。Windowsでは、ゲスト ログオンは既定で無効になっています。Microsoftでは、安全
でないゲスト ログオンを有効にすることは推奨していません。

こういうエラーが記録されていたら、該当していると思われます。

編集者:すずき(2018/11/17 01:29)

コメント一覧

  • hdkさん(2018/11/17 08:18)
    -in-に色がついていますね :-)
    この設定、たぶん昔のWindowsも同様に拒否されるんだと思います。ウチではいつもユーザー名を指定して接続を使っていました。ファイルコピーが主な用途だったので、OpenSSHが使えるようになった今は外からscp/sftpで済ませてしまいますが...
  • すずきさん(2018/11/17 13:15)
    hdk さん

    色は自動で付けているので…、たまに変になります。お気になさらず。

    昔の Windows でも発生していたかどうかはわからないです。ググっても出てこなかったんですが、困っている人は居ないのかなあ…。

    確かに Windows 10 なら SSH も使えますね。ファイルコピーという意味では等価ですが、Samba なら Windows 側から見たとき、ファイルシステムと統合してくれるのが利点ですね。
  • hdkさん(2018/11/17 21:07)
    あっ、拒否されるというのは昔のWindowsにWindows 10からつなぐと拒否されるのではという意味でした。わかりにくくてすみません。
  • すずきさん(2018/11/17 22:47)
    なるほど、Windows 10 と古い Windows の間でも同じ問題があるってことですね。

    しかしそれだとなおさら同じ問題で困っている人が居そうなものなのですが…。探し方が悪かったかなあ??
open/close この記事にコメントする



link もっと前
2018年11月28日 >>> 2018年11月15日
link もっと後

管理用メニュー

link 記事を新規作成

<2018>
<<<11>>>
----123
45678910
11121314151617
18192021222324
252627282930-

最近のコメント5件

  • link 20年6月19日
    すずきさん (04/06 22:54)
    「ディレクトリを予め作成しておけば良いです...」
  • link 20年6月19日
    斎藤さん (04/06 16:25)
    「「Preferencesというメニューか...」
  • link 21年3月13日
    すずきさん (03/05 15:13)
    「あー、このプログラムがまずいんですね。ご...」
  • link 21年3月13日
    emkさん (03/05 12:44)
    「キャストでvolatileを外してアクセ...」
  • link 24年1月24日
    すずきさん (02/19 18:37)
    「簡単にできる方法はPowerShellの...」

最近の記事3件

  • link 20年2月22日
    すずき (04/17 02:22)
    「[Zephyr - まとめリンク] 目次: Zephyr導入、ブート周りHello! Zephyr OS!!Hello! Ze...」
  • link 24年4月16日
    すずき (04/17 02:05)
    「[Zephyr SDKのhosttoolsは移動してはいけない、その2 - インストール時のバイナリ書き換え] 目次: Zep...」
  • link 24年4月15日
    すずき (04/17 01:47)
    「[Zephyr SDKのhosttoolsは移動してはいけない、その1 - 移動させると動かなくなる] 目次: ZephyrZ...」
link もっとみる

こんてんつ

open/close wiki
open/close Linux JM
open/close Java API

過去の日記

open/close 2002年
open/close 2003年
open/close 2004年
open/close 2005年
open/close 2006年
open/close 2007年
open/close 2008年
open/close 2009年
open/close 2010年
open/close 2011年
open/close 2012年
open/close 2013年
open/close 2014年
open/close 2015年
open/close 2016年
open/close 2017年
open/close 2018年
open/close 2019年
open/close 2020年
open/close 2021年
open/close 2022年
open/close 2023年
open/close 2024年
open/close 過去日記について

その他の情報

open/close アクセス統計
open/close サーバ一覧
open/close サイトの情報

合計:  counter total
本日:  counter today

link About www.katsuster.net
RDFファイル RSS 1.0

最終更新: 04/17 02:22