Re: [PATCH v1] ASoC: TSCS454: Add Support

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Steven,

I love your patch! Perhaps something to improve:

[auto build test WARNING on asoc/for-next]
[also build test WARNING on v4.17-rc7 next-20180530]
[if your patch is applied to the wrong git tree, please drop us a note to help improve the system]

url:    https://github.com/0day-ci/linux/commits/Steven-Eckhoff/ASoC-TSCS454-Add-Support/20180531-001905
base:   https://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound.git for-next
reproduce:
        # apt-get install sparse
        make ARCH=x86_64 allmodconfig
        make C=1 CF=-D__CHECK_ENDIAN__


sparse warnings: (new ones prefixed by >>)

>> sound/soc/codecs/tscs454.c:2454:9: sparse: Using plain integer as NULL pointer
>> sound/soc/codecs/tscs454.c:2629:5: sparse: symbol 'tscs454_set_sysclk' was not declared. Should it be static?
   sound/soc/codecs/tscs454.c:236:10: sparse: Initializer entry defined twice
   sound/soc/codecs/tscs454.c:239:10:   also defined here

Please review and possibly fold the followup patch.

vim +2454 sound/soc/codecs/tscs454.c

  2348	
  2349	static struct snd_soc_dapm_widget const tscs454_dapm_widgets[] = {
  2350		/* R_PLLCTL PG 0 ADDR 0x15 */
  2351		SND_SOC_DAPM_SUPPLY("PLL 1 Power", R_PLLCTL, FB_PLLCTL_PU_PLL1, 0,
  2352				pll_power_event,
  2353				SND_SOC_DAPM_POST_PMU|SND_SOC_DAPM_PRE_PMD),
  2354		SND_SOC_DAPM_SUPPLY("PLL 2 Power", R_PLLCTL, FB_PLLCTL_PU_PLL2, 0,
  2355				pll_power_event,
  2356				SND_SOC_DAPM_POST_PMU|SND_SOC_DAPM_PRE_PMD),
  2357		/* R_I2SPINC0 PG 0 ADDR 0x22 */
  2358		SND_SOC_DAPM_AIF_OUT("DAI 3 Out", "DAI 3 Capture", 0,
  2359				R_I2SPINC0, FB_I2SPINC0_SDO3TRI, 1),
  2360		SND_SOC_DAPM_AIF_OUT("DAI 2 Out", "DAI 2 Capture", 0,
  2361				R_I2SPINC0, FB_I2SPINC0_SDO2TRI, 1),
  2362		SND_SOC_DAPM_AIF_OUT("DAI 1 Out", "DAI 1 Capture", 0,
  2363				R_I2SPINC0, FB_I2SPINC0_SDO1TRI, 1),
  2364		/* R_PWRM0 PG 0 ADDR 0x33 */
  2365		SND_SOC_DAPM_ADC("Input Processor Channel 3", NULL,
  2366				R_PWRM0, FB_PWRM0_INPROC3PU, 0),
  2367		SND_SOC_DAPM_ADC("Input Processor Channel 2", NULL,
  2368				R_PWRM0, FB_PWRM0_INPROC2PU, 0),
  2369		SND_SOC_DAPM_ADC("Input Processor Channel 1", NULL,
  2370				R_PWRM0, FB_PWRM0_INPROC1PU, 0),
  2371		SND_SOC_DAPM_ADC("Input Processor Channel 0", NULL,
  2372				R_PWRM0, FB_PWRM0_INPROC0PU, 0),
  2373		SND_SOC_DAPM_SUPPLY("Mic Bias 2",
  2374				R_PWRM0, FB_PWRM0_MICB2PU, 0, NULL, 0),
  2375		SND_SOC_DAPM_SUPPLY("Mic Bias 1", R_PWRM0,
  2376				FB_PWRM0_MICB1PU, 0, NULL, 0),
  2377		/* R_PWRM1 PG 0 ADDR 0x34 */
  2378		SND_SOC_DAPM_SUPPLY("Sub Power", R_PWRM1, FB_PWRM1_SUBPU, 0, NULL, 0),
  2379		SND_SOC_DAPM_SUPPLY("Headphone Left Power",
  2380				R_PWRM1, FB_PWRM1_HPLPU, 0, NULL, 0),
  2381		SND_SOC_DAPM_SUPPLY("Headphone Right Power",
  2382				R_PWRM1, FB_PWRM1_HPRPU, 0, NULL, 0),
  2383		SND_SOC_DAPM_SUPPLY("Speaker Left Power",
  2384				R_PWRM1, FB_PWRM1_SPKLPU, 0, NULL, 0),
  2385		SND_SOC_DAPM_SUPPLY("Speaker Right Power",
  2386				R_PWRM1, FB_PWRM1_SPKRPU, 0, NULL, 0),
  2387		SND_SOC_DAPM_SUPPLY("Differential Input 2 Power",
  2388				R_PWRM1, FB_PWRM1_D2S2PU, 0, NULL, 0),
  2389		SND_SOC_DAPM_SUPPLY("Differential Input 1 Power",
  2390				R_PWRM1, FB_PWRM1_D2S1PU, 0, NULL, 0),
  2391		/* R_PWRM2 PG 0 ADDR 0x35 */
  2392		SND_SOC_DAPM_SUPPLY("DAI 3 Out Power",
  2393				R_PWRM2, FB_PWRM2_I2S3OPU, 0, NULL, 0),
  2394		SND_SOC_DAPM_SUPPLY("DAI 2 Out Power",
  2395				R_PWRM2, FB_PWRM2_I2S2OPU, 0, NULL, 0),
  2396		SND_SOC_DAPM_SUPPLY("DAI 1 Out Power",
  2397				R_PWRM2, FB_PWRM2_I2S1OPU, 0, NULL, 0),
  2398		SND_SOC_DAPM_SUPPLY("DAI 3 In Power",
  2399				R_PWRM2, FB_PWRM2_I2S3IPU, 0, NULL, 0),
  2400		SND_SOC_DAPM_SUPPLY("DAI 2 In Power",
  2401				R_PWRM2, FB_PWRM2_I2S2IPU, 0, NULL, 0),
  2402		SND_SOC_DAPM_SUPPLY("DAI 1 In Power",
  2403				R_PWRM2, FB_PWRM2_I2S1IPU, 0, NULL, 0),
  2404		/* R_PWRM3 PG 0 ADDR 0x36 */
  2405		SND_SOC_DAPM_SUPPLY("Line Out Left Power",
  2406				R_PWRM3, FB_PWRM3_LLINEPU, 0, NULL, 0),
  2407		SND_SOC_DAPM_SUPPLY("Line Out Right Power",
  2408				R_PWRM3, FB_PWRM3_RLINEPU, 0, NULL, 0),
  2409		/* R_PWRM4 PG 0 ADDR 0x37 */
  2410		SND_SOC_DAPM_DAC("Sub", NULL, R_PWRM4, FB_PWRM4_OPSUBPU, 0),
  2411		SND_SOC_DAPM_DAC("DAC Left", NULL, R_PWRM4, FB_PWRM4_OPDACLPU, 0),
  2412		SND_SOC_DAPM_DAC("DAC Right", NULL, R_PWRM4, FB_PWRM4_OPDACRPU, 0),
  2413		SND_SOC_DAPM_DAC("ClassD Left", NULL, R_PWRM4, FB_PWRM4_OPSPKLPU, 0),
  2414		SND_SOC_DAPM_DAC("ClassD Right", NULL, R_PWRM4, FB_PWRM4_OPSPKRPU, 0),
  2415		/* R_AUDIOMUX1  PG 0 ADDR 0x3A */
  2416		SND_SOC_DAPM_MUX("DAI 2 Out Mux", SND_SOC_NOPM, 0, 0,
  2417				&dai2_mux_dapm_enum),
  2418		SND_SOC_DAPM_MUX("DAI 1 Out Mux", SND_SOC_NOPM, 0, 0,
  2419				&dai1_mux_dapm_enum),
  2420		/* R_AUDIOMUX2 PG 0 ADDR 0x3B */
  2421		SND_SOC_DAPM_MUX("DAC Mux", SND_SOC_NOPM, 0, 0,
  2422				&dac_mux_dapm_enum),
  2423		SND_SOC_DAPM_MUX("DAI 3 Out Mux", SND_SOC_NOPM, 0, 0,
  2424				&dai3_mux_dapm_enum),
  2425		/* R_AUDIOMUX3 PG 0 ADDR 0x3C */
  2426		SND_SOC_DAPM_MUX("Sub Mux", SND_SOC_NOPM, 0, 0,
  2427				&sub_mux_dapm_enum),
  2428		SND_SOC_DAPM_MUX("Speaker Mux", SND_SOC_NOPM, 0, 0,
  2429				&classd_mux_dapm_enum),
  2430		/* R_HSDCTL1 PG 1 ADDR 0x01 */
  2431		SND_SOC_DAPM_SUPPLY("GHS Detect Power", R_HSDCTL1,
  2432				FB_HSDCTL1_CON_DET_PWD, 1, NULL, 0),
  2433		/* R_CH0AIC PG 1 ADDR 0x06 */
  2434		SND_SOC_DAPM_MUX("Input Boost Channel 0 Mux", SND_SOC_NOPM, 0, 0,
  2435				&in_bst_mux_ch0_dapm_enum),
  2436		SND_SOC_DAPM_MUX("ADC Channel 0 Mux", SND_SOC_NOPM, 0, 0,
  2437				&adc_mux_ch0_dapm_enum),
  2438		SND_SOC_DAPM_MUX("Input Processor Channel 0 Mux", SND_SOC_NOPM, 0, 0,
  2439				&in_proc_mux_ch0_dapm_enum),
  2440		/* R_CH1AIC PG 1 ADDR 0x07 */
  2441		SND_SOC_DAPM_MUX("Input Boost Channel 1 Mux", SND_SOC_NOPM, 0, 0,
  2442				&in_bst_mux_ch1_dapm_enum),
  2443		SND_SOC_DAPM_MUX("ADC Channel 1 Mux", SND_SOC_NOPM, 0, 0,
  2444				&adc_mux_ch1_dapm_enum),
  2445		SND_SOC_DAPM_MUX("Input Processor Channel 1 Mux", SND_SOC_NOPM, 0, 0,
  2446				&in_proc_mux_ch1_dapm_enum),
  2447		/* Virtual */
  2448		SND_SOC_DAPM_AIF_IN("DAI 3 In", "DAI 3 Playback", 0,
  2449				SND_SOC_NOPM, 0, 0),
  2450		SND_SOC_DAPM_AIF_IN("DAI 2 In", "DAI 2 Playback", 0,
  2451				SND_SOC_NOPM, 0, 0),
  2452		SND_SOC_DAPM_AIF_IN("DAI 1 In", "DAI 1 Playback", 0,
  2453				SND_SOC_NOPM, 0, 0),
> 2454		SND_SOC_DAPM_SUPPLY("PLLs", SND_SOC_NOPM, 0, 0, 0, 0),
  2455		SND_SOC_DAPM_OUTPUT("Sub Out"),
  2456		SND_SOC_DAPM_OUTPUT("Headphone Left"),
  2457		SND_SOC_DAPM_OUTPUT("Headphone Right"),
  2458		SND_SOC_DAPM_OUTPUT("Speaker Left"),
  2459		SND_SOC_DAPM_OUTPUT("Speaker Right"),
  2460		SND_SOC_DAPM_OUTPUT("Line Out Left"),
  2461		SND_SOC_DAPM_OUTPUT("Line Out Right"),
  2462		SND_SOC_DAPM_INPUT("D2S 2"),
  2463		SND_SOC_DAPM_INPUT("D2S 1"),
  2464		SND_SOC_DAPM_INPUT("Line In 1 Left"),
  2465		SND_SOC_DAPM_INPUT("Line In 1 Right"),
  2466		SND_SOC_DAPM_INPUT("Line In 2 Left"),
  2467		SND_SOC_DAPM_INPUT("Line In 2 Right"),
  2468		SND_SOC_DAPM_INPUT("Line In 3 Left"),
  2469		SND_SOC_DAPM_INPUT("Line In 3 Right"),
  2470		SND_SOC_DAPM_INPUT("DMic 1"),
  2471		SND_SOC_DAPM_INPUT("DMic 2"),
  2472	
  2473		SND_SOC_DAPM_MUX("CH 0_1 Mux", SND_SOC_NOPM, 0, 0,
  2474				&ch_0_1_mux_dapm_enum),
  2475		SND_SOC_DAPM_MUX("CH 2_3 Mux", SND_SOC_NOPM, 0, 0,
  2476				&ch_2_3_mux_dapm_enum),
  2477		SND_SOC_DAPM_MUX("CH 4_5 Mux", SND_SOC_NOPM, 0, 0,
  2478				&ch_4_5_mux_dapm_enum),
  2479	};
  2480	
  2481	static struct snd_soc_dapm_route const tscs454_intercon[] = {
  2482		/* PLLs */
  2483		{"PLLs", NULL, "PLL 1 Power", pll_connected},
  2484		{"PLLs", NULL, "PLL 2 Power", pll_connected},
  2485		/* Inputs */
  2486		{"DAI 3 In", NULL, "DAI 3 In Power"},
  2487		{"DAI 2 In", NULL, "DAI 2 In Power"},
  2488		{"DAI 1 In", NULL, "DAI 1 In Power"},
  2489		/* Outputs */
  2490		{"DAI 3 Out", NULL, "DAI 3 Out Power"},
  2491		{"DAI 2 Out", NULL, "DAI 2 Out Power"},
  2492		{"DAI 1 Out", NULL, "DAI 1 Out Power"},
  2493		/* Ch Muxing */
  2494		{"CH 0_1 Mux", "DAI 1", "DAI 1 In"},
  2495		{"CH 0_1 Mux", "TDM 0_1", "DAI 1 In"},
  2496		{"CH 2_3 Mux", "DAI 2", "DAI 2 In"},
  2497		{"CH 2_3 Mux", "TDM 2_3", "DAI 1 In"},
  2498		{"CH 4_5 Mux", "DAI 3", "DAI 2 In"},
  2499		{"CH 4_5 Mux", "TDM 4_5", "DAI 1 In"},
  2500		/* In/Out Muxing */
  2501		{"DAI 1 Out Mux", "CH 0_1", "CH 0_1 Mux"},
  2502		{"DAI 1 Out Mux", "CH 2_3", "CH 2_3 Mux"},
  2503		{"DAI 1 Out Mux", "CH 4_5", "CH 4_5 Mux"},
  2504		{"DAI 2 Out Mux", "CH 0_1", "CH 0_1 Mux"},
  2505		{"DAI 2 Out Mux", "CH 2_3", "CH 2_3 Mux"},
  2506		{"DAI 2 Out Mux", "CH 4_5", "CH 4_5 Mux"},
  2507		{"DAI 3 Out Mux", "CH 0_1", "CH 0_1 Mux"},
  2508		{"DAI 3 Out Mux", "CH 2_3", "CH 2_3 Mux"},
  2509		{"DAI 3 Out Mux", "CH 4_5", "CH 4_5 Mux"},
  2510		/******************
  2511		 * Playback Paths *
  2512		 ******************/
  2513		/* DAC Path */
  2514		{"DAC Mux", "CH 4_5", "CH 4_5 Mux"},
  2515		{"DAC Mux", "CH 2_3", "CH 2_3 Mux"},
  2516		{"DAC Mux", "CH 0_1", "CH 0_1 Mux"},
  2517		{"DAC Left", NULL, "DAC Mux"},
  2518		{"DAC Right", NULL, "DAC Mux"},
  2519		{"DAC Left", NULL, "PLLs"},
  2520		{"DAC Right", NULL, "PLLs"},
  2521		{"Headphone Left", NULL, "Headphone Left Power"},
  2522		{"Headphone Right", NULL, "Headphone Right Power"},
  2523		{"Headphone Left", NULL, "DAC Left"},
  2524		{"Headphone Right", NULL, "DAC Right"},
  2525		/* Line Out */
  2526		{"Line Out Left", NULL, "Line Out Left Power"},
  2527		{"Line Out Right", NULL, "Line Out Right Power"},
  2528		{"Line Out Left", NULL, "DAC Left"},
  2529		{"Line Out Right", NULL, "DAC Right"},
  2530		/* ClassD Path */
  2531		{"Speaker Mux", "CH 4_5", "CH 4_5 Mux"},
  2532		{"Speaker Mux", "CH 2_3", "CH 2_3 Mux"},
  2533		{"Speaker Mux", "CH 0_1", "CH 0_1 Mux"},
  2534		{"ClassD Left", NULL, "Speaker Mux"},
  2535		{"ClassD Right", NULL, "Speaker Mux"},
  2536		{"ClassD Left", NULL, "PLLs"},
  2537		{"ClassD Right", NULL, "PLLs"},
  2538		{"Speaker Left", NULL, "Speaker Left Power"},
  2539		{"Speaker Right", NULL, "Speaker Right Power"},
  2540		{"Speaker Left", NULL, "ClassD Left"},
  2541		{"Speaker Right", NULL, "ClassD Right"},
  2542		/* Sub Path */
  2543		{"Sub Mux", "CH 4", "CH 4_5 Mux"},
  2544		{"Sub Mux", "CH 5", "CH 4_5 Mux"},
  2545		{"Sub Mux", "CH 4 + 5", "CH 4_5 Mux"},
  2546		{"Sub Mux", "CH 2", "CH 2_3 Mux"},
  2547		{"Sub Mux", "CH 3", "CH 2_3 Mux"},
  2548		{"Sub Mux", "CH 2 + 3", "CH 2_3 Mux"},
  2549		{"Sub Mux", "CH 0", "CH 0_1 Mux"},
  2550		{"Sub Mux", "CH 1", "CH 0_1 Mux"},
  2551		{"Sub Mux", "CH 0 + 1", "CH 0_1 Mux"},
  2552		{"Sub Mux", "ADC/DMic 1 Left", "Input Processor Channel 0"},
  2553		{"Sub Mux", "ADC/DMic 1 Right", "Input Processor Channel 1"},
  2554		{"Sub Mux", "ADC/DMic 1 Left Plus Right", "Input Processor Channel 0"},
  2555		{"Sub Mux", "ADC/DMic 1 Left Plus Right", "Input Processor Channel 1"},
  2556		{"Sub Mux", "DMic 2 Left", "DMic 2"},
  2557		{"Sub Mux", "DMic 2 Right", "DMic 2"},
  2558		{"Sub Mux", "DMic 2 Left Plus Right", "DMic 2"},
  2559		{"Sub Mux", "ClassD Left", "ClassD Left"},
  2560		{"Sub Mux", "ClassD Right", "ClassD Right"},
  2561		{"Sub Mux", "ClassD Left Plus Right", "ClassD Left"},
  2562		{"Sub Mux", "ClassD Left Plus Right", "ClassD Right"},
  2563		{"Sub", NULL, "Sub Mux"},
  2564		{"Sub", NULL, "PLLs"},
  2565		{"Sub Out", NULL, "Sub Power"},
  2566		{"Sub Out", NULL, "Sub"},
  2567		/*****************
  2568		 * Capture Paths *
  2569		 *****************/
  2570		{"Input Boost Channel 0 Mux", "Input 3", "Line In 3 Left"},
  2571		{"Input Boost Channel 0 Mux", "Input 2", "Line In 2 Left"},
  2572		{"Input Boost Channel 0 Mux", "Input 1", "Line In 1 Left"},
  2573		{"Input Boost Channel 0 Mux", "D2S", "D2S 1"},
  2574	
  2575		{"Input Boost Channel 1 Mux", "Input 3", "Line In 3 Right"},
  2576		{"Input Boost Channel 1 Mux", "Input 2", "Line In 2 Right"},
  2577		{"Input Boost Channel 1 Mux", "Input 1", "Line In 1 Right"},
  2578		{"Input Boost Channel 1 Mux", "D2S", "D2S 2"},
  2579	
  2580		{"ADC Channel 0 Mux", "Input 3 Boost Bypass", "Line In 3 Left"},
  2581		{"ADC Channel 0 Mux", "Input 2 Boost Bypass", "Line In 2 Left"},
  2582		{"ADC Channel 0 Mux", "Input 1 Boost Bypass", "Line In 1 Left"},
  2583		{"ADC Channel 0 Mux", "Input Boost", "Input Boost Channel 0 Mux"},
  2584	
  2585		{"ADC Channel 1 Mux", "Input 3 Boost Bypass", "Line In 3 Right"},
  2586		{"ADC Channel 1 Mux", "Input 2 Boost Bypass", "Line In 2 Right"},
  2587		{"ADC Channel 1 Mux", "Input 1 Boost Bypass", "Line In 1 Right"},
  2588		{"ADC Channel 1 Mux", "Input Boost", "Input Boost Channel 1 Mux"},
  2589	
  2590		{"Input Processor Channel 0 Mux", "ADC", "ADC Channel 0 Mux"},
  2591		{"Input Processor Channel 0 Mux", "DMic", "DMic 1"},
  2592	
  2593		{"Input Processor Channel 0", NULL, "PLLs"},
  2594		{"Input Processor Channel 0", NULL, "Input Processor Channel 0 Mux"},
  2595	
  2596		{"Input Processor Channel 1 Mux", "ADC", "ADC Channel 1 Mux"},
  2597		{"Input Processor Channel 1 Mux", "DMic", "DMic 1"},
  2598	
  2599		{"Input Processor Channel 1", NULL, "PLLs"},
  2600		{"Input Processor Channel 1", NULL, "Input Processor Channel 1 Mux"},
  2601	
  2602		{"Input Processor Channel 2", NULL, "PLLs"},
  2603		{"Input Processor Channel 2", NULL, "DMic 2"},
  2604	
  2605		{"Input Processor Channel 3", NULL, "PLLs"},
  2606		{"Input Processor Channel 3", NULL, "DMic 2"},
  2607	
  2608		{"DAI 1 Out Mux", "ADC/DMic 1", "Input Processor Channel 0"},
  2609		{"DAI 1 Out Mux", "ADC/DMic 1", "Input Processor Channel 1"},
  2610		{"DAI 1 Out Mux", "DMic 2", "Input Processor Channel 2"},
  2611		{"DAI 1 Out Mux", "DMic 2", "Input Processor Channel 3"},
  2612	
  2613		{"DAI 2 Out Mux", "ADC/DMic 1", "Input Processor Channel 0"},
  2614		{"DAI 2 Out Mux", "ADC/DMic 1", "Input Processor Channel 1"},
  2615		{"DAI 2 Out Mux", "DMic 2", "Input Processor Channel 2"},
  2616		{"DAI 2 Out Mux", "DMic 2", "Input Processor Channel 3"},
  2617	
  2618		{"DAI 3 Out Mux", "ADC/DMic 1", "Input Processor Channel 0"},
  2619		{"DAI 3 Out Mux", "ADC/DMic 1", "Input Processor Channel 1"},
  2620		{"DAI 3 Out Mux", "DMic 2", "Input Processor Channel 2"},
  2621		{"DAI 3 Out Mux", "DMic 2", "Input Processor Channel 3"},
  2622	
  2623		{"DAI 1 Out", NULL, "DAI 1 Out Mux"},
  2624		{"DAI 2 Out", NULL, "DAI 2 Out Mux"},
  2625		{"DAI 3 Out", NULL, "DAI 3 Out Mux"},
  2626	};
  2627	
  2628	/* This is used when BCLK is sourcing the PLLs */
> 2629	int tscs454_set_sysclk(struct snd_soc_dai *dai, int clk_id, unsigned int freq,
  2630			int dir)
  2631	{
  2632		struct snd_soc_component *component = dai->component;
  2633		struct tscs454 *tscs454 = snd_soc_component_get_drvdata(component);
  2634		unsigned int val;
  2635		int bclk_dai;
  2636		int ret;
  2637	
  2638		dev_dbg(component->dev, "%s(): freq = %u\n", __func__, freq);
  2639	
  2640		ret = snd_soc_component_read(component, R_PLLCTL, &val);
  2641		if (ret < 0)
  2642			return ret;
  2643	
  2644		bclk_dai = (val & FM_PLLCTL_BCLKSEL) >> FB_PLLCTL_BCLKSEL;
  2645		if (bclk_dai != dai->id)
  2646			return 0;
  2647	
  2648		tscs454->bclk_freq = freq;
  2649		return set_sysclk(component);
  2650	}
  2651	

---
0-DAY kernel test infrastructure                Open Source Technology Center
https://lists.01.org/pipermail/kbuild-all                   Intel Corporation
_______________________________________________
Alsa-devel mailing list
Alsa-devel@xxxxxxxxxxxxxxxx
http://mailman.alsa-project.org/mailman/listinfo/alsa-devel



[Index of Archives]     [ALSA User]     [Linux Audio Users]     [Kernel Archive]     [Asterisk PBX]     [Photo Sharing]     [Linux Sound]     [Video 4 Linux]     [Gimp]     [Yosemite News]

  Powered by Linux